#lcd #i2c #adafruit

no-std adafruit-lcd-backpack

Unofficial driver for the Adafruit I2C LCD backpack

2 releases

0.1.2 Oct 22, 2024
0.1.1 Feb 19, 2024

#1750 in Embedded development

Download history 6/week @ 2024-09-23 151/week @ 2024-10-21 1/week @ 2024-10-28 15/week @ 2024-11-04 8/week @ 2024-11-18

84 downloads per month

MIT license

570KB
319 lines

adafruit-lcd-backpack

THIS LIBRARY IS NO LONGER MAINTAINED

This library has not been updated to be compatible with embedded-hal version 1.0.0 and later. It is recommended to use the i2c-character-display driver instead (repository), which is compatible with embedded-hal version 1.0.0 and later and supports the Adafruit I2C LCD backpack plus other I2C character displays.


Rust driver for the Adafruit I2C LCD backpack with MCP23008 GPIO expander

NOTE: This library is not made by Adafruit, and is not supported by them. The use of the Adafruit name is for compatibility identification purposes only.

Overview

This crate provides a driver for the Adafruit I2C LCD backpack with MCP23008 GPIO expander. It is designed to be used with the embedded-hal traits for embeded systems. It supports standard HD44780 based LCD displays.

Usage

To create a new LCD backpack, use the new method. This will return a new LCD backpack object. Pass it the type of LCD display you are using, the I2C bus, and the delay object. Both the I2C Bus and Delay objects must implement the relevant embedded-hal traits.

// The embedded-hal traits are used to define the I2C bus and delay objects
use embedded_hal::{
    blocking::delay::{DelayMs, DelayUs},
    blocking::i2c::{Write, WriteRead},
};
use lcd_backpack::{LcdBackpack, LcdDisplayType};

// create the I2C bus per your platform
let i2c = ...;

// create the delay object per your platform
let delay = ...;

// create the LCD backpack
let mut lcd = LcdBackpack::new(LcdDisplayType::Lcd16x2, i2c, delay);

// initialize the LCD
if let Err(_e) = lcd.init() {
   panic!("Error initializing LCD");
}

This library supports the core::fmt::Write trait, allowing it to be used with the write! macro. For example:

use core::fmt::Write;

// write a string to the LCD
if let Err(_e) = write!(lcd, "Hello, world!") {
  panic!("Error writing to LCD");
}

The various methods for controlling the LCD are also available. Each returns a Result that wraps the LCD backpack object. This allows you to chain the methods together. For example:

// clear the display and home the cursor before writing a string
if let Err(_e) = write!(lcd.clear()?.home()?, "Hello, world!") {
 panic!("Error writing to LCD");
}

License

Licensed under the MIT license.

Dependencies