pub struct Frame2d<const W: usize, const H: usize>(pub [[RGB8; W]; H]);Expand description
2D pixel array used for general graphics on LED panels.
- Coordinates are
(x, y)with(0, 0)at the top-left. The x-axis increases to the right, and the y-axis increases downward. - Set pixels using tuple indexing:
frame[(x, y)] = colors::RED;. - For shapes, lines, and text rendering, use the
embedded-graphicscrate.
§Indexing and storage
Frame2d supports both:
(x, y)tuple indexing:frame[(x, y)]- Row-major array indexing:
frame[y][x]
Tuple indexing matches display coordinates. Array indexing matches the underlying storage.
§Example: Draw pixels both directly and with embedded-graphics
use device_envoy_core::{led2d::Frame2d, led_strip::ToRgb888};
use embedded_graphics::{
prelude::*,
primitives::{Circle, PrimitiveStyle, Rectangle},
};
use smart_leds::colors;
type Frame = Frame2d<12, 8>;
/// Calculate the top-left corner position to center a shape within a bounding box.
const fn centered_top_left(width: usize, height: usize, size: usize) -> Point {
assert!(size <= width);
assert!(size <= height);
Point::new(((width - size) / 2) as i32, ((height - size) / 2) as i32)
}
// Create a frame to draw on. This is just an in-memory 2D pixel buffer.
let mut frame = Frame::new();
// Use the embedded-graphics crate to draw a red rectangle border around the edge of the frame.
// We use `to_rgb888()` to convert from smart-leds RGB8 to embedded-graphics Rgb888.
Rectangle::new(Frame::TOP_LEFT, Frame::SIZE)
.into_styled(PrimitiveStyle::with_stroke(colors::RED.to_rgb888(), 1))
.draw(&mut frame)
?;
// Direct pixel access: set the upper-left LED pixel (x = 0, y = 0).
// Frame2d stores LED colors directly, so we write an LED color here.
frame[(0, 0)] = colors::CYAN;
// Use the embedded-graphics crate to draw a green circle centered in the frame.
const DIAMETER: u32 = 6;
const CIRCLE_TOP_LEFT: Point = centered_top_left(Frame::WIDTH, Frame::HEIGHT, DIAMETER as usize);
Circle::new(CIRCLE_TOP_LEFT, DIAMETER)
.into_styled(PrimitiveStyle::with_stroke(colors::LIME.to_rgb888(), 1))
.draw(&mut frame)
?;Tuple Fields§
§0: [[RGB8; W]; H]Implementations§
Source§impl<const W: usize, const H: usize> Frame2d<W, H>
impl<const W: usize, const H: usize> Frame2d<W, H>
Sourcepub const SIZE: Size
pub const SIZE: Size
Frame dimensions as a Size.
For embedded-graphics drawing operations.
Sourcepub const TOP_LEFT: Point
pub const TOP_LEFT: Point
Top-left corner coordinate as a Point.
For embedded-graphics drawing operations.
Sourcepub const TOP_RIGHT: Point
pub const TOP_RIGHT: Point
Top-right corner coordinate as a Point.
For embedded-graphics drawing operations.
Sourcepub const BOTTOM_LEFT: Point
pub const BOTTOM_LEFT: Point
Bottom-left corner coordinate as a Point.
For embedded-graphics drawing operations.
Sourcepub const BOTTOM_RIGHT: Point
pub const BOTTOM_RIGHT: Point
Bottom-right corner coordinate as a Point.
For embedded-graphics drawing operations.
Trait Implementations§
Source§impl<const W: usize, const H: usize> DrawTarget for Frame2d<W, H>
impl<const W: usize, const H: usize> DrawTarget for Frame2d<W, H>
Source§type Error = Infallible
type Error = Infallible
Error type to return when a drawing operation fails. Read more
Source§fn draw_iter<I>(&mut self, pixels: I) -> Result<(), Self::Error>
fn draw_iter<I>(&mut self, pixels: I) -> Result<(), Self::Error>
Draw individual pixels to the display without a defined order. Read more
Source§fn fill_contiguous<I>(
&mut self,
area: &Rectangle,
colors: I,
) -> Result<(), Self::Error>where
I: IntoIterator<Item = Self::Color>,
fn fill_contiguous<I>(
&mut self,
area: &Rectangle,
colors: I,
) -> Result<(), Self::Error>where
I: IntoIterator<Item = Self::Color>,
Fill a given area with an iterator providing a contiguous stream of pixel colors. Read more
impl<const W: usize, const H: usize> Copy for Frame2d<W, H>
Auto Trait Implementations§
impl<const W: usize, const H: usize> Freeze for Frame2d<W, H>
impl<const W: usize, const H: usize> RefUnwindSafe for Frame2d<W, H>
impl<const W: usize, const H: usize> Send for Frame2d<W, H>
impl<const W: usize, const H: usize> Sync for Frame2d<W, H>
impl<const W: usize, const H: usize> Unpin for Frame2d<W, H>
impl<const W: usize, const H: usize> UnsafeUnpin for Frame2d<W, H>
impl<const W: usize, const H: usize> UnwindSafe for Frame2d<W, H>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CheckedAs for T
impl<T> CheckedAs for T
Source§fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
Casts the value.
Source§impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
Source§fn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
Casts the value.
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Dimensions for Twhere
T: OriginDimensions,
impl<T> Dimensions for Twhere
T: OriginDimensions,
Source§fn bounding_box(&self) -> Rectangle
fn bounding_box(&self) -> Rectangle
Returns the bounding box.
Source§impl<T> DrawTargetExt for Twhere
T: DrawTarget,
impl<T> DrawTargetExt for Twhere
T: DrawTarget,
Source§fn translated(&mut self, offset: Point) -> Translated<'_, T>
fn translated(&mut self, offset: Point) -> Translated<'_, T>
Creates a translated draw target based on this draw target. Read more
Source§fn cropped(&mut self, area: &Rectangle) -> Cropped<'_, T>
fn cropped(&mut self, area: &Rectangle) -> Cropped<'_, T>
Creates a cropped draw target based on this draw target. Read more
Source§fn clipped(&mut self, area: &Rectangle) -> Clipped<'_, T>
fn clipped(&mut self, area: &Rectangle) -> Clipped<'_, T>
Creates a clipped draw target based on this draw target. Read more
Source§fn color_converted<C>(&mut self) -> ColorConverted<'_, T, C>
fn color_converted<C>(&mut self) -> ColorConverted<'_, T, C>
Creates a color conversion draw target. Read more
Source§impl<T> OverflowingAs for T
impl<T> OverflowingAs for T
Source§fn overflowing_as<Dst>(self) -> (Dst, bool)where
T: OverflowingCast<Dst>,
fn overflowing_as<Dst>(self) -> (Dst, bool)where
T: OverflowingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere
Src: OverflowingCast<Dst>,
impl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere
Src: OverflowingCast<Dst>,
Source§fn overflowing_cast_from(src: Src) -> (Dst, bool)
fn overflowing_cast_from(src: Src) -> (Dst, bool)
Casts the value.
Source§impl<T> SaturatingAs for T
impl<T> SaturatingAs for T
Source§fn saturating_as<Dst>(self) -> Dstwhere
T: SaturatingCast<Dst>,
fn saturating_as<Dst>(self) -> Dstwhere
T: SaturatingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere
Src: SaturatingCast<Dst>,
impl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere
Src: SaturatingCast<Dst>,
Source§fn saturating_cast_from(src: Src) -> Dst
fn saturating_cast_from(src: Src) -> Dst
Casts the value.
Source§impl<T> StrictAs for T
impl<T> StrictAs for T
Source§fn strict_as<Dst>(self) -> Dstwhere
T: StrictCast<Dst>,
fn strict_as<Dst>(self) -> Dstwhere
T: StrictCast<Dst>,
Casts the value.
Source§impl<Src, Dst> StrictCastFrom<Src> for Dstwhere
Src: StrictCast<Dst>,
impl<Src, Dst> StrictCastFrom<Src> for Dstwhere
Src: StrictCast<Dst>,
Source§fn strict_cast_from(src: Src) -> Dst
fn strict_cast_from(src: Src) -> Dst
Casts the value.
Source§impl<T> UnwrappedAs for T
impl<T> UnwrappedAs for T
Source§fn unwrapped_as<Dst>(self) -> Dstwhere
T: UnwrappedCast<Dst>,
fn unwrapped_as<Dst>(self) -> Dstwhere
T: UnwrappedCast<Dst>,
Casts the value.
Source§impl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere
Src: UnwrappedCast<Dst>,
impl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere
Src: UnwrappedCast<Dst>,
Source§fn unwrapped_cast_from(src: Src) -> Dst
fn unwrapped_cast_from(src: Src) -> Dst
Casts the value.
Source§impl<T> WrappingAs for T
impl<T> WrappingAs for T
Source§fn wrapping_as<Dst>(self) -> Dstwhere
T: WrappingCast<Dst>,
fn wrapping_as<Dst>(self) -> Dstwhere
T: WrappingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> WrappingCastFrom<Src> for Dstwhere
Src: WrappingCast<Dst>,
impl<Src, Dst> WrappingCastFrom<Src> for Dstwhere
Src: WrappingCast<Dst>,
Source§fn wrapping_cast_from(src: Src) -> Dst
fn wrapping_cast_from(src: Src) -> Dst
Casts the value.