data:image/s3,"s3://crabby-images/900cf/900cf5408ccf91aa601ff402ba330222be353d99" alt=""
Graphics Library
Espruino has a built-in graphics library, exposed via the Graphics class.
On most boards (without built in displays) you can create your own instance(s) of the Graphics class using a module that is designed to interface to a display (see 'Graphics Drivers' below), or you can manually create you own using one of the Graphics.createXYZ
functions.
On the few boards that do contain LCDs, there is a predefined variable called g
(which is an instance of the Graphics Object).
Note: All coordinates in the Graphics library treat 0,0 as the top left corner of the display. However you can rotate or mirror what you draw using the Graphics.setRotation method.
Graphics Drivers
Below are a list of currently available modules that will interface to hardware and create a Graphics object for you:
data:image/s3,"s3://crabby-images/45123/451238ff17fa1db2c053658b1921d48e5b7b0188" alt="SSD16XX e-Paper display driver SSD16XX e-Paper display driver"
data:image/s3,"s3://crabby-images/df105/df105400f7676606bb0fd92b1e981bfa6e571653" alt="ST7735 LCD controller ST7735 LCD controller"
data:image/s3,"s3://crabby-images/af289/af289f62f4bd1c2f881f55559fecb0583da707cc" alt="LCD_SPI_UNBUF LCD Library LCD_SPI_UNBUF LCD Library"
data:image/s3,"s3://crabby-images/b1107/b1107bff67b25bea25df983577e05b42dd625b7b" alt="ST7789 LCD controller ST7789 LCD controller"
data:image/s3,"s3://crabby-images/943eb/943eb73edbb240db62f1b45625a6e408c05e4859" alt="ILI9341 LCD controller ILI9341 LCD controller"
data:image/s3,"s3://crabby-images/7a047/7a047fa3eef3bfd493d7289c9252050c8d75218e" alt="SSD1306 OLED driver SSD1306 OLED driver"
data:image/s3,"s3://crabby-images/013f4/013f4f1e84e7aa227e34c5c52c407e56f5934d4a" alt="SSD1606 e-Paper display driver SSD1606 e-Paper display driver"
data:image/s3,"s3://crabby-images/325ad/325adce9c0ffd22dfeeb57238f3f84dbcef241ce" alt="PCD8544 LCD driver (Nokia 5110) PCD8544 LCD driver (Nokia 5110)"
data:image/s3,"s3://crabby-images/122ac/122ac8de3569a63014146417442399d13741b372" alt="SH1106 OLED driver SH1106 OLED driver"
data:image/s3,"s3://crabby-images/79f95/79f95127a2c3613b26fb9ecf7ee7e7cab517cd2d" alt="TV Out TV Out"
data:image/s3,"s3://crabby-images/fb7b0/fb7b044f160214e4f717e0637c496be534baa956" alt="SSD1351 OLED display driver SSD1351 OLED display driver"
data:image/s3,"s3://crabby-images/0daad/0daad2a10c5d7093018dc28342dda2659291bb1a" alt="Sharp Memory LCD Sharp Memory LCD"
data:image/s3,"s3://crabby-images/ba519/ba5199c690a0a173a396983361387aeaa9ca7dcc" alt="LPD-6416 LED Matrix Display LPD-6416 LED Matrix Display"
data:image/s3,"s3://crabby-images/5040b/5040beb8fe89362afbf62a5e9b216de26dc68204" alt="ILI9163 LCD controller ILI9163 LCD controller"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="SSD1327 OLED driver SSD1327 OLED driver"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="ST7565/ST7567 128x64 Monochrome LCD driver ST7565/ST7567 128x64 Monochrome LCD driver"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="IS31FL3731 Charlieplexed LED controller IS31FL3731 Charlieplexed LED controller"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="SH1107 OLED driver SH1107 OLED driver"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="TM1640 8x8 Matrix LED Shield driver TM1640 8x8 Matrix LED Shield driver"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="Digole LCD driver (monochrome) Digole LCD driver (monochrome)"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="Charlieplexed LED Module Charlieplexed LED Module"
Note: several of the graphics drivers use offscreen buffers. This means that
draw operations won't immediately effect the display, and a method needs calling
to copy the buffer's data onto the screen. By convention this method is usually
called .flip()
.
Internal (Offscreen) Use
If you don't already have a graphics object set up then you can create a Graphics class which renders to an ArrayBuffer:
Graphics.prototype.print = function() {
for (var y=0;y<this.getHeight();y++)
console.log(new Uint8Array(this.buffer,this.getWidth()*y,this.getWidth()).toString());
};
var g = Graphics.createArrayBuffer(8,8,8);
g.setColor(1);
g.drawString("Hi",0,0);
g.print();
// 1,0,1,0,0,1,0,0
// 1,0,1,0,0,0,0,0
// 1,1,1,0,1,1,0,0
// 1,0,1,0,0,1,0,0
// 1,0,1,0,1,1,1,0
// 0,0,0,0,0,0,0,0
// 0,0,0,0,0,0,0,0
// 0,0,0,0,0,0,0,0
See the Graphics.createArrayBuffer
reference for more information on possible arguments that can be used.
Or you can create a Graphics instance which calls your function whenever a pixel needs to be drawn:
var g = Graphics.createCallback(8,8,1,function(x,y,c) {
print(x+","+y);
});
g.drawLine(0,0,2,2)
//0,0
//1,1
//2,2
Dumping Graphics contents
Espruino can output the contents of a Graphics instance to the Web IDE's REPL
using g.dump()
.
For example you can just type g.dump()
in the REPL to see what
is in the Graphics instance g
.
Internally, g.dump()
works using
g.asURL()
which creates a base64
encoded bitmap of the Graphics instance.
Text / Fonts
Simple Hello World text using a bitmap font:
g.clear();
g.drawString("Hello World",0,0);
The final two arguments are colours (background and foreground)
Or use vector fonts, which are scaleable!
g.clear();
g.setFontVector(40);
g.setColor(1,0,0);
g.drawString("Hello",0,0); // 40px high in red
g.setFontVector(60);
g.setColor(0,1,0);
g.drawString("World",40,40); // 60px high in green
Note: Some non-official Espruino boards don't have vector font support built-in.
You can then switch back to the bitmap font using:
g.setFontBitmap();
You can also use custom Bitmap Fonts. For more information, see Fonts
Circles
In Espruino versions since 1.87, support for drawing circles has been added.
You can draw filled or outlined circles using the two circle functions. For each, the current foreground colour will be used.
The three required arguments are x,y,rad
. The x
and y
coordinates for the centre position of the circle and rad
the radius of the circle.
// Draw a circle
g.drawCircle(100,100,50); // A circle with a radius of 50, centred at 100x100
// Draw a filled circle
g.fillCircle(100,100,50); // A filled circle with a radius of 50, centred at 100x100
However if you want to add your own support in earlier versions then you can always do something like this:
g.fillCircle = function(x,y,rad) {
var pts = parseInt(rad)/2;
var a = [];
for (var i=0;i<pts;i++) {
var t = 2*i*Math.PI/pts;
a.push(x+Math.sin(t)*rad);
a.push(y+Math.cos(t)*rad);
}
g.fillPoly(a);
}
Random Lines
Randomly draw lines on the screen:
g.clear();
while (true) {
g.setColor(Math.random(),Math.random(),Math.random());
g.drawLine(
Math.random()*g.getWidth(), Math.random()*g.getHeight(),
Math.random()*g.getWidth(),Math.random()*g.getHeight())
}
Offscreen Graphics
Images / Bitmaps
Espruino has a function called Graphics.drawImage
which can be used to draw images.
Images are either a special kind of object or a String.
Objects
Objects are of the form:
{
width : int,
height : int,
bpp : int (bits per pixel, optional - default 1),
transparent : int (transparent colour index, optional),
palette : Uint16Array/string (colour palette),
buffer : string/arraybuffer (image data)
}
For instance this is a 8x8
pixel, 1 bit smiley face
where any pixel that is 0
is treated as transparent:
var img = {
width : 8, height : 8, bpp : 1,
transparent : 0,
buffer : new Uint8Array([
0b00000000,
0b01000100,
0b00000000,
0b00010000,
0b00000000,
0b10000001,
0b01111110,
0b00000000,
]).buffer
};
Strings
You can also specify the image as a string or arraybuffer, in the following form:
- For nontransparent:
[width, height, bpp, pixel data...]
- For nontransparent with 16 bit palette:
[width, height, bpp|64, col0_lo, col0_hi, col1_lo, col1_hi, ..., pixel data...]
- For transparent:
[width, height, bpp|128, transparent col, pixel data...]
- For transparent with 16 bit palette:
[width, height, bpp|64|128, transparent col, col0_lo, col0_hi, col1_lo, col1_hi, ..., pixel data...]
Multiple frames
An image can contain multiple frames of the same size (eg for an animation). To do this just ensure that the image bitmap contains all the frames one after the other, then specify
the frame when drawing with Graphics.drawImage
: g.drawImage(img, x, y, { frame : n });
.
To generate an image like this, the easiest way is to use the Image Converter with the images tiled vertically one after the other, and then change the width. As an example, if you want to store 10, 64x64px images:
- Arrange all images vertically into one bitmap, 64x640px
- Load this into the image converter, choose
Image Object
as the output, and convert - Change the
height
field in the output from640
to64
It is also possible to create an image with frames in an image string, but you would have to modify the height in the image string (second byte):
var tmp = atob("......"); // decode the image
E.toArrayBuffer(tmp)[1]=64; // or whatever you image height is
print(btoa(tmp)); // re-encode as base64
Note: For this to work, each frame of the image must contain a multiple of 8 bits - eg. (width * height * bpp) & 7 == 0
.
Creating images
You can:
- Specify images manually (as above)
- Use
Graphics.createImage
to specify a 1 bit image in a more compact, readable way:
var img = Graphics.createImage(`
X X
X
X X
XXXXXX
`);
Use
Graphics.asImage
to create these images from an existing Graphics instance.Upload images to your board's storage (and convert at the same time) with the Web IDE's
Storage
button.Use our online Image Converter to convert an image into Base64-encoded JavaScript that can be pasted into your code.
Load bitmaps directly (eg. from an SD card) with the BMPLoader module:
var img = require("BMPLoader").load(require('fs').readFileSync("foo.bmp"));
g.drawImage(img, 10, 10);
Beware: Microcontrollers don't have much memory - even a small 128x128 pixel 8 bit image may be too big to fit in Espruino's memory!
Rendering
You can then simply draw images to the screen wherever you want:
g.drawImage(img, 10, 10);
// or draw an image directly from Storage
g.drawImage(require("Storage").read("myimage.img"), 10, 10);
// draw an image twice the size
g.drawImage(img, 10, 10, {scale:2});
// draw a large, rotated image
g.drawImage(img, 10, 10, {scale:1.5, rotate:Math.PI/4});
If you use a single-bit image, the foreground and background colors will be used instead of the image's colors. Otherwise the color data will be copied directly so it's an idea to use a bitmap of the same bit depth as your display.
See the reference for Graphics.drawImage
for more information...
Creating an image via command-line
The easiest solution is to use our online Image Converter.
Or you can use command-line tools locally to create a raw image that can be uploaded separately. It's best to install ImageMagick. Then you can type commands like:
# Create a 24 bit RGB image called output.raw
convert myimage.png rgb:output.raw
# Create a 24 bit, 16x16 pixel RGB image called output.raw
convert myimage.png -resize 16x16\! -depth 8 rgb:output.raw
# Create an 8 bit, 16x16 pixel Greyscale image called output.raw
convert myimage.png -resize 16x16\! -depth 8 gray:output.raw
# Create a 1 bit, 16x16 pixel black and white image called output.raw
# Note this one only works if your image is a multiple of 8 pixels wide
convert myimage.png -resize 16x16\! -depth 1 gray:output.raw
On Linux, you can type base64 --wrap=0 myfilename.raw
to convert the raw file to base64 - or on other platforms you can use the File Converter webpage.
Once you've got the base64 encoded image, simply decode it with atob
and create an ArrayBuffer from it. For instance this is the Espruino logo:
var img = {
width : 32, height : 32, bpp : 1,
transparent : 0,
buffer : E.toArrayBuffer(atob("AAAAAAAAeAAAf/4AH/+bAH/ABQBoAAeAaAADwHQAAf5aAfCfS/8/sUXP//1G//AdQ/wAHUAAAB1AAAAdQAAAHWAAABNgAAAeYAAAEOAAABDgAAAQ8AAAGPgAABz4AAAcfAAAnD4AP/A+B//AHz//wA///4AAP+AAABgAAAAAAAA="))
};
Decoding encoded images
Sometimes you might want to turn an image that's in Espruino format back into a PNG file. The best way to do this is to just use Espruino.
You can just write to the existing Graphics instance and dump the whole thing out to the Web IDE's console (but then you'll have to manually crop it to size):
// the image to decode
let img = atob("GBiBAAAAAAAAAAAAAA//8B//+BgAGBgAGBgAGB//+B//+B//+B/++B/8+B/5+B8z+B+H+B/P+B//+B//+B//+A//8AAAAAAAAAAAAA==")
// draw the image and dump it out
g.clear(1).drawImage(img).dump();
Or you can create a Graphics instance of the correct size and dump that out:
// the image to decode
let img = atob("GBiBAAAAAAAAAAAAAA//8B//+BgAGBgAGBgAGB//+B//+B//+B/++B/8+B/5+B8z+B+H+B/P+B//+B//+B//+A//8AAAAAAAAAAAAA==")
// create a Graphics instance of the correct size
let m = g.imageMetrics(img);
let t = Graphics.createArrayBuffer(m.width,m.height,m.bpp,{msb:true});
// draw to the Graphics instance and dump it to the IDE console
t.drawImage(img).dump();
// you can also use .asBMP/.asURL to get the contents in a variable
Tutorials using Graphics
data:image/s3,"s3://crabby-images/76d8b/76d8b4a419247a543bd69af97a225a26c0678364" alt="Font Converter Font Converter"
data:image/s3,"s3://crabby-images/ad9b5/ad9b51975484e12f1719389153c7af7a6476e816" alt="Bluetooth LE Printers Bluetooth LE Printers"
data:image/s3,"s3://crabby-images/1eb3d/1eb3dc7713e7fe50a2c88a5ed712592419d240ad" alt="Graph Library Graph Library"
data:image/s3,"s3://crabby-images/26757/267579d1c5c5756d08254f4021edb6b6b83e47eb" alt="Tilt Hydrometer Brew Display with Pixl.js Tilt Hydrometer Brew Display with Pixl.js"
data:image/s3,"s3://crabby-images/f7048/f70485aac6aff221aa2017bacdf461adafa12942" alt="Dinosaur Game Dinosaur Game"
data:image/s3,"s3://crabby-images/c6255/c6255f0627dc83c3b710a16bc61a7d5ccaf46cc5" alt="Pixl.js Wireless Temperature Display Pixl.js Wireless Temperature Display"
data:image/s3,"s3://crabby-images/ec705/ec705888618de3bbb695108ac5210c6602b65f30" alt="Fonts Fonts"
data:image/s3,"s3://crabby-images/45c84/45c8415b2aa9bd8a6ecac88c2abe50db4cb3eaee" alt="Image Slideshow with ILI9341 display Image Slideshow with ILI9341 display"
data:image/s3,"s3://crabby-images/5ff46/5ff46528945b3f6a5004edc0e7395e25b30e420f" alt="Converting Bitmaps for Graphics Converting Bitmaps for Graphics"
data:image/s3,"s3://crabby-images/9a123/9a1235bde720f4002824c5fcca44de4a2bccb0e6" alt="Bangle.js Graphics Bangle.js Graphics"
data:image/s3,"s3://crabby-images/e7edb/e7edb5ae5edd35bb3322e8b34d3322ae7029023b" alt="Ethernet Webcam Display Ethernet Webcam Display"
data:image/s3,"s3://crabby-images/b7b1e/b7b1ee8b0b7d2345248f41305f0cd571c2cbc057" alt="Rubble Watch Rubble Watch"
data:image/s3,"s3://crabby-images/86cdf/86cdfdd1b7c67c569f057943bde63d74f7f82f81" alt="Pocket 'walking' GPS Pocket 'walking' GPS"
data:image/s3,"s3://crabby-images/4cfa0/4cfa0fd22af9504cefc3882e1db46a27de943e89" alt="Asteroids Game Asteroids Game"
data:image/s3,"s3://crabby-images/dca45/dca45d524faee279b8e04fcd77cfb5a6fe49f29f" alt="Flappy Bird Game Flappy Bird Game"
data:image/s3,"s3://crabby-images/e8df4/e8df47287aecb79c64afe8a96ab2b143ce0e6997" alt="Pixl.js Wireless Weather Station Pixl.js Wireless Weather Station"
data:image/s3,"s3://crabby-images/126e7/126e7b21cc09a46698a12e3875bf7aecb2399b82" alt="Freezer Alarm Freezer Alarm"
data:image/s3,"s3://crabby-images/4198e/4198e500ffff17897db2dafddc3c53a95b8dbeac" alt="Pixl.js Simple Logger Pixl.js Simple Logger"
data:image/s3,"s3://crabby-images/91270/91270809abd1c1ef2f6ccc41d87d41d0f89ab24e" alt="Pixl.js Pong Game Pixl.js Pong Game"
data:image/s3,"s3://crabby-images/4d294/4d294c77f3047b04bfb18a4df7bd2d601ad0273f" alt="Pixl.js Multiplayer Pong Game Pixl.js Multiplayer Pong Game"
data:image/s3,"s3://crabby-images/c086a/c086a7ebc702f6e34feb95499c9f0e7f64744234" alt="Morphing 7 Segment Clock Morphing 7 Segment Clock"
data:image/s3,"s3://crabby-images/24eb2/24eb209d1a3ed12a8b2eab8a9d6f84c17d1482e2" alt="Pixl.js Home Computer Pixl.js Home Computer"
data:image/s3,"s3://crabby-images/dbd0d/dbd0d3487f135e316197246af22444f0b7f8ad33" alt="Wireless Temperature Sensor Wireless Temperature Sensor"
data:image/s3,"s3://crabby-images/5d740/5d74024048ebd4f0ae014bee70a6683117af17d4" alt="Pico Clock Pico Clock"
data:image/s3,"s3://crabby-images/b5662/b5662cfbe35e65bf12f02fa09a8322a76dbd8747" alt="Pixl.js Spectrum Analyser Pixl.js Spectrum Analyser"
data:image/s3,"s3://crabby-images/4a3f5/4a3f59a01e8606478363715bb731ce4132a8b868" alt="Pixl.js Oscilloscope Pixl.js Oscilloscope"
data:image/s3,"s3://crabby-images/7f25b/7f25b545c248f719adbdcddc4568b252591027ed" alt="Espruino Home Computer Espruino Home Computer"
data:image/s3,"s3://crabby-images/c5c8a/c5c8aa52a95dc168079fe478db767a86df615dee" alt="Pixl.js Clock Pixl.js Clock"
data:image/s3,"s3://crabby-images/a3079/a3079991a3cccbb93049f3986cc562bcf15fb2d6" alt="Animal Guessing Game Animal Guessing Game"
data:image/s3,"s3://crabby-images/d1888/d18884e820378845b1cca0cbc548c81048c43071" alt="Platform Game Platform Game"
data:image/s3,"s3://crabby-images/82531/82531f831621ad3724e7b48fc3bb8961df5c61ca" alt="Pixl.js Temperature Display Pixl.js Temperature Display"
data:image/s3,"s3://crabby-images/72d51/72d51899db9a9f651f1a1ea1decbd7585eceaab5" alt="Pixl.js Conference Badge - Rotating Cube Pixl.js Conference Badge - Rotating Cube"
data:image/s3,"s3://crabby-images/a3af1/a3af19312c3336cfecd552360b15af35a31543fe" alt="YouTube View Counter YouTube View Counter"
data:image/s3,"s3://crabby-images/98296/9829633643a3d877f1f195c4ee7c04404120f56b" alt="Snake Game Snake Game"
data:image/s3,"s3://crabby-images/2d3c9/2d3c9549b303fc554a51754dad13d866ffcec6bb" alt="5 Minute Wire Loop Game 5 Minute Wire Loop Game"
data:image/s3,"s3://crabby-images/fef67/fef670547b8682e39751c7370874f2b8a5a6c97e" alt="Pico Weather Station Pico Weather Station"
data:image/s3,"s3://crabby-images/2e9e5/2e9e59926a59cdcf578572ea2e75a58c72dada85" alt="Pico LCD Display Hello World Pico LCD Display Hello World"
data:image/s3,"s3://crabby-images/1dceb/1dcebab163589a61ff5e268fb718f5cb30e42174" alt="Pico Electronic Dice Pico Electronic Dice"
data:image/s3,"s3://crabby-images/5e38b/5e38bf7dd593c79a1c24b155c1c2030db58523c2" alt="Controlling Pico from a Computer Controlling Pico from a Computer"
data:image/s3,"s3://crabby-images/88d13/88d136d91655147d39ac9ae892f48f7f61b6a159" alt="AA/AAA Battery Charger AA/AAA Battery Charger"
data:image/s3,"s3://crabby-images/2abbb/2abbbd5c3830c4457c604f01596fabe5d44866e4" alt="VT100 Terminal Emulator VT100 Terminal Emulator"
data:image/s3,"s3://crabby-images/8a5fe/8a5fee927446f39f0479102258f473dd29e992f8" alt="WiFi Xively Humidity/Temperature Sensor with Display WiFi Xively Humidity/Temperature Sensor with Display"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="Graphical Menu Graphical Menu"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="Bitmap file (BMP) Loader Module Bitmap file (BMP) Loader Module"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="Temperature Graph on a PCD8544 display, with DS18B20 temperature sensor Temperature Graph on a PCD8544 display, with DS18B20 temperature sensor"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="Temperature on a PCD8544 display, with DS18B20 temperature sensor Temperature on a PCD8544 display, with DS18B20 temperature sensor"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="Reaction Timer using RGB123 Reaction Timer using RGB123"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="HTTP Image Loader HTTP Image Loader"
This page is auto-generated from GitHub. If you see any mistakes or have suggestions, please let us know.