10 releases (6 breaking)

0.7.1 May 24, 2023
0.6.0 Jan 12, 2023
0.5.0 Oct 19, 2022
0.2.0 Apr 13, 2022
0.1.0 Sep 9, 2021

#52 in Hardware support

Download history 977/week @ 2023-12-17 981/week @ 2023-12-24 897/week @ 2023-12-31 1244/week @ 2024-01-07 1474/week @ 2024-01-14 1558/week @ 2024-01-21 1547/week @ 2024-01-28 1643/week @ 2024-02-04 1510/week @ 2024-02-11 1342/week @ 2024-02-18 1697/week @ 2024-02-25 2010/week @ 2024-03-03 2027/week @ 2024-03-10 1793/week @ 2024-03-17 1678/week @ 2024-03-24 1759/week @ 2024-03-31

7,485 downloads per month
Used in 3 crates

MIT license

85KB
2K SLoC

mipidsi

Crates.io Docs.rs Discuss driver on embedded-graphics on Matrix

This crate provides a generic display driver to connect to TFT displays that implement the MIPI Display Command Set.

Uses display_interface to talk to the hardware via transports (currently SPI, I2C and Parallel GPIO).

An optional batching of draws is supported via the batch feature (default on)

NOTES:

  • The name of this crate is a bit unfortunate as this driver works with displays that use the MIPI Display Command Set via any transport supported by display_interface but MIPI Display Serial Interface is NOT supported at this time.

Architecture

The Display driver itself contains most of the functionality. Each specific display model implements the Model trait for every color format it supports. Each model can also have different variants which are handled via the Builder struct.

embedded-graphics-core is used to provide the drawing API.

Models

Each supported display model can be used either through the Builder::with_model call or through a shortcut function such as Builder::st7789 if provided. External crates can be used to provide additional models, and can even expand the display constructor pool via trait extension.

Variants that require different screen sizes and window addressing offsets are now supported via the Builder logic as well (see docs).

List of supported models

  • ST7789
  • ST7735
  • ILI9486
  • ILI9341
  • ILI9342C

Migration

See MIGRATION.md document.

Troubleshooting

See TROUBLESHOOTING.md document.

Example

// create a DisplayInterface from SPI and DC pin, with no manual CS control
let di = SPIInterfaceNoCS::new(spi, dc);
// create the ILI9486 display driver in rgb666 color mode from the display interface and use a HW reset pin during init
let mut display = Builder::ili9486_rgb666(di)
    .init(&mut delay, Some(rst))?; // delay provider from your MCU
// clear the display to black
display.clear(Rgb666::BLACK)?;

License: MIT

Minimum Supported Rust Version (MSRV)

This crate is guaranteed to compile on stable Rust 1.61.0 and up. It might compile with older versions but that may change in any new patch release.

Dependencies

~685KB
~12K SLoC