Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cat-in-136/ws2812-esp32-rmt-driver
WS2812 driver using ESP32 RMT for Rust
https://github.com/cat-in-136/ws2812-esp32-rmt-driver
embedded esp32 neopixel rust-library
Last synced: about 20 hours ago
JSON representation
WS2812 driver using ESP32 RMT for Rust
- Host: GitHub
- URL: https://github.com/cat-in-136/ws2812-esp32-rmt-driver
- Owner: cat-in-136
- License: mit
- Created: 2022-02-12T22:49:42.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-11-08T13:38:52.000Z (2 months ago)
- Last Synced: 2025-01-01T21:09:38.333Z (8 days ago)
- Topics: embedded, esp32, neopixel, rust-library
- Language: Rust
- Homepage:
- Size: 141 KB
- Stars: 45
- Watchers: 2
- Forks: 21
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ws2812-esp32-rmt-driver
A rust driver library to control WS2812B (NeoPixel) RGB LED pixels/strips using ESP32 RMT (Remote Control) module.
![Rust](https://github.com/cat-in-136/ws2812-esp32-rmt-driver/workflows/Rust/badge.svg)
[![ws2812-esp32-rmt-driver at crates.io](https://img.shields.io/crates/v/ws2812-esp32-rmt-driver.svg)](https://crates.io/crates/ws2812-esp32-rmt-driver)
[![API](https://docs.rs/ws2812-esp32-rmt-driver/badge.svg)](https://docs.rs/ws2812-esp32-rmt-driver)By disabling the carrier generator of [the RMT's transmitter][rmt]
, it can be used as just a PWM signal generator for [WS2812B data signal][ws2812b-datasheet]. This control way is the
same as major Arduino/C++ library such as [FastLED](https://github.com/FastLED/FastLED),
[Adafruit_NeoPixel](https://github.com/adafruit/Adafruit_NeoPixel).The RMT (Remote Control) module is specific to ESP32. Hence, it can be used only for ESP32 SoC.
This library also support SK6812-RGBW 4-color LED pixels/strips (smart-leds API only).
[rmt]: https://docs.espressif.com/projects/esp-idf/en/latest/esp32/api-reference/peripherals/rmt.html
[ws2812b-datasheet]: https://cdn-shop.adafruit.com/datasheets/WS2812B.pdf
## Usage
Install rust with Xtensa support. Refer [esp-rs/rust-build](https://github.com/esp-rs/rust-build) for the setup
instruction.Add following dependency to your `Cargo.toml`. Note that version is stripped in this example but it is recommended to
specify version explicitly in your project.```toml
[dependencies]
esp-idf-sys = { version = "*", features = ["binstart"] }
esp-idf-hal = "*"
smart-leds = "*"ws2812-esp32-rmt-driver = { version = "*", features = ["smart-leds-trait"] }
[build-dependencies]
embuild = "*"
anyhow = "1"
```Refer `examples/` directory for the source code.
Make ensure `esp` toolchain is available and `xtensa-esp32-elf-clang` is in your `$PATH`. And then, run as follows
```console
$ cargo build
$ cargo espflash
```## Features
|Features |Default|Description |
|------------------------|-------|----------------------------------------------------------------------|
|`embedded_graphics_core`| |embedded-graphics API `ws2812_esp32_rmt_driver::lib_embedded_graphics`|
|`smart-leds-trait` | |smart-leds API `ws2812_esp32_rmt_driver::lib_smart_leds` |
|`std` |x |use standard library `std` |
|`alloc` |x |use memory allocator (heap) |Some examples:
* `features = ["embedded-graphics-core"]` to enable embedded-graphics
API `ws2812_esp32_rmt_driver::lib_embedded_graphics`.
* `features = ["smart-leds-trait"]` to enable smart-leds API `ws2812_esp32_rmt_driver::lib_smart_leds`.
* default feature to enable just only driver API.## no_std
To use `no_std`, disable `default` feature. Then, `std` feature is disabled and this library get compatible with `no_std`.
Some examples:
* `default-feature = false, features = ["alloc", "embedded-graphics-core"]` to enable embedded-graphics API
`ws2812_esp32_rmt_driver::lib_embedded_graphics` for `no_std` environment with memory allocator.
* `default-feature = false, features = ["alloc", "smart-leds-trait"]` to enable smart-leds API
`ws2812_esp32_rmt_driver::lib_smart_leds` for `no_std` environment with memory allocator.
* `default-feature = false, features = ["embedded-graphics-core"]` to enable embedded-graphics API
`ws2812_esp32_rmt_driver::lib_embedded_graphics` for `no_std` environment without memory allocator.
* `default-feature = false, features = ["smart-leds-trait"]` to enable smart-leds API
`ws2812_esp32_rmt_driver::lib_smart_leds` for `no_std` environment without memory allocator.When using the memory allocator (heap), enable the `alloc` feature. In this case, most processing works in the same way as `std`.
When not using the memory allocator (heap), leave the `alloc` feature disabled. In this case,
some APIs cannot be used and processing must be changed.
For example, in the embedded-graphics API, the pixel data storage must be prepared by the programmer
using heapless `Vec`-like struct such as `heapless::Vec`.This library is intended for use with espidf.
For bare-metal environments (i.e. use with [esp-hal](https://crates.io/crates/esp-hal/)),
use the espressif official crate [esp-hal-smartled](https://crates.io/crates/esp-hal-smartled).## Development
To run the test locally, specify the local toolchain (`stable`, `nightly`, etc...) and target explicitly and disable
example builds (specify `--lib`)
.```console
$ cargo +stable test --target x86_64-unknown-linux-gnu --lib
```