Skip to content

Latest commit

 

History

History
 
 

commodetto

Moddable SDK - Commodetto Examples

Copyright 2021 Moddable Tech, Inc.
Revised: November 4, 2021

These examples demonstrate how to use features of Commodetto, a bitmap graphics library that provides a 2D graphics API. Commodetto includes the lightweight Poco rendering engine, a display list renderer able to efficiently render a single scanline at a time, saving considerable memory by eliminating the need for a frame buffer.

Most of the examples are designed for a QVGA (320x240) screen, but many work on a variety of screen sizes. All of the examples in this folder run on the desktop simulator with the exception of the mini-drag example.

This document provides a brief description of each example and a preview of each app running on the desktop simulator. If you are looking for an example that demonstrates how to use a specific feature, see the list below. Keep in mind that this list provides only a few recommendations and is not a complete list of examples that use each feature.


cfe8x8

The cfe8x8 example demonstrates how to use a simple embedded 8 x 8 bitmap font. This is the simplest example of implementing a new Commodetto Font Engine.


cfeNFNT

The cfeNFNT example renders text using an NFNT font resource, the bitmap font format of the original Macintosh. Includes an Commodetto Font Engine. for NFNT.


clip

The clip example shows how to use the drawing clip. The clip stack is maintained by the Poco rendering engine.


clock

The clock example shows a simple on screen clock with a blinking colon. It demonstrates how to center text to build an application that works on any screen size.


docs

The docs example includes all of the examples in the Poco documentation.


epaper-mini-travel-time

The epaper-mini-travel-time is a miniature version of the piu/epaper-travel-time example designed for Moddable Three.

See the blog post "Getting the Most from ePaper Displays" for more information about this example.


fonts

The fonts example displays messages in English and Japanese using eight different fonts. It demonstrates how to use scalable TrueType and OpenType fonts in projects.

See the blog post "Using More Fonts More Easily in IoT Products" for more information about this example.


gif

The gif example shows an animated flag. It demonstrates how to render an animated GIF directly.


image-frames

The image-frames example shows an animated flag. It demonstrates how to render an animated GIF converted to a lightweight color cell encoded stream.


jpeghttp and jpegstream

The jpeghttp and jpegstream examples fetch images from moddable.com and display them on screen. These examples run on the ESP8266, which doesn't have enough memory to hold the compressed JPEG images. Async/await is used to decode and render the JPEG images as they arrive, allowing the application to overcome the RAM limits.


mini-drag

The mini-drag example is great for testing touch on displays. You can move the object by touching it and dragging across the screen.


origin

The origin example demonstrates the use of the Poco drawing origin stack.


outline/oscilloscope

The outline/oscilloscope example demonstrates using both stroked and filled polygons to render a simple oscilloscope.


outline/random-ellipses

The outline/random-ellipses example demonstrates using both stroked and filled polygons to render a simple oscilloscope.


outline/random-triangles

The outline/random-triangles example demonstrates using both stroked and filled polygons to render a simple oscilloscope.


pngdisplay

The pngdisplay allows you to use the curl command line tool to push PNG images to the display. Created for use by user interface designers, not developers.

See the blog post Pushing PNG Images to a Display for more information about this example.


progress

The progress example displays high frame rate animations of progress bars and a spinner, all of which are useful for loading screens.


rotated

The rotated example demonstrates how to define the rotation of the screen. This example rotates 90 degrees; 0, 180, and 270 degree rotation is also supported.


sprite

The sprite example displays a simple spinning animation, useful for loading screens. It demonstrates how to cycle through different portions of a single image to create an animated sprite.


static

The static example demonstrates how to use Poco to efficiently render static.


text-ticker

The text-ticker example displays the message "Greetings from Moddable..." animated in a loop.


text

The text example demonstrates different truncation and alignment options for rendering text.