use crate::prelude::*;
pub struct TheToolbar {
id: TheId,
limiter: TheSizeLimiter,
dim: TheDim,
is_dirty: bool,
}
impl TheWidget for TheToolbar {
fn new(id: TheId) -> Self
where
Self: Sized,
{
let mut limiter = TheSizeLimiter::new();
limiter.set_max_height(22);
Self {
id,
limiter,
dim: TheDim::zero(),
is_dirty: false,
}
}
fn id(&self) -> &TheId {
&self.id
}
fn dim(&self) -> &TheDim {
&self.dim
}
fn dim_mut(&mut self) -> &mut TheDim {
&mut self.dim
}
fn set_dim(&mut self, dim: TheDim, _ctx: &mut TheContext) {
if self.dim != dim {
self.dim = dim;
self.is_dirty = true;
}
}
fn limiter(&self) -> &TheSizeLimiter {
&self.limiter
}
fn limiter_mut(&mut self) -> &mut TheSizeLimiter {
&mut self.limiter
}
fn needs_redraw(&mut self) -> bool {
self.is_dirty
}
fn draw(
&mut self,
buffer: &mut TheRGBABuffer,
_style: &mut Box<dyn TheStyle>,
ctx: &mut TheContext,
) {
if !self.dim().is_valid() {
return;
}
let stride = buffer.stride();
let utuple: (usize, usize, usize, usize) = self.dim.to_buffer_utuple();
if let Some(icon) = ctx.ui.icon("dark_toolbar") {
for x in 0..utuple.2 {
let r = (utuple.0 + x, utuple.1, 1, icon.dim().height as usize);
ctx.draw
.copy_slice(buffer.pixels_mut(), icon.pixels(), &r, stride);
}
}
self.is_dirty = false;
}
fn as_any(&mut self) -> &mut dyn std::any::Any {
self
}
}