diff options
author | 2023-02-25 16:05:42 +0100 | |
---|---|---|
committer | 2023-02-25 16:05:42 +0100 | |
commit | 535d7a4d57e131e661587b36e41820dd6ccccc3e (patch) | |
tree | 0127873baeff222a32bd840e0735f82249f912d3 /tiny_skia/src/window | |
parent | 8c373cd497e370d356b480380482779397bdb510 (diff) | |
download | iced-535d7a4d57e131e661587b36e41820dd6ccccc3e.tar.gz iced-535d7a4d57e131e661587b36e41820dd6ccccc3e.tar.bz2 iced-535d7a4d57e131e661587b36e41820dd6ccccc3e.zip |
Implement basic presentation with `softbuffer` for `iced_tiny_skia`
Diffstat (limited to 'tiny_skia/src/window')
-rw-r--r-- | tiny_skia/src/window/compositor.rs | 66 |
1 files changed, 52 insertions, 14 deletions
diff --git a/tiny_skia/src/window/compositor.rs b/tiny_skia/src/window/compositor.rs index 053bb29b..164d99c6 100644 --- a/tiny_skia/src/window/compositor.rs +++ b/tiny_skia/src/window/compositor.rs @@ -10,7 +10,11 @@ pub struct Compositor<Theme> { _theme: PhantomData<Theme>, } -pub struct Surface; +pub struct Surface { + window: softbuffer::GraphicsContext, + pixels: tiny_skia::Pixmap, + buffer: Vec<u32>, +} impl<Theme> iced_graphics::window::Compositor for Compositor<Theme> { type Settings = Settings; @@ -28,19 +32,33 @@ impl<Theme> iced_graphics::window::Compositor for Compositor<Theme> { fn create_surface<W: HasRawWindowHandle + HasRawDisplayHandle>( &mut self, - _window: &W, + window: &W, + width: u32, + height: u32, ) -> Surface { - // TODO - Surface + let window = + unsafe { softbuffer::GraphicsContext::new(window, window) } + .expect("Create softbuffer for window"); + + let pixels = tiny_skia::Pixmap::new(width, height) + .expect("Create pixmap for window"); + + Surface { + window, + pixels, + buffer: vec![0; (width * height) as usize], + } } fn configure_surface( &mut self, - _surface: &mut Surface, - _width: u32, - _height: u32, + surface: &mut Surface, + width: u32, + height: u32, ) { - // TODO + surface.pixels = tiny_skia::Pixmap::new(width, height) + .expect("Create pixmap for window"); + surface.buffer = vec![0; (width * height) as usize]; } fn fetch_information(&self) -> Information { @@ -84,13 +102,33 @@ pub fn new<Theme>(settings: Settings) -> (Compositor<Theme>, Backend) { pub fn present<Theme, T: AsRef<str>>( _compositor: &mut Compositor<Theme>, - _backend: &mut Backend, - _surface: &mut Surface, - _primitives: &[Primitive], - _viewport: &Viewport, - _background_color: Color, - _overlay: &[T], + backend: &mut Backend, + surface: &mut Surface, + primitives: &[Primitive], + viewport: &Viewport, + background_color: Color, + overlay: &[T], ) -> Result<(), compositor::SurfaceError> { + backend.draw( + &mut surface.pixels, + primitives, + viewport, + background_color, + overlay, + ); + + for (i, pixel) in surface.pixels.pixels_mut().iter().enumerate() { + surface.buffer[i] = u32::from(pixel.red()) << 16 + | u32::from(pixel.green()) << 8 + | u32::from(pixel.blue()); + } + + surface.window.set_buffer( + &surface.buffer, + surface.pixels.width() as u16, + surface.pixels.height() as u16, + ); + // TODO Ok(()) } |