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.rs | 22 +++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) (limited to 'native/src/widget/image.rs') 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::::new("resources/ferris.png"); /// ``` /// /// #[derive(Debug, Hash)] -pub struct Image { +pub struct Image { handle: Handle, width: Length, height: Length, } -impl Image { +impl Image { /// Creates a new [`Image`] with the given path. pub fn new>(handle: T) -> Self { Image { @@ -50,9 +51,10 @@ impl Image { } } -impl Widget for Image +impl Widget for Image where - Renderer: image::Renderer, + Renderer: image::Renderer, + Handle: Clone + Hash, { fn width(&self) -> Length { self.width @@ -108,11 +110,13 @@ where } } -impl<'a, Message, Renderer> From for Element<'a, Message, Renderer> +impl<'a, Message, Renderer, Handle> From> + for Element<'a, Message, Renderer> where - Renderer: image::Renderer, + Renderer: image::Renderer, + Handle: Clone + Hash + 'a, { - fn from(image: Image) -> Element<'a, Message, Renderer> { + fn from(image: Image) -> Element<'a, Message, Renderer> { Element::new(image) } } -- cgit