Skip to content
Base Class for SmartMatrix::GFX and NeoMatrix::GFX
Branch: master
Clone or download
Type Name Latest commit message Commit time
Failed to load latest commit information.
.github Add GitHub issue template May 27, 2016
extras First convertion to SmartMatrix. Dec 30, 2018
.gitignore Added .gitignore May 27, 2019
Framebuffer_GFX.cpp Fixed gamma table computation. Jun 11, 2019
Framebuffer_GFX.h Fixed data types to support more than 64K pixels (like 320x240). Jun 2, 2019 updated May 28, 2019
gamma.h Update to support ESP8266 Jun 27, 2015 New common library Framebuffer_GFX. May 9, 2019

Framebuffer::GFX, FastLED's CRGB Backed Framebuffer

How to use this library

Framebuffer::GFX does not drive any hardware directly, but it is used by other drivers for its shared framebuffer functionality and functions.

It is like Adafruit::GFX, but better, as it provides 3 different 2D APIs:

Why do you want 3 APIs at the same time?
This is so that you can run existing code that was written for those different APIs and re-run that code on backends it wasn't originally meant to also run on (like FastLED code on an SSD1331 TFT screen or a SmartMatrix backend). See for lots of demos which show how to use those APIs.

It depends on these base libraries:

Driver backends that use this library base class

This is a base class, offering support for these drivers:

See the above libraries for example code, and more specifically this repository of example code that works on all these backends:

Here is an example of code ultimately running on top of Framebuffer::GFX via FastLED::NeoMatrix on ESP8266 (24x32 and 32x32) and SmartMatrix::GFX on ESP32 (64x96): image Below is the same code again now running on top of FastLED_SPITFT::GFX on an SSD1331 96x64 TFT screen: image

Adafruit::GFX vs FastLED vs LEDMatrix APIs

Years ago, back when we only had 8x8 displays, Adafruit wrote a nice API, .
It is in no means perfect or exhaustive, but it does what most people need, including font support. Its huge strength is how it works many different hardware backends, all the way back to 8x8 matrices. See this example of code working on 3 different hardware backends all using the same GFX demo code:

Here is an example of my same code on multiple GFX backends:

Now Adafruit::GFX has a drawback nowadays which is how it only supports color in 16 bits (RGB 565).
Honestly it is good enough for most displays that aren't good enough to show 16,777,216 colors, and if you care, there is a bypass to drawPixel that lets you draw in 24bit color (see below)

FastLED supports 24bit color natively. It is not a 2D API per se, but used along with you can get GFX API support while adding FastLED primitives like nscale and fade.
There is also FastLED 2D demo code written with just FastLED primitives and an XY() function to turn 2D coordinates into FastLED 1D array indexes, see for examples

LEDMatrix is a library that predates FastLED::NeoMatrix . It offers a GFX like API with a few extras, as well as sprites and font libraries. See for a sprites example. One of its drawbacks is that its layout for multiple tiled matrices, layout is complicated and FastLED::NeoMatrix is much simpler to use.

Color Management

This code was originally based on Adafruit::NeoMatrix although it evolved a fair amount before becoming what it is now. Namely it tries to work with 24bit colors and accepts them in uint32_t format, FastLED::CRGB struct format, and Adafruit::GFX RGB565 format which is upconverted to its native RGB888 format.

There are conversion functions between these color formats:

  • Color(r, g, b) creates an RGB565 (used for Adafruit::GFX draw functions)
  • Color24to16 does the same but takes an RGB888 in uint32_t
  • CRGBtoint32 turns a FastLED::CRGB struct into a RGB888 uint32_t
  • drawPixel can take either RGB65, RGB888, or CRGB. Make sure you give it "(uint32_t) 0" instead of "0" so that it knows which version to use.
  • setPassThruColor also takes all 3 color formats and allows forcing a 24bit color when using GFX functions that only take RGB565. Make sure to call setPassThruColor() when done.

You can learn more about how to use the GFX API by going to as well as but keep in mind that this library offers

You can’t perform that action at this time.