mirror of
https://github.com/Feliix42/ssd1675.git
synced 2024-11-22 02:46:30 +00:00
Merge pull request #22 from ferristseng/own-buffer
Allow GraphicDisplay to take ownership of Buffer
This commit is contained in:
commit
65c0685002
1 changed files with 24 additions and 23 deletions
|
@ -1,5 +1,8 @@
|
||||||
use color::Color;
|
use color::Color;
|
||||||
use core::ops::{Deref, DerefMut};
|
use core::{
|
||||||
|
convert::AsMut,
|
||||||
|
ops::{Deref, DerefMut},
|
||||||
|
};
|
||||||
use display::{Display, Rotation};
|
use display::{Display, Rotation};
|
||||||
use hal;
|
use hal;
|
||||||
use interface::DisplayInterface;
|
use interface::DisplayInterface;
|
||||||
|
@ -9,28 +12,25 @@ use interface::DisplayInterface;
|
||||||
/// When the `graphics` feature is enabled `GraphicDisplay` implements the `Draw` trait from
|
/// When the `graphics` feature is enabled `GraphicDisplay` implements the `Draw` trait from
|
||||||
/// [embedded-graphics](https://crates.io/crates/embedded-graphics). This allows basic shapes and
|
/// [embedded-graphics](https://crates.io/crates/embedded-graphics). This allows basic shapes and
|
||||||
/// text to be drawn on the display.
|
/// text to be drawn on the display.
|
||||||
pub struct GraphicDisplay<'a, I>
|
pub struct GraphicDisplay<'a, I, B = &'a mut [u8]>
|
||||||
where
|
where
|
||||||
I: DisplayInterface,
|
I: DisplayInterface,
|
||||||
{
|
{
|
||||||
display: Display<'a, I>,
|
display: Display<'a, I>,
|
||||||
black_buffer: &'a mut [u8],
|
black_buffer: B,
|
||||||
red_buffer: &'a mut [u8],
|
red_buffer: B,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, I> GraphicDisplay<'a, I>
|
impl<'a, I, B> GraphicDisplay<'a, I, B>
|
||||||
where
|
where
|
||||||
I: DisplayInterface,
|
I: DisplayInterface,
|
||||||
|
B: AsMut<[u8]>,
|
||||||
{
|
{
|
||||||
/// Promote a `Display` to a `GraphicDisplay`.
|
/// Promote a `Display` to a `GraphicDisplay`.
|
||||||
///
|
///
|
||||||
/// B/W and Red buffers for drawing into must be supplied. These should be `rows` * `cols` in
|
/// B/W and Red buffers for drawing into must be supplied. These should be `rows` * `cols` in
|
||||||
/// length.
|
/// length.
|
||||||
pub fn new(
|
pub fn new(display: Display<'a, I>, black_buffer: B, red_buffer: B) -> Self {
|
||||||
display: Display<'a, I>,
|
|
||||||
black_buffer: &'a mut [u8],
|
|
||||||
red_buffer: &'a mut [u8],
|
|
||||||
) -> Self {
|
|
||||||
GraphicDisplay {
|
GraphicDisplay {
|
||||||
display,
|
display,
|
||||||
black_buffer,
|
black_buffer,
|
||||||
|
@ -44,7 +44,7 @@ where
|
||||||
delay: &mut D,
|
delay: &mut D,
|
||||||
) -> Result<(), I::Error> {
|
) -> Result<(), I::Error> {
|
||||||
self.display
|
self.display
|
||||||
.update(self.black_buffer, self.red_buffer, delay)
|
.update(self.black_buffer.as_mut(), self.red_buffer.as_mut(), delay)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Clear the buffers, filling them a single color.
|
/// Clear the buffers, filling them a single color.
|
||||||
|
@ -55,12 +55,12 @@ where
|
||||||
Color::Red => (0xFF, 0xFF),
|
Color::Red => (0xFF, 0xFF),
|
||||||
};
|
};
|
||||||
|
|
||||||
for byte in &mut self.black_buffer.iter_mut() {
|
for byte in &mut self.black_buffer.as_mut().iter_mut() {
|
||||||
*byte = black; // background_color.get_byte_value();
|
*byte = black; // background_color.get_byte_value();
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: Combine loops
|
// TODO: Combine loops
|
||||||
for byte in &mut self.red_buffer.iter_mut() {
|
for byte in &mut self.red_buffer.as_mut().iter_mut() {
|
||||||
*byte = red; // background_color.get_byte_value();
|
*byte = red; // background_color.get_byte_value();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -77,22 +77,22 @@ where
|
||||||
|
|
||||||
match color {
|
match color {
|
||||||
Color::Black => {
|
Color::Black => {
|
||||||
self.black_buffer[index] &= !bit;
|
self.black_buffer.as_mut()[index] &= !bit;
|
||||||
self.red_buffer[index] &= !bit;
|
self.red_buffer.as_mut()[index] &= !bit;
|
||||||
}
|
}
|
||||||
Color::White => {
|
Color::White => {
|
||||||
self.black_buffer[index] |= bit;
|
self.black_buffer.as_mut()[index] |= bit;
|
||||||
self.red_buffer[index] &= !bit;
|
self.red_buffer.as_mut()[index] &= !bit;
|
||||||
}
|
}
|
||||||
Color::Red => {
|
Color::Red => {
|
||||||
self.black_buffer[index] |= bit;
|
self.black_buffer.as_mut()[index] |= bit;
|
||||||
self.red_buffer[index] |= bit;
|
self.red_buffer.as_mut()[index] |= bit;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, I> Deref for GraphicDisplay<'a, I>
|
impl<'a, I, B> Deref for GraphicDisplay<'a, I, B>
|
||||||
where
|
where
|
||||||
I: DisplayInterface,
|
I: DisplayInterface,
|
||||||
{
|
{
|
||||||
|
@ -103,7 +103,7 @@ where
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, I> DerefMut for GraphicDisplay<'a, I>
|
impl<'a, I, B> DerefMut for GraphicDisplay<'a, I, B>
|
||||||
where
|
where
|
||||||
I: DisplayInterface,
|
I: DisplayInterface,
|
||||||
{
|
{
|
||||||
|
@ -130,9 +130,10 @@ extern crate embedded_graphics;
|
||||||
use self::embedded_graphics::prelude::*;
|
use self::embedded_graphics::prelude::*;
|
||||||
|
|
||||||
#[cfg(feature = "graphics")]
|
#[cfg(feature = "graphics")]
|
||||||
impl<'a, I> DrawTarget for GraphicDisplay<'a, I>
|
impl<'a, I, B> DrawTarget for GraphicDisplay<'a, I, B>
|
||||||
where
|
where
|
||||||
I: DisplayInterface,
|
I: DisplayInterface,
|
||||||
|
B: AsMut<[u8]>,
|
||||||
{
|
{
|
||||||
type Color = Color;
|
type Color = Color;
|
||||||
type Error = core::convert::Infallible;
|
type Error = core::convert::Infallible;
|
||||||
|
@ -154,7 +155,7 @@ where
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(feature = "graphics")]
|
#[cfg(feature = "graphics")]
|
||||||
impl<'a, I> OriginDimensions for GraphicDisplay<'a, I>
|
impl<'a, I, B> OriginDimensions for GraphicDisplay<'a, I, B>
|
||||||
where
|
where
|
||||||
I: DisplayInterface,
|
I: DisplayInterface,
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue