//! Display images in your user interface. pub mod viewer; pub use viewer::Viewer; use crate::image::{self, Handle}; use crate::layout; use crate::renderer; use crate::{Element, Hasher, Layout, Length, Point, Rectangle, Size, Widget}; use std::hash::Hash; /// A frame that displays an image while keeping aspect ratio. /// /// # Example /// /// ``` /// # use iced_native::widget::Image; /// # /// let image = Image::new("resources/ferris.png"); /// ``` /// /// #[derive(Debug, Hash)] pub struct Image { handle: Handle, width: Length, height: Length, } impl Image { /// Creates a new [`Image`] with the given path. pub fn new>(handle: T) -> Self { Image { handle: handle.into(), width: Length::Shrink, height: Length::Shrink, } } /// Sets the width of the [`Image`] boundaries. pub fn width(mut self, width: Length) -> Self { self.width = width; self } /// Sets the height of the [`Image`] boundaries. pub fn height(mut self, height: Length) -> Self { self.height = height; self } } impl Widget for Image where Renderer: image::Renderer, { fn width(&self) -> Length { self.width } fn height(&self) -> Length { self.height } fn layout( &self, renderer: &Renderer, limits: &layout::Limits, ) -> layout::Node { let (width, height) = renderer.dimensions(&self.handle); let aspect_ratio = width as f32 / height as f32; let mut size = limits .width(self.width) .height(self.height) .resolve(Size::new(width as f32, height as f32)); let viewport_aspect_ratio = size.width / size.height; if viewport_aspect_ratio > aspect_ratio { size.width = width as f32 * size.height / height as f32; } else { size.height = height as f32 * size.width / width as f32; } layout::Node::new(size) } fn draw( &self, renderer: &mut Renderer, _style: &renderer::Style, layout: Layout<'_>, _cursor_position: Point, _viewport: &Rectangle, ) { renderer.draw(self.handle.clone(), layout.bounds()); } fn hash_layout(&self, state: &mut Hasher) { struct Marker; std::any::TypeId::of::().hash(state); self.handle.hash(state); self.width.hash(state); self.height.hash(state); } } impl<'a, Message, Renderer> From for Element<'a, Message, Renderer> where Renderer: image::Renderer, { fn from(image: Image) -> Element<'a, Message, Renderer> { Element::new(image) } }