Skip to content

DisplayText Command

RTurala edited this page Nov 29, 2018 · 1 revision

FUTURE CAPABILITY

The functionality described here is expected to be merged from https://github.com/arendst/Sonoff-Tasmota/pull/3748

The DisplayText command is used to display text as well as graphics and graphs on LCD, OLED and ePaper displays attached to tasmota. The command argument is a string that is by default printed on the screen but that can also contain embedded commands enclosed in brackets [].

In order to use the DisplayText command the DisplayMode must be set to zero or other modes must be disabled before compilation with #undef USE_DISPLAY_MODES1TO5.

Command list

In the list below p stands for parameter and may be a number from 1 to n digits. On monochrome graphics displays things are drawn into a local frame buffer and send to the display either via the d command or automatically at the end of the command.

Positioning

  • l p = sets a character line to print at
  • c p = sets a character column to print at
  • x p = sets the x position for consecutive prints
  • y p = sets the y position for consecutive prints

Text is printed at the last provided position, either l or y for the vertical position, and either x or x for the horizontal position. Neither x nor y are advanced/updated after printing text.

Line primitives

  • h p = draws a horizontal line with length p (x is advanced)
  • v p = draws a vertical line with length p (y is advanced)
  • L p:p = draws a line to p:p (x,y are advanced)
  • k p = draws a circle with radius p
  • K p = draws a filled circle with radius p
  • r p:p = draws a rectangle with p with and p height
  • R p:p = draws a filled rectangle with p with and p height

Miscellaneous

  • z = clear the display
  • i = (re)init the display (in e-paper mode with partial update)
  • I = (re)init the display (in e-paper mode with full update)
  • d = update the display
  • D p = switch display auto updates on(p=1)/off(p=0), when off display must be updated via cmd d
  • o = switch display off
  • O = switch display on
  • t = display Tasmota time in HH:MM
  • T = display Tasmota date in DD.MM.YY
  • s p = set text scaling for classic GFX font (scaling factor 1...N)
  • f p = set font (1=12, 2=24,(opt 3=8)) if font==0 the classic GFX font is used
  • C p = set color (0,1) for black or white (later for color displays index colors)

Line chart

Up to 4 line charts may be defined.

  • G n:xp:yp:xs:ys:t:ymax:ymin = defines a line chart, where:
    • n = chart number (0-3) + optional ticks (see below)
    • xp = x position
    • yp = y position
    • xs = x size
    • ys = y size
    • t = time in minutes for total chart
    • ymin = float chart minimum y
    • ymax = float chat maximum y

Ticks may be defined by adding tick numbers to the first parameter n:

  • Add 4 times the number of x ticks desired

  • Add 256 times the number of y ticks desired Example: for graph 1 with 4 X ticks and 3 Y ticks use G785 (785 = 1 + 44 +3256).

  • g n:v Adds a (float) value v to chart n

Notes about e-paper displays

E-paper displays have 2 operating modes: full update and partial update. While full update delivers a clean and sharp picture it has the disadvantage of taking several seconds for the screen update and shows severe flickering during update. Partial update is quite fast (300 ms) with no flickering but there is the possibility that erased content is still slightly visible. To "whiten" the display it is therefore useful to perform a full update in regular intervals (e.g each hour).

Defines => USE_SOFTSPI, USE_DISPLAY_EPAPER29, USE_DISPLAY_EPAPER42

Hardware connections:

I2C displays are connected in the usual manner and defined via tasmota pin selection. The I2C Adress must be given by DisplayAddress XX, e.g. 60, and the model set with DisplayModel ,e.g. 2 for SSD1306. To permanently turn the display on set DisplayDimmer 100. Display rotation can be permanently set using DisplayRotate X (0-3).

E-paper displays are connected via 3 wire SPI (CS, SCLK, MOSI) the other 3 Interface lines of the display (DC, Reset, busy) may be left unconnected. The jumper on the circuit board of the display must be set to 3 wire SPI.

Examples

Print Text at size 1 on line 1, column 1:

DisplayText [s1l1c1]Hello how are you?

Draw a rectangle and draw text inside with size 2 and 7 chars padded with spaces:

DisplayText [x85y95h130v30h-130v-30s2p7x90y100]37.25 C

Clear screen:

DisplayText [z]

Draw rectangle from x,y with width and height:

DisplayText [x50y50r200:100]

Display local sensors using rules

Show sensor values, time and a separation line, whiten display every 60 minutes (line breaks and indentation added for readability):

rule1 on tele-SHT3X-0x44#Temperature do DisplayText [f1p7x0y5]%value% C endon
      on tele-SHT3X-0x44#Humidity do DisplayText [f1p10x70y5]%value% %[x0y20h296x250y5t] endon
      on tele-BMP280#Pressure do DisplayText [f1p10x140y5]%value% hPa endon
      on Time#Minute|60 do DisplayText [Tt] endon

Show 4 analog channels (line breaks and indentation added for readability):

rule1 on tele-ADS1115#A0 do DisplayText [s1p21c1l01]Analog1: %value% adc endon
      on tele-ADS1115#A1 do DisplayText [s1p21c1l3]Analog2: %value% adc endon
      on tele-ADS1115#A2 do DisplayText [s1p21c1l5]Analog3: %value% adc endon
      on tele-ADS1115#A3 do DisplayText [s1p21c1l7]Analog4: %value% adc endon

Show BME280 + SGP30 (line breaks and indentation added for readability):

rule1 on tele-BME280#Temperature do DisplayText [s1p21x0y0]Temp: %value% C endon
      on tele-BME280#Humidity do DisplayText [s1p21x0y10]Hum : %value% %% endon
      on BME280#Pressure do DisplayText [s1p21x0y20]Prss: %value% hPa endon
      on tele-SGP30#TVOC do DisplayText [s1p21x0y30]TVOC: %value% ppb endon
      on tele-SGP30#eCO2 do DisplayText [s1p21x0y40]eCO2: %value% ppm [s1p0x0y50]Time: [x35y50t] endon

Notes about display drivers:

Waveshare has 2 kinds of display controllers: with partial update and without partial update. The 2.9 inch driver is for partial update and should support also other waveshare partial update models with modified WIDTH and HEIGHT parameters. The 4.2 inch driver is a hack which makes the full update display behave like a partial update and should probably work with other full update displays.

The drivers are subclasses of the Adafruit GFX library. The class hierarchy is LOWLEVEL :: Paint :: Renderer :: GFX, where:

  • GFX: unmodified Adafruit library
  • Renderer: the interface for Tasmota
  • Paint: the modified pixel driver for e-paper
  • there are several virtual functions that can be subclassed down to LOWLEVEL.

The display dispatcher only does the class init call. All other calls go to the Renderer class.

In black and white displays a local ram buffer must be allocated before calling the driver. This must be set to zero on character or TFT color displays.

To use the 400x300 e-paper display the Arduino library 2.4 or later must be used because it leaves much more RAM available than prior versions. This display requires 15k of RAM!

About 28 k flash is used by these 4 drivers, the epd fonts use about 9k space, which can be if-def'd.

  • SSD1306 = 1,15 k
  • SH1106 = 1,18 k
  • EPD42 = 2,57 k
  • EPD29 = 2,1 k
  • Display and Render class about 12 k

Home
Theo's Tasmota Tips
What's New

Getting Started

Upload tools

Usage

Devices - Additional Info

Home Automation Integration

Other Integrations

Further Topics

ESP32

Misc

Clone this wiki locally