diff options
Diffstat (limited to '')
| -rw-r--r-- | src/application.rs | 18 | ||||
| -rw-r--r-- | src/lib.rs | 10 | ||||
| -rw-r--r-- | src/sandbox.rs | 22 | ||||
| -rw-r--r-- | src/window/icon.rs | 209 | 
4 files changed, 75 insertions, 184 deletions
| diff --git a/src/application.rs b/src/application.rs index c9ddf840..abf58fa3 100644 --- a/src/application.rs +++ b/src/application.rs @@ -39,15 +39,15 @@ pub use crate::style::application::{Appearance, StyleSheet};  /// to listen to time.  /// - [`todos`], a todos tracker inspired by [TodoMVC].  /// -/// [The repository has a bunch of examples]: https://github.com/iced-rs/iced/tree/0.8/examples -/// [`clock`]: https://github.com/iced-rs/iced/tree/0.8/examples/clock -/// [`download_progress`]: https://github.com/iced-rs/iced/tree/0.8/examples/download_progress -/// [`events`]: https://github.com/iced-rs/iced/tree/0.8/examples/events -/// [`game_of_life`]: https://github.com/iced-rs/iced/tree/0.8/examples/game_of_life -/// [`pokedex`]: https://github.com/iced-rs/iced/tree/0.8/examples/pokedex -/// [`solar_system`]: https://github.com/iced-rs/iced/tree/0.8/examples/solar_system -/// [`stopwatch`]: https://github.com/iced-rs/iced/tree/0.8/examples/stopwatch -/// [`todos`]: https://github.com/iced-rs/iced/tree/0.8/examples/todos +/// [The repository has a bunch of examples]: https://github.com/iced-rs/iced/tree/0.9/examples +/// [`clock`]: https://github.com/iced-rs/iced/tree/0.9/examples/clock +/// [`download_progress`]: https://github.com/iced-rs/iced/tree/0.9/examples/download_progress +/// [`events`]: https://github.com/iced-rs/iced/tree/0.9/examples/events +/// [`game_of_life`]: https://github.com/iced-rs/iced/tree/0.9/examples/game_of_life +/// [`pokedex`]: https://github.com/iced-rs/iced/tree/0.9/examples/pokedex +/// [`solar_system`]: https://github.com/iced-rs/iced/tree/0.9/examples/solar_system +/// [`stopwatch`]: https://github.com/iced-rs/iced/tree/0.9/examples/stopwatch +/// [`todos`]: https://github.com/iced-rs/iced/tree/0.9/examples/todos  /// [`Sandbox`]: crate::Sandbox  /// [`Canvas`]: crate::widget::Canvas  /// [PokéAPI]: https://pokeapi.co/ @@ -24,13 +24,13 @@  //! [scrollables]: https://gfycat.com/perkybaggybaboon-rust-gui  //! [Debug overlay with performance metrics]: https://gfycat.com/incredibledarlingbee  //! [Modular ecosystem]: https://github.com/iced-rs/iced/blob/master/ECOSYSTEM.md -//! [renderer-agnostic native runtime]: https://github.com/iced-rs/iced/tree/0.8/native +//! [renderer-agnostic native runtime]: https://github.com/iced-rs/iced/tree/0.9/native  //! [`wgpu`]: https://github.com/gfx-rs/wgpu-rs -//! [built-in renderer]: https://github.com/iced-rs/iced/tree/0.8/wgpu -//! [windowing shell]: https://github.com/iced-rs/iced/tree/0.8/winit +//! [built-in renderer]: https://github.com/iced-rs/iced/tree/0.9/wgpu +//! [windowing shell]: https://github.com/iced-rs/iced/tree/0.9/winit  //! [`dodrio`]: https://github.com/fitzgen/dodrio  //! [web runtime]: https://github.com/iced-rs/iced_web -//! [examples]: https://github.com/iced-rs/iced/tree/0.8/examples +//! [examples]: https://github.com/iced-rs/iced/tree/0.9/examples  //! [repository]: https://github.com/iced-rs/iced  //!  //! # Overview @@ -235,7 +235,7 @@ pub mod mouse {  pub mod subscription {      //! Listen to external events in your application.      pub use iced_futures::subscription::{ -        events, events_with, run, run_with_id, unfold, Subscription, +        channel, events, events_with, run, run_with_id, unfold, Subscription,      };  } diff --git a/src/sandbox.rs b/src/sandbox.rs index e8ed0f81..cca327b6 100644 --- a/src/sandbox.rs +++ b/src/sandbox.rs @@ -34,19 +34,19 @@ use crate::{Application, Command, Element, Error, Settings, Subscription};  /// - [`tour`], a simple UI tour that can run both on native platforms and the  /// web!  /// -/// [The repository has a bunch of examples]: https://github.com/iced-rs/iced/tree/0.8/examples -/// [`bezier_tool`]: https://github.com/iced-rs/iced/tree/0.8/examples/bezier_tool -/// [`counter`]: https://github.com/iced-rs/iced/tree/0.8/examples/counter -/// [`custom_widget`]: https://github.com/iced-rs/iced/tree/0.8/examples/custom_widget -/// [`geometry`]: https://github.com/iced-rs/iced/tree/0.8/examples/geometry -/// [`pane_grid`]: https://github.com/iced-rs/iced/tree/0.8/examples/pane_grid -/// [`progress_bar`]: https://github.com/iced-rs/iced/tree/0.8/examples/progress_bar -/// [`styling`]: https://github.com/iced-rs/iced/tree/0.8/examples/styling -/// [`svg`]: https://github.com/iced-rs/iced/tree/0.8/examples/svg -/// [`tour`]: https://github.com/iced-rs/iced/tree/0.8/examples/tour +/// [The repository has a bunch of examples]: https://github.com/iced-rs/iced/tree/0.9/examples +/// [`bezier_tool`]: https://github.com/iced-rs/iced/tree/0.9/examples/bezier_tool +/// [`counter`]: https://github.com/iced-rs/iced/tree/0.9/examples/counter +/// [`custom_widget`]: https://github.com/iced-rs/iced/tree/0.9/examples/custom_widget +/// [`geometry`]: https://github.com/iced-rs/iced/tree/0.9/examples/geometry +/// [`pane_grid`]: https://github.com/iced-rs/iced/tree/0.9/examples/pane_grid +/// [`progress_bar`]: https://github.com/iced-rs/iced/tree/0.9/examples/progress_bar +/// [`styling`]: https://github.com/iced-rs/iced/tree/0.9/examples/styling +/// [`svg`]: https://github.com/iced-rs/iced/tree/0.9/examples/svg +/// [`tour`]: https://github.com/iced-rs/iced/tree/0.9/examples/tour  /// [`Canvas widget`]: crate::widget::Canvas  /// [the overview]: index.html#overview -/// [`iced_wgpu`]: https://github.com/iced-rs/iced/tree/0.8/wgpu +/// [`iced_wgpu`]: https://github.com/iced-rs/iced/tree/0.9/wgpu  /// [`Svg` widget]: crate::widget::Svg  /// [Ghostscript Tiger]: https://commons.wikimedia.org/wiki/File:Ghostscript_Tiger.svg  /// diff --git a/src/window/icon.rs b/src/window/icon.rs index 659d2b64..b67b2ea3 100644 --- a/src/window/icon.rs +++ b/src/window/icon.rs @@ -1,175 +1,66 @@  //! Attach an icon to the window of your application. -use std::fmt; +pub use crate::core::window::icon::*; + +use crate::core::window::icon; +  use std::io; -#[cfg(feature = "image_rs")] +#[cfg(feature = "image")]  use std::path::Path; -/// The icon of a window. -#[derive(Clone)] -pub struct Icon(iced_winit::winit::window::Icon); +/// Creates an icon from an image file. +/// +/// This will return an error in case the file is missing at run-time. You may prefer [`Self::from_file_data`] instead. +#[cfg(feature = "image")] +#[cfg_attr(docsrs, doc(cfg(feature = "image")))] +pub fn from_file<P: AsRef<Path>>(icon_path: P) -> Result<Icon, Error> { +    let icon = image_rs::io::Reader::open(icon_path)?.decode()?.to_rgba8(); -impl fmt::Debug for Icon { -    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { -        f.debug_tuple("Icon").field(&format_args!("_")).finish() -    } +    Ok(icon::from_rgba(icon.to_vec(), icon.width(), icon.height())?)  } -impl Icon { -    /// Creates an icon from 32bpp RGBA data. -    pub fn from_rgba( -        rgba: Vec<u8>, -        width: u32, -        height: u32, -    ) -> Result<Self, Error> { -        let raw = -            iced_winit::winit::window::Icon::from_rgba(rgba, width, height)?; - -        Ok(Icon(raw)) -    } - -    /// Creates an icon from an image file. -    /// -    /// This will return an error in case the file is missing at run-time. You may prefer [`Self::from_file_data`] instead. -    #[cfg(feature = "image_rs")] -    pub fn from_file<P: AsRef<Path>>(icon_path: P) -> Result<Self, Error> { -        let icon = image_rs::io::Reader::open(icon_path)?.decode()?.to_rgba8(); - -        Self::from_rgba(icon.to_vec(), icon.width(), icon.height()) -    } - -    /// Creates an icon from the content of an image file. -    /// -    /// This content can be included in your application at compile-time, e.g. using the `include_bytes!` macro. \ -    /// You can pass an explicit file format. Otherwise, the file format will be guessed at runtime. -    #[cfg(feature = "image_rs")] -    pub fn from_file_data( -        data: &[u8], -        explicit_format: Option<image_rs::ImageFormat>, -    ) -> Result<Self, Error> { -        let mut icon = image_rs::io::Reader::new(std::io::Cursor::new(data)); -        let icon_with_format = match explicit_format { -            Some(format) => { -                icon.set_format(format); -                icon -            } -            None => icon.with_guessed_format()?, -        }; +/// Creates an icon from the content of an image file. +/// +/// This content can be included in your application at compile-time, e.g. using the `include_bytes!` macro. +/// You can pass an explicit file format. Otherwise, the file format will be guessed at runtime. +#[cfg(feature = "image")] +#[cfg_attr(docsrs, doc(cfg(feature = "image")))] +pub fn from_file_data( +    data: &[u8], +    explicit_format: Option<image_rs::ImageFormat>, +) -> Result<Icon, Error> { +    let mut icon = image_rs::io::Reader::new(std::io::Cursor::new(data)); +    let icon_with_format = match explicit_format { +        Some(format) => { +            icon.set_format(format); +            icon +        } +        None => icon.with_guessed_format()?, +    }; -        let pixels = icon_with_format.decode()?.to_rgba8(); +    let pixels = icon_with_format.decode()?.to_rgba8(); -        Self::from_rgba(pixels.to_vec(), pixels.width(), pixels.height()) -    } +    Ok(icon::from_rgba( +        pixels.to_vec(), +        pixels.width(), +        pixels.height(), +    )?)  } -/// An error produced when using `Icon::from_rgba` with invalid arguments. -#[derive(Debug)] +/// An error produced when creating an [`Icon`]. +#[derive(Debug, thiserror::Error)]  pub enum Error { -    /// The provided RGBA data isn't divisble by 4. -    /// -    /// Therefore, it cannot be safely interpreted as 32bpp RGBA pixels. -    InvalidData { -        /// The length of the provided RGBA data. -        byte_count: usize, -    }, - -    /// The number of RGBA pixels does not match the provided dimensions. -    DimensionsMismatch { -        /// The provided width. -        width: u32, -        /// The provided height. -        height: u32, -        /// The amount of pixels of the provided RGBA data. -        pixel_count: usize, -    }, +    /// The [`Icon`] is not valid. +    #[error("The icon is invalid: {0}")] +    InvalidError(#[from] icon::Error),      /// The underlying OS failed to create the icon. -    OsError(io::Error), - -    /// The `image` crate reported an error -    #[cfg(feature = "image_rs")] -    ImageError(image_rs::error::ImageError), -} - -impl From<std::io::Error> for Error { -    fn from(os_error: std::io::Error) -> Self { -        Error::OsError(os_error) -    } -} - -impl From<iced_winit::winit::window::BadIcon> for Error { -    fn from(error: iced_winit::winit::window::BadIcon) -> Self { -        use iced_winit::winit::window::BadIcon; - -        match error { -            BadIcon::ByteCountNotDivisibleBy4 { byte_count } => { -                Error::InvalidData { byte_count } -            } -            BadIcon::DimensionsVsPixelCount { -                width, -                height, -                pixel_count, -                .. -            } => Error::DimensionsMismatch { -                width, -                height, -                pixel_count, -            }, -            BadIcon::OsError(os_error) => Error::OsError(os_error), -        } -    } -} - -impl From<Icon> for iced_winit::winit::window::Icon { -    fn from(icon: Icon) -> Self { -        icon.0 -    } -} - -#[cfg(feature = "image_rs")] -impl From<image_rs::error::ImageError> for Error { -    fn from(image_error: image_rs::error::ImageError) -> Self { -        Self::ImageError(image_error) -    } -} - -impl fmt::Display for Error { -    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { -        match self { -            Error::InvalidData { byte_count } => { -                write!( -                    f, -                    "The provided RGBA data (with length {byte_count:?}) isn't divisble by \ -                4. Therefore, it cannot be safely interpreted as 32bpp RGBA \ -                pixels." -                ) -            } -            Error::DimensionsMismatch { -                width, -                height, -                pixel_count, -            } => { -                write!( -                    f, -                    "The number of RGBA pixels ({pixel_count:?}) does not match the provided \ -                dimensions ({width:?}x{height:?})." -                ) -            } -            Error::OsError(e) => write!( -                f, -                "The underlying OS failed to create the window \ -                icon: {e:?}" -            ), -            #[cfg(feature = "image_rs")] -            Error::ImageError(e) => { -                write!(f, "Unable to create icon from a file: {e:?}") -            } -        } -    } -} - -impl std::error::Error for Error { -    fn source(&self) -> Option<&(dyn std::error::Error + 'static)> { -        Some(self) -    } +    #[error("The underlying OS failted to create the window icon: {0}")] +    OsError(#[from] io::Error), + +    /// The `image` crate reported an error. +    #[cfg(feature = "image")] +    #[cfg_attr(docsrs, doc(cfg(feature = "image")))] +    #[error("Unable to create icon from a file: {0}")] +    ImageError(#[from] image_rs::error::ImageError),  } | 
