diff options
author | 2021-12-10 20:15:27 +0100 | |
---|---|---|
committer | 2021-12-10 23:33:58 +0100 | |
commit | a7bcd65bb82a2640e10cbe25bf24bc003d059857 (patch) | |
tree | 99e9991ba33d8f808d3bba76fae813182977c814 /native | |
parent | 8cbba944581a81931848352ec45646d882d9b3d0 (diff) | |
download | iced-a7bcd65bb82a2640e10cbe25bf24bc003d059857.tar.gz iced-a7bcd65bb82a2640e10cbe25bf24bc003d059857.tar.bz2 iced-a7bcd65bb82a2640e10cbe25bf24bc003d059857.zip |
Decouple the image Handle type from the iced_native implementation
Diffstat (limited to 'native')
-rw-r--r-- | native/src/image.rs | 9 | ||||
-rw-r--r-- | native/src/widget/image.rs | 22 | ||||
-rw-r--r-- | native/src/widget/image/viewer.rs | 28 |
3 files changed, 35 insertions, 24 deletions
diff --git a/native/src/image.rs b/native/src/image.rs index 00379417..43bba4f1 100644 --- a/native/src/image.rs +++ b/native/src/image.rs @@ -115,10 +115,15 @@ impl std::fmt::Debug for Data { /// /// [renderer]: crate::renderer pub trait Renderer: crate::Renderer { + /// The image Handle to be displayed. Iced exposes its own default implementation of a [`Handle`] + /// + /// [`Handle`]: Self::Handle + type Handle: Clone + Hash; + /// Returns the dimensions of an image for the given [`Handle`]. - fn dimensions(&self, handle: &Handle) -> (u32, u32); + fn dimensions(&self, handle: &Self::Handle) -> (u32, u32); /// Draws an image with the given [`Handle`] and inside the provided /// `bounds`. - fn draw(&mut self, handle: Handle, bounds: Rectangle); + fn draw(&mut self, handle: Self::Handle, bounds: Rectangle); } diff --git a/native/src/widget/image.rs b/native/src/widget/image.rs index 66e95265..164b4a5e 100644 --- a/native/src/widget/image.rs +++ b/native/src/widget/image.rs @@ -2,7 +2,7 @@ pub mod viewer; pub use viewer::Viewer; -use crate::image::{self, Handle}; +use crate::image; use crate::layout; use crate::renderer; use crate::{Element, Hasher, Layout, Length, Point, Rectangle, Size, Widget}; @@ -15,19 +15,20 @@ use std::hash::Hash; /// /// ``` /// # use iced_native::widget::Image; +/// # use iced_native::image; /// # -/// let image = Image::new("resources/ferris.png"); +/// let image = Image::<image::Handle>::new("resources/ferris.png"); /// ``` /// /// <img src="https://github.com/hecrj/iced/blob/9712b319bb7a32848001b96bd84977430f14b623/examples/resources/ferris.png?raw=true" width="300"> #[derive(Debug, Hash)] -pub struct Image { +pub struct Image<Handle> { handle: Handle, width: Length, height: Length, } -impl Image { +impl<Handle> Image<Handle> { /// Creates a new [`Image`] with the given path. pub fn new<T: Into<Handle>>(handle: T) -> Self { Image { @@ -50,9 +51,10 @@ impl Image { } } -impl<Message, Renderer> Widget<Message, Renderer> for Image +impl<Message, Renderer, Handle> Widget<Message, Renderer> for Image<Handle> where - Renderer: image::Renderer, + Renderer: image::Renderer<Handle = Handle>, + Handle: Clone + Hash, { fn width(&self) -> Length { self.width @@ -108,11 +110,13 @@ where } } -impl<'a, Message, Renderer> From<Image> for Element<'a, Message, Renderer> +impl<'a, Message, Renderer, Handle> From<Image<Handle>> + for Element<'a, Message, Renderer> where - Renderer: image::Renderer, + Renderer: image::Renderer<Handle = Handle>, + Handle: Clone + Hash + 'a, { - fn from(image: Image) -> Element<'a, Message, Renderer> { + fn from(image: Image<Handle>) -> Element<'a, Message, Renderer> { Element::new(image) } } 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<Renderer>(&self, renderer: &Renderer, bounds: Size) -> Size where - Renderer: image::Renderer, + Renderer: image::Renderer<Handle = Handle>, { let (width, height) = renderer.dimensions(&self.handle); @@ -114,9 +112,11 @@ impl<'a> Viewer<'a> { } } -impl<'a, Message, Renderer> Widget<Message, Renderer> for Viewer<'a> +impl<'a, Message, Renderer, Handle> Widget<Message, Renderer> + for Viewer<'a, Handle> where - Renderer: image::Renderer, + Renderer: image::Renderer<Handle = Handle>, + Handle: Clone + Hash, { fn width(&self) -> Length { self.width @@ -394,12 +394,14 @@ impl State { } } -impl<'a, Message, Renderer> From<Viewer<'a>> for Element<'a, Message, Renderer> +impl<'a, Message, Renderer, Handle> From<Viewer<'a, Handle>> + for Element<'a, Message, Renderer> where - Renderer: 'a + image::Renderer, + Renderer: 'a + image::Renderer<Handle = Handle>, 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) } } |