-
Notifications
You must be signed in to change notification settings - Fork 227
GDISPLAY module
This page is under construction
This module contains functions for accessing graphic SPI displays, and gives the programmer an api to work with SPI graphic displays in a unified form, regardless of the used display.
There are functions in this module that are not compatible with some displays. For example, it's not possible to show a JPG image (true color) in a monochrome display. Don't worry about this, the module raises an exception in this case.
Chipset | Variants | Comments | Identifier |
---|---|---|---|
ST7735 | ST7735_18 | Black tab, 1.8" | gdisplay.ST7735_18 |
ST7735B_18 | Blue tab, 1.8" | gdisplay.ST7735B_18 | |
ST7735G_18 | Green tab, 1.8" | gdisplay.ST7735G_18 | |
ST7735G_144 | Green tab, 1.44" | gdisplay.ST7735G_144 | |
ST7735_096 | Green tab, 0.96" | gdisplay.ST7735_096 | |
PCD8544 | --- | Nokia 5110 | gdisplay.PCD8544 |
ILI9341 | --- | --- | gdisplay.ILI9341 |
SSD1306 | 128 x 32 | 128 x 32 pixels | gdisplay.SSD1306_128_32 |
128 x 64 | 128 x 64 pixels | gdisplay.SSD1306_128_64 | |
96 x 16 | 96 x 16 pixels | gdisplay.SSD1306_96_16 |
Font | Identifier | Comments |
---|---|---|
Default | gdisplay.FONT_DEFAULT | |
DejaVu 18 | gdisplay.FONT_DEJAVU18 | |
DejaVu 24 | gdisplay.FONT_DEJAVU24 | |
Ubuntu 16 | gdisplay.FONT_UBUNTU16 | |
Comic 24 | gdisplay.FONT_COMIC24 | |
Tooney 32 | gdisplay.FONT_TOONEY32 | |
Minya 24 | gdisplay.FONT_MINYA24 | |
7segments | gdisplay.FONT_7SEG | |
LCD | gdisplay.FONT_LCD | Old style font, used in the past in smalls LCD, such as NOKIA 5110 |
Screen's coordinates are referenced as points. Many functions of this module expects one ore more points as an argument. For example, the gdisplay.putpixel has the following arguments:
- point: the point coordinates where draw the pixel.
- color (optional): the color to use for draw the pixel.
You can reference a point in two ways:
-
table notation: in this case the point is referenced as a table in format {x, y}, where x and y are the point's coordinates.
gdisplay.putpixel({10,10})
-
legacy notation: in this case the point's coordinates are referenced as classical function arguments, using one argument for x and another argument for y.
gdisplay.putpixel(10,10)
We recommend to use the table notation, because source code is more clear.
Colors are referenced by it's R (red), G (green) and B (blue) components. Many functions of this module expects one ore more colors as an argument. For example, the gdisplay.clear has a color argument.
You can reference a color in two ways:
-
table notation: in this case the color is referenced as a table in format {r, g, b}, where r, g and b are the color's components.
gdisplay.clear({255,0,0})
-
a system color: in this case the color is referenced using a predefined gdisplay constant.
gdisplay.clear(gdisplay.RED)
Available system colors:
Constant Constant gdisplay.BLACK gdisplay.BLUE gdisplay.CYAN gdisplay.DARKCYAN gdisplay.DARKGREEN gdisplay.GREEN gdisplay.GREENYELLOW gdisplay.LIGHTGREY gdisplay.MAGENTA gdisplay.MAROON gdisplay.NAVY gdisplay.OLIVE gdisplay.ORANGE gdisplay.PINK gdisplay.PURPLE gdisplay.RED gdisplay.WHITE gdisplay.YELLOW
Initialize the display and clear the screen.
After the initialization the display has the following settings:
- All the pixels are turn off.
- Text foreground is set to white.
- Text background is set to black.
- Text rotation is set to 0 degrees.
- Text warp is set to false.
- Text transparency is set to true.
Arguments:
- chipset: chipset used by the display. Can be any identifier from the supported chipsets.
- orientation (optional): display orientation, can be either gdisplay.LANDSCAPE, gdisplay.LANDSCAPE_FLIP, gdisplay.PORTRAIT, or gdisplay.PORTRAIT_FLIP. Default orientation is gdisplay.LANDSCAPE.
- framed (optional): if true frame buffer is used. Default is false.
- address (optional): for I2C displays, is the display address in the I2C bus. If missing or 0 the default address is applied.
Returns: nothing, or an exception.
-- Attach an ILI9341 display with orientation LANDSCAPE_FLIP,
-- and without frame buffer
gdisplay.attach(gdisplay.ILI9341, gdisplay.LANDSCAPE_FLIP, false)
Get current screen size (width & height) in pixels. Remember that for the same display, the screen size may vary depending on the screen's orientation.
Arguments: nothing.
Returns: the screen size, or an exception
- xsize: width of the screen in pixels
- ysize: height of the screen in pixels
Clear the display to the specified color. Any text property is change when the display is clear, such as text wrap, text orientation, etc ...
Arguments:
- color (optional): the color used to fill de display. The default color depends on the display chipset, for example in TFT displays it is black, and in monochrome LCD displays it is white. In general, the default color is one that keeps all of the screen pixels off.
Returns: noting, or an exception.
-- Clear the display to RED
gdisplay.clear(gdisplay.RED)
-- Clear the display to RED
gdisplay.clear({255, 0, 0})
-- Clear the display to default color
gdisplay.clear()
Turns the display off and preserve power. Back light has to be turned off separately.
Arguments: nothing Returns: nothing or an exception
Turns the display on.
Arguments: nothing Returns: nothing or an exception
Arguments:
- invert: if true, show inverted colors, and if false, show normal colors. Returns: nothing or an exception
Set the display orientation, and clear the screen to the default color. The default color depends on the display chipset, for example in TFT displays it is black, and in monochrome LCD displays it is white. In general, the default color is one that keeps all of the screen pixels off.
Arguments:
- orientaion: display orientation, can be either gdisplay.LANDSCAPE, gdisplay.LANDSCAPE_FLIP, gdisplay.PORTRAIT, or gdisplay.PORTRAIT_FLIP.
Returns: nothing, or an exception.
-- Set the display orientation to LANDSCAPE_FLIP
gdisplay.setorient(gdisplay.LANDSCAPE_FLIP)
Sets the clipping area coordinates. All writing to the display is clipped to that area.
Arguments:
- point0: top left point of the clipping area.
- point1: bottom right point of the clipping area.
Returns: nothing, or an exception.
-- Set the clipping area to (10,10) - (50, 50)
gdisplay.setclipwin({10,10}, {50, 50})
-- Draw a pixel outside the clipping area. Pixel is not show
-- on the display.
gdisplay.putpixel({1,1})
-- Draw a pixel inside the clipping area. Pixel is show
-- on the display.
gdisplay.putpixel({20,20})
Reset the clipping area to full screen.
Arguments: nothing Returns: nothing, or an exception.
-- Reset the clipping area to full screen
gdisplay.resetclipwin()
-- Pixel now is show on the display.
gdisplay.putpixel({1,1})
Text functions are used for write text.
Set the font used when writing the text to display.
Arguments:
- font identifier: the identifier of the system's font. Can be any identifier from the system fonts.
- font name: if the programmer wants to use a custom font, the file name with the font definition.
Returns: nothing, or an exception.
-- Set the font to UBUNTU16_FONT
gdisplay.setfont(gdisplay.UBUNTU16_FONT)
Write text on the display using the current font.
Arguments:
-
point: the point coordinates where draw text. You can use the following special coordinates to drawing text:
-
For the x component:
gdisplay.RIGHT: align text to the right gdisplay.LEFT: align text to the left gdisplay.CENTER: align text to the center gdisplay.LASTX: draw text at last x position
-
For the y component:
gdisplay.BOTTOM: align text to the bottom gdisplay.CENTER: align text to the center gdisplay.LASTY: draw text at last y position
-
-
string | number | table: the text to display that can be either a string, a number or a table.
-
foreground (optional): the foreground color. If not specified the current foreground color is used.
-
background (optional): the background color. If not specified the current background color is used.
Returns: nothing, or an exception.
-- Attach the display and clear
gdisplay.attach(gdisplay.ILI9341, gdisplay.LANDSCAPE_FLIP, false)
gdisplay.clear()
-- Set the font to UBUNTU16_FONT
gdisplay.setfont(gdisplay.UBUNTU16_FONT)
-- Write text at 0,0
gdisplay.write({0,0},"WHITECAT")
-- Attach the display and clear
gdisplay.attach(gdisplay.ILI9341, gdisplay.LANDSCAPE_FLIP, false)
gdisplay.clear()
-- Set the font to UBUNTU16_FONT
gdisplay.setfont(gdisplay.UBUNTU16_FONT)
-- Write text at the center of the string
gdisplay.write({gdisplay.CENTER,gdisplay.CENTER},"WHITECAT")
Set the foreground color. The foreground color is used to write text when the color is not specified.
Arguments:
- color: the foreground color.
Returns: nothing, or an exception.
Set the background color. The background color is used to write text when the color is not specified.
Arguments:
- color: the background color.
Returns: nothing, or an exception.
Get current font size in pixels. Useful if FONT_7SEG is used to get actual character width and height.
Arguments: nothing
Returns: the font size, or an exception
- xsize: width of the font character in pixels. For the proportional fonts, maximal char width will be returned.
- ysize: height of the font character in pixels.
Get current font height in pixels.
Arguments: nothing
Returns: height of the font character in pixels, or an exception.
Set text rotation when writing text.
Arguments:
- angle: rotation angle, in degrees (from 0 to 360)
Returns: nothing, or an exception.
Set transparency when writing the text.
Arguments:
- transparency: if true only text foreground color is shown, if false all the text background is filled with the background color.
Returns: nothing, or an exception.
Set line wrapping when writing the text. If wrap is true, text will be wrap to new line, otherwise it will be clipped.
Arguments:
- wrap: if true wrapping is on.
Returns: nothing, or an exception.
Forces fixed width print when using proportional fonts.
Arguments:
- force: if true force fixed. Returns: nothing, or an exception.
Draws pixel on display at the point coordinates using the current foreground color, or a given color.
Arguments:
- point: the point coordinates where draw the pixel.
- color (optional): the color to use for draw the pixel. If not specified, the foreground color is used.
Returns: nothing, or an exception.
-- Draw a pixel at point (50, 50), using current foreground
gdisplay.putpixel(50, 50)
-- Draw a pixel at point (50, 50), using current foreground
gdisplay.putpixel({50, 50})
-- Draw a pixel at point (50, 50), using RED color
gdisplay.putpixel({50, 50}, gdisplay.RED)
-- Draw a pixel at point (50, 50), using RED color
gdisplay.putpixel({50, 50}, {255, 0, 0})
Draws line from point 1 to point 2, using the current stroke color, or a given color.
Arguments:
- point 1: the start point coordinates.
- point 2: the end point coordinates.
- color (optional): the color to use for draw the line. If not specified, the stroke color is used.
Returns: nothing, or an exception.
-- Get the screen size
dw, dh = gdisplay.getscreensize()
-- Draw a diagonal line, from the first screen's point to
-- the last screen's point
gdisplay.line({0,0}, {dw - 1, dh - 1})
Draws a width * height rectangle starting at point, using the current stroke color, or a given color. If the fill color is given, fills the rectangle.
Arguments:
- point: the start point coordinates.
- width: width of the rectangle in pixels.
- height: height of the rectangle in pixels.
- color (optional): the color to use for draw the rectangle. If not specified, the stroke color is used.
- fill color (optional): the color to use for fill the rectangle.
Returns: nothing, or an exception.
-- Get the screen size
dw, dh = gdisplay.getscreensize()
-- Draw a diagonal line, from the first screen's point to
-- the last screen's point
gdisplay.line({0,0}, {dw - 1, dh - 1})
Returns: nothing, or an exception.
-- Get the screen size
dw, dh = gdisplay.getscreensize()
-- Display 50 x 50 white rectangle, starting at screen's center, and blue filled
gdisplay.rect({dw / 2 - 1, dh / 2 - 1}, 50, 50, {255, 255, 255}, {0,0,255})
Draws a circle centered at center point with a given radius, using the current stroke color, or a given color. If the fill color is given, fills the circle.
Arguments:
- center point: the center point coordinates.
- radius: circle's radius in pixels.
- color (optional): the color to use for draw the rectangle. If not specified, the stroke color is used.
- fill color (optional): the color to use for fill the rectangle.
Returns: nothing, or an exception.
-- Get the screen size
dw, dh = gdisplay.getscreensize()
-- Draw a 80-pixel radius white circle, centered at the screen, and blue filled
gdisplay.circle({dw /2 - 1, dh / 2 - 1}, 80, {255, 255, 255}, {0,0,255})
Draws pixel on display at the point coordinates using the current foreground color, or a given color.
Arguments:
- point: the point coordinates where draw qr-code's upper-left corner.
- text: the content of qr-code
- eccmode (optional): one of gdisplay.ECC_LOW, gdisplay.ECC_MEDIUM, gdisplay.ECC_QUARTILE or gdisplay.ECC_HIGH
- multisize (optional): multiply the size of the qr-code by this factor, e.g. use 2 to make the size double, 3 to make the size triple, etc.
Returns: nothing, or an exception.
gdisplay.qrcode(0,0,"text-to-encode")
gdisplay.qrcode(0,0,"text-to-encode",gdisplay.ECC_HIGH)
gdisplay.qrcode({0,0},"text-to-encode"[,gdisplay.ECC_LOW[, 2]])
This function supports qr code segmentation which can save a lot of qr-space and so make the qr-code smaller: https://www.nayuki.io/page/optimal-text-segmentation-for-qr-codes
gdisplay.qrcode(0,0,{{mode=gdisplay.MODE_ALPHANUM,val="WIFI:S:MY-EXTRA-LONG-NAME"},{mode=gdisplay.MODE_BYTE,val=";T:WPA;P:87654321;;"}})
As shown above, segmentation is achieved by providing a specially formatted table instead of the "text-to-encode". The above could be written as:
segment1 = {mode=gdisplay.MODE_ALPHANUM,val="WIFI:S:MY-EXTRA-LONG-NAME"}
segment2 = {mode=gdisplay.MODE_BYTE,val=";T:WPA;P:87654321;;"}
content = {segment1, segment2}
gdisplay.qrcode({0,0}, content)
Each segment consists of a table with two attributes: mode
and val
. Instead of val
the key value
or text
can be used, which are synonym.
Supported values for mode
are: gdisplay.MODE_NUMERIC, gdisplay.MODE_ALPHANUM, gdisplay.MODE_BYTE or gdisplay.MODE_ECI
Display the "Senyera", the Catalonian's flag. This flag has been selected as a testimonial of where Lua RTOS has been developed.
function senyera()
-- Attach
gdisplay.attach(gdisplay.ILI9341, gdisplay.LANDSCAPE_FLIP, false)
gdisplay.clear()
-- Get the screen size
local dw, dh = gdisplay.getscreensize()
-- The Senyera has 9 bands
local band = dh / 9
-- The Senyera has 2 colors
-- even bands are yellow, and odd bands are red
color1 = gdisplay.YELLOW
color2 = gdisplay.RED
-- Draw bands
i = 1
y = 0
for i = 1,9,1 do
if (i % 2 == 1) then
color = color1
else
color = color2
end
gdisplay.rect({0, y}, dw - 1, band, color, color)
y = y + band - 1
end
end
senyera()