summaryrefslogtreecommitdiffstats
path: root/native/src/widget/image.rs
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón <hector0193@gmail.com>2021-12-13 15:36:15 +0700
committerLibravatar GitHub <noreply@github.com>2021-12-13 15:36:15 +0700
commite24eaa7c665f6b73aa4e9bac4b723cd8d24b78e1 (patch)
treec94edd5f2ffbabfe8dcd56ab3933f5aabc2ecd83 /native/src/widget/image.rs
parentbc15bfdb67394eb6eaaacec96d919f0f6cfe4efb (diff)
parentd06e6bfb5111c1f2d2fd43c10a0c69870539742f (diff)
downloadiced-e24eaa7c665f6b73aa4e9bac4b723cd8d24b78e1.tar.gz
iced-e24eaa7c665f6b73aa4e9bac4b723cd8d24b78e1.tar.bz2
iced-e24eaa7c665f6b73aa4e9bac4b723cd8d24b78e1.zip
Merge pull request #1155 from AlisCode/refactor/decouple_image
Decouple `image::Handle` from `iced_native` and lower trait bound on `text::Renderer::Font`
Diffstat (limited to 'native/src/widget/image.rs')
-rw-r--r--native/src/widget/image.rs22
1 files changed, 13 insertions, 9 deletions
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)
}
}