|
|
|
|
@ -1,19 +1,12 @@
|
|
|
|
|
use epd1in54::{DEFAULT_BACKGROUND_COLOR, WIDTH, HEIGHT}; |
|
|
|
|
use graphics::DisplayDimension; |
|
|
|
|
|
|
|
|
|
pub struct DisplayEink1in54BlackWhite { |
|
|
|
|
width: u32, |
|
|
|
|
height: u32, |
|
|
|
|
pub struct Buffer1in54BlackWhite { |
|
|
|
|
pub buffer: [u8; WIDTH as usize * HEIGHT as usize / 8], |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
impl Default for DisplayEink1in54BlackWhite { |
|
|
|
|
impl Default for Buffer1in54BlackWhite { |
|
|
|
|
fn default() -> Self { |
|
|
|
|
DisplayEink1in54BlackWhite { |
|
|
|
|
width: WIDTH, |
|
|
|
|
height: HEIGHT, |
|
|
|
|
Buffer1in54BlackWhite { |
|
|
|
|
buffer: [ |
|
|
|
|
DEFAULT_BACKGROUND_COLOR.get_byte_value(); |
|
|
|
|
WIDTH as usize * HEIGHT as usize / 8
|
|
|
|
|
@ -22,18 +15,6 @@ impl Default for DisplayEink1in54BlackWhite {
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
impl DisplayDimension for DisplayEink1in54BlackWhite { |
|
|
|
|
fn buffer(&mut self) -> &mut [u8] { |
|
|
|
|
&mut self.buffer |
|
|
|
|
} |
|
|
|
|
fn width(&self) -> u32 { |
|
|
|
|
self.width |
|
|
|
|
} |
|
|
|
|
fn height(&self) -> u32 { |
|
|
|
|
self.height |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#[cfg(test)] |
|
|
|
|
mod tests { |
|
|
|
|
@ -47,7 +28,7 @@ mod tests {
|
|
|
|
|
// test buffer length
|
|
|
|
|
#[test] |
|
|
|
|
fn graphics_size() { |
|
|
|
|
let mut display1in54 = DisplayEink1in54BlackWhite::default(); |
|
|
|
|
let mut display1in54 = Buffer1in54BlackWhite::default(); |
|
|
|
|
let display = Display::new(WIDTH, HEIGHT, &mut display1in54.buffer); |
|
|
|
|
assert_eq!(display.buffer().len(), 5000); |
|
|
|
|
} |
|
|
|
|
@ -55,7 +36,7 @@ mod tests {
|
|
|
|
|
// test default background color on all bytes
|
|
|
|
|
#[test] |
|
|
|
|
fn graphics_default() { |
|
|
|
|
let mut display1in54 = DisplayEink1in54BlackWhite::default(); |
|
|
|
|
let mut display1in54 = Buffer1in54BlackWhite::default(); |
|
|
|
|
let display = Display::new(WIDTH, HEIGHT, &mut display1in54.buffer); |
|
|
|
|
for &byte in display.buffer() { |
|
|
|
|
assert_eq!(byte, DEFAULT_BACKGROUND_COLOR.get_byte_value()); |
|
|
|
|
@ -64,7 +45,7 @@ mod tests {
|
|
|
|
|
|
|
|
|
|
#[test] |
|
|
|
|
fn graphics_rotation_0() { |
|
|
|
|
let mut display1in54 = DisplayEink1in54BlackWhite::default(); |
|
|
|
|
let mut display1in54 = Buffer1in54BlackWhite::default(); |
|
|
|
|
let mut display = Display::new(WIDTH, HEIGHT, &mut display1in54.buffer); |
|
|
|
|
display.draw( |
|
|
|
|
Line::new(Coord::new(0, 0), Coord::new(7, 0)) |
|
|
|
|
@ -83,7 +64,7 @@ mod tests {
|
|
|
|
|
|
|
|
|
|
#[test] |
|
|
|
|
fn graphics_rotation_90() { |
|
|
|
|
let mut display1in54 = DisplayEink1in54BlackWhite::default(); |
|
|
|
|
let mut display1in54 = Buffer1in54BlackWhite::default(); |
|
|
|
|
let mut display = Display::new(WIDTH, HEIGHT, &mut display1in54.buffer); |
|
|
|
|
display.set_rotation(DisplayRotation::Rotate90); |
|
|
|
|
display.draw( |
|
|
|
|
@ -103,7 +84,7 @@ mod tests {
|
|
|
|
|
|
|
|
|
|
#[test] |
|
|
|
|
fn graphics_rotation_180() { |
|
|
|
|
let mut display1in54 = DisplayEink1in54BlackWhite::default(); |
|
|
|
|
let mut display1in54 = Buffer1in54BlackWhite::default(); |
|
|
|
|
let mut display = Display::new(WIDTH, HEIGHT, &mut display1in54.buffer); |
|
|
|
|
display.set_rotation(DisplayRotation::Rotate180); |
|
|
|
|
display.draw( |
|
|
|
|
@ -127,7 +108,7 @@ mod tests {
|
|
|
|
|
|
|
|
|
|
#[test] |
|
|
|
|
fn graphics_rotation_270() { |
|
|
|
|
let mut display1in54 = DisplayEink1in54BlackWhite::default(); |
|
|
|
|
let mut display1in54 = Buffer1in54BlackWhite::default(); |
|
|
|
|
let mut display = Display::new(WIDTH, HEIGHT, &mut display1in54.buffer); |
|
|
|
|
display.set_rotation(DisplayRotation::Rotate270); |
|
|
|
|
display.draw( |
|
|
|
|
|