Decouple the image Handle type from the iced_native implementation

This commit is contained in:
Olivier Pinon 2021-12-10 20:15:27 +01:00
parent 8cbba94458
commit a7bcd65bb8
4 changed files with 37 additions and 24 deletions

View file

@ -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)
}
}