use super::*;
use crate::util::Array2d;
pub struct PaddingCanvas<C: Canvas> {
inner: C,
curr_buf: Array2d<Color>,
new_buf: Array2d<Color>,
}
impl<C: Canvas> PaddingCanvas<C> {
pub fn from(inner: C) -> Self {
let (width, height) = inner.bounding_box();
Self {
inner,
curr_buf: Array2d::new(width, height),
new_buf: Array2d::new(width, height),
}
}
}
impl<C: Canvas> Canvas for PaddingCanvas<C> {
fn bounding_box(&self) -> (u32, u32) {
self.inner.bounding_box()
}
fn lowest_visible_brightness(&self) -> f32 {
self.inner.lowest_visible_brightness()
}
fn low_level_get(&self, x: u32, y: u32) -> Option<&Color> {
if let Some(color) = self.inner.low_level_get(x, y) {
Some(color)
} else {
self.curr_buf.get(x, y)
}
}
fn low_level_get_pending(&self, x: u32, y: u32) -> Option<&Color> {
if let Some(color) = self.inner.low_level_get_pending(x, y) {
Some(color)
} else {
self.new_buf.get(x, y)
}
}
fn low_level_get_pending_mut(&mut self, x: u32, y: u32) -> Option<&mut Color> {
if let Some(color) = self.inner.low_level_get_pending_mut(x, y) {
Some(color)
} else {
self.new_buf.get_mut(x, y)
}
}
fn flush(&mut self) -> Result<(), crate::MidiError> {
self.curr_buf = self.new_buf.clone();
self.inner.flush()
}
}
impl_traits_for_canvas!(PaddingCanvas[C: Canvas]);