diff options
| author | 2022-11-05 04:37:59 +0100 | |
|---|---|---|
| committer | 2022-11-05 04:37:59 +0100 | |
| commit | 370fa14efb8d41bcf81e4a0ead6a9ab7ab750bee (patch) | |
| tree | 6a434e6bc8c3a95065faafa533cf1d5e2318cc06 /native | |
| parent | 7b129917281baaa6688158c303922f94341ab69f (diff) | |
| parent | 078cadfed0e67560d9047d84435e87b8671c5992 (diff) | |
| download | iced-370fa14efb8d41bcf81e4a0ead6a9ab7ab750bee.tar.gz iced-370fa14efb8d41bcf81e4a0ead6a9ab7ab750bee.tar.bz2 iced-370fa14efb8d41bcf81e4a0ead6a9ab7ab750bee.zip | |
Merge pull request #1485 from ids1024/glow-image
Glow image rendering support; move image/svg code to iced_graphics
Diffstat (limited to '')
| -rw-r--r-- | native/src/image.rs | 14 | ||||
| -rw-r--r-- | native/src/svg.rs | 4 | ||||
| -rw-r--r-- | native/src/widget/image.rs | 4 | ||||
| -rw-r--r-- | native/src/widget/image/viewer.rs | 4 | ||||
| -rw-r--r-- | native/src/widget/svg.rs | 4 | 
5 files changed, 15 insertions, 15 deletions
| diff --git a/native/src/image.rs b/native/src/image.rs index b849ef84..06fd7ae6 100644 --- a/native/src/image.rs +++ b/native/src/image.rs @@ -1,5 +1,5 @@  //! Load and draw raster graphics. -use crate::{Hasher, Rectangle}; +use crate::{Hasher, Rectangle, Size};  use std::borrow::Cow;  use std::hash::{Hash, Hasher as _}; @@ -22,7 +22,7 @@ impl Handle {      }      /// Creates an image [`Handle`] containing the image pixels directly. This -    /// function expects the input data to be provided as a `Vec<u8>` of BGRA +    /// function expects the input data to be provided as a `Vec<u8>` of RGBA      /// pixels.      ///      /// This is useful if you have already decoded your image. @@ -31,7 +31,7 @@ impl Handle {          height: u32,          pixels: impl Into<Cow<'static, [u8]>>,      ) -> Handle { -        Self::from_data(Data::Pixels { +        Self::from_data(Data::Rgba {              width,              height,              pixels: pixels.into(), @@ -93,8 +93,8 @@ pub enum Data {      /// In-memory data      Bytes(Cow<'static, [u8]>), -    /// Decoded image pixels in BGRA format. -    Pixels { +    /// Decoded image pixels in RGBA format. +    Rgba {          /// The width of the image.          width: u32,          /// The height of the image. @@ -109,7 +109,7 @@ impl std::fmt::Debug for Data {          match self {              Data::Path(path) => write!(f, "Path({:?})", path),              Data::Bytes(_) => write!(f, "Bytes(...)"), -            Data::Pixels { width, height, .. } => { +            Data::Rgba { width, height, .. } => {                  write!(f, "Pixels({} * {})", width, height)              }          } @@ -126,7 +126,7 @@ pub trait Renderer: crate::Renderer {      type Handle: Clone + Hash;      /// Returns the dimensions of an image for the given [`Handle`]. -    fn dimensions(&self, handle: &Self::Handle) -> (u32, u32); +    fn dimensions(&self, handle: &Self::Handle) -> Size<u32>;      /// Draws an image with the given [`Handle`] and inside the provided      /// `bounds`. diff --git a/native/src/svg.rs b/native/src/svg.rs index d4d20182..a8e481d2 100644 --- a/native/src/svg.rs +++ b/native/src/svg.rs @@ -1,5 +1,5 @@  //! Load and draw vector graphics. -use crate::{Hasher, Rectangle}; +use crate::{Hasher, Rectangle, Size};  use std::borrow::Cow;  use std::hash::{Hash, Hasher as _}; @@ -82,7 +82,7 @@ impl std::fmt::Debug for Data {  /// [renderer]: crate::renderer  pub trait Renderer: crate::Renderer {      /// Returns the default dimensions of an SVG for the given [`Handle`]. -    fn dimensions(&self, handle: &Handle) -> (u32, u32); +    fn dimensions(&self, handle: &Handle) -> Size<u32>;      /// Draws an SVG with the given [`Handle`] and inside the provided `bounds`.      fn draw(&mut self, handle: Handle, bounds: Rectangle); diff --git a/native/src/widget/image.rs b/native/src/widget/image.rs index 91d68e34..8bd8ca1e 100644 --- a/native/src/widget/image.rs +++ b/native/src/widget/image.rs @@ -85,7 +85,7 @@ where  {      // The raw w/h of the underlying image      let image_size = { -        let (width, height) = renderer.dimensions(handle); +        let Size { width, height } = renderer.dimensions(handle);          Size::new(width as f32, height as f32)      }; @@ -149,7 +149,7 @@ where          _cursor_position: Point,          _viewport: &Rectangle,      ) { -        let (width, height) = renderer.dimensions(&self.handle); +        let Size { width, height } = renderer.dimensions(&self.handle);          let image_size = Size::new(width as f32, height as f32);          let bounds = layout.bounds(); diff --git a/native/src/widget/image/viewer.rs b/native/src/widget/image/viewer.rs index b1fe596c..9c83287e 100644 --- a/native/src/widget/image/viewer.rs +++ b/native/src/widget/image/viewer.rs @@ -108,7 +108,7 @@ where          renderer: &Renderer,          limits: &layout::Limits,      ) -> layout::Node { -        let (width, height) = renderer.dimensions(&self.handle); +        let Size { width, height } = renderer.dimensions(&self.handle);          let mut size = limits              .width(self.width) @@ -409,7 +409,7 @@ pub fn image_size<Renderer>(  where      Renderer: image::Renderer,  { -    let (width, height) = renderer.dimensions(handle); +    let Size { width, height } = renderer.dimensions(handle);      let (width, height) = {          let dimensions = (width as f32, height as f32); diff --git a/native/src/widget/svg.rs b/native/src/widget/svg.rs index aa68bfb8..1015ed0a 100644 --- a/native/src/widget/svg.rs +++ b/native/src/widget/svg.rs @@ -83,7 +83,7 @@ where          limits: &layout::Limits,      ) -> layout::Node {          // The raw w/h of the underlying image -        let (width, height) = renderer.dimensions(&self.handle); +        let Size { width, height } = renderer.dimensions(&self.handle);          let image_size = Size::new(width as f32, height as f32);          // The size to be available to the widget prior to `Shrink`ing @@ -120,7 +120,7 @@ where          _cursor_position: Point,          _viewport: &Rectangle,      ) { -        let (width, height) = renderer.dimensions(&self.handle); +        let Size { width, height } = renderer.dimensions(&self.handle);          let image_size = Size::new(width as f32, height as f32);          let bounds = layout.bounds(); | 
