From a7bcd65bb82a2640e10cbe25bf24bc003d059857 Mon Sep 17 00:00:00 2001 From: Olivier Pinon Date: Fri, 10 Dec 2021 20:15:27 +0100 Subject: Decouple the image Handle type from the iced_native implementation --- native/src/widget/image/viewer.rs | 28 +++++++++++++++------------- 1 file changed, 15 insertions(+), 13 deletions(-) (limited to 'native/src/widget/image/viewer.rs') diff --git a/native/src/widget/image/viewer.rs b/native/src/widget/image/viewer.rs index 0fc766c3..645ce852 100644 --- a/native/src/widget/image/viewer.rs +++ b/native/src/widget/image/viewer.rs @@ -13,7 +13,7 @@ use std::hash::Hash; /// A frame that displays an image with the ability to zoom in/out and pan. #[allow(missing_debug_implementations)] -pub struct Viewer<'a> { +pub struct Viewer<'a, Handle> { state: &'a mut State, padding: u16, width: Length, @@ -21,14 +21,12 @@ pub struct Viewer<'a> { min_scale: f32, max_scale: f32, scale_step: f32, - handle: image::Handle, + handle: Handle, } -impl<'a> Viewer<'a> { - /// Creates a new [`Viewer`] with the given [`State`] and [`Handle`]. - /// - /// [`Handle`]: image::Handle - pub fn new(state: &'a mut State, handle: image::Handle) -> Self { +impl<'a, Handle> Viewer<'a, Handle> { + /// Creates a new [`Viewer`] with the given [`State`]. + pub fn new(state: &'a mut State, handle: Handle) -> Self { Viewer { state, padding: 0, @@ -89,7 +87,7 @@ impl<'a> Viewer<'a> { /// will be respected. fn image_size(&self, renderer: &Renderer, bounds: Size) -> Size where - Renderer: image::Renderer, + Renderer: image::Renderer, { let (width, height) = renderer.dimensions(&self.handle); @@ -114,9 +112,11 @@ impl<'a> Viewer<'a> { } } -impl<'a, Message, Renderer> Widget for Viewer<'a> +impl<'a, Message, Renderer, Handle> Widget + for Viewer<'a, Handle> where - Renderer: image::Renderer, + Renderer: image::Renderer, + Handle: Clone + Hash, { fn width(&self) -> Length { self.width @@ -394,12 +394,14 @@ impl State { } } -impl<'a, Message, Renderer> From> for Element<'a, Message, Renderer> +impl<'a, Message, Renderer, Handle> From> + for Element<'a, Message, Renderer> where - Renderer: 'a + image::Renderer, + Renderer: 'a + image::Renderer, Message: 'a, + Handle: Clone + Hash + 'a, { - fn from(viewer: Viewer<'a>) -> Element<'a, Message, Renderer> { + fn from(viewer: Viewer<'a, Handle>) -> Element<'a, Message, Renderer> { Element::new(viewer) } } -- cgit