[![Contributors][contributors-shield]][contributors-url] [![Forks][forks-shield]][forks-url] [![Stargazers][stars-shield]][stars-url] [![Issues][issues-shield]][issues-url] [![Build Status][build-status]][build-status-url] [![MIT License][license-shield]][license-url] [![LinkedIn][linkedin-shield]][linkedin-url]
Embedded graphics logo

Fraramebuffer implementation for Rust's Embedded-graphics

Framebuffer approach helps to deal with display flickering when you update multiple parts of the display in separate operations. Intead, with this approach, you're going to write to a in-memory display and push it all at once into your hardware display when the whole picture is drawn.

This technique is useful when you're updating large portions of screen or just simply don't want to deal with partial display updates.
The approach has been tested on TTGO (esp32) with ST7789
Explore the docs »

Rust Crate · Report Bug · Request Feature

Table of Contents
  1. About The Project
  2. Getting Started
  3. Roadmap
  4. License
  5. Contact
  6. Acknowledgments

About The Project

This library is a Rust implementation of framebuffer approach that is often used when driving hardware displays. The goal is to perform bulk-write of all the screen pixels at once, avoiding multiple individual updates that could lead to screen flickering.

This library has been designed to work with Rust's embedded-graphics library.

(back to top)

Built With

(back to top)

Getting Started

Make sure you have your rust environment configurated

Installation

  1. Add library to your Cargo.toml

    toml ... [dependencies] embedded-graphics-framebuf = "0.1.0"

  2. Use the library in you code ```rust use embeddedgraphicsframebuf::FrameBuf; ...

    let mut display = st7789::ST7789::new( di, rst.into_output()?, // SP7789V is designed to drive 240x320 screens, even though the TTGO physical screen is smaller 320, 240, );

    static mut FBUFF: FrameBuf = FrameBuf([[Rgb565::BLACK; 240]; 135]); let fbuff = unsafe { &mut FBUFF };

    fbuff.clearblack(); Text::new( &"Good luck!", Point::new(10, 13), MonoTextStyle::new(&FONT10X20, Rgb565::WHITE.into()), ) .draw(fbuff).unwrap();

    // write to the actual display :-) let u16iter = fbuff .intoiter() .map(|px| px.into_storage());

    // those are the offsets for my physical ST7789 display display.setpixels(40, 53, 240 - 1 + 40, 53 + 135, u16iter); ```

  3. Your flickering problems should be solved at this point :)

(back to top)

Roadmap

See the open issues for a full list of proposed features (and known issues).

(back to top)

License

Distributed under the MIT License. See LICENSE for more information.

(back to top)

Contact

Bernard Kobos - @bkobos - bkobos@gmail.com

Project Link: https://github.com/bernii/embedded-graphics-framebuf

(back to top)

Acknowledgments

(back to top)