9 releases
new 0.1.8 | Dec 13, 2024 |
---|---|
0.1.7 | Sep 19, 2023 |
#318 in Data structures
56KB
1.5K
SLoC
Smart LED Effects
This supplies a collection of effects for usage with individually addressable LED strips such as the WS2812b. Each effect returns a vector of colours that can then be sent to your LED driver.
The EffectIterator trait defines two methods:
- name
- next
name
will just return the name as a static string slice.
next
will return the next page of the effect. It uses the Option
enum, and in the future there will be One Shot effects that end and return None
. For now, all effects will loop.
This crate borrows heavily from fastLED and tweaking4all. The majority of the effect art is taken straight from here, andd reimplemented in Rust.
Dimensionality
Currently only works for strips/loops. But someday the plan is to extend it.
Effects
- Breathe
- Bounce
- Collision
- Cylon
- Fire
- Meteor
- Morse
- ProgressBar
- Rainbow
- RunningLights
- SnowSparkle
- Strobe
- Timer
- Twinkle
- Wipe
Example Usage
[dependencies]
smart_led_effects = 0.1.7
use smart_led_effects::{
strip::{self, EffectIterator},
Srgb,
};
//...
const COUNT: usize = 55;
let effect = strip::Rainbow::new(COUNT, None);
loop {
let pixels = effect.next().unwrap();
// show pixels
thread::sleep(Duration::from_millis(10));
}
References
Dependencies
~2.5MB
~53K SLoC