diff options
-rw-r--r-- | pure/src/widget.rs | 2 | ||||
-rw-r--r-- | pure/src/widget/svg.rs | 62 | ||||
-rw-r--r-- | src/pure/widget.rs | 6 |
3 files changed, 70 insertions, 0 deletions
diff --git a/pure/src/widget.rs b/pure/src/widget.rs index be73c5fa..8200f9a7 100644 --- a/pure/src/widget.rs +++ b/pure/src/widget.rs @@ -9,6 +9,7 @@ pub mod radio; pub mod rule; pub mod scrollable; pub mod slider; +pub mod svg; pub mod text_input; pub mod toggler; pub mod tree; @@ -32,6 +33,7 @@ pub use rule::Rule; pub use scrollable::Scrollable; pub use slider::Slider; pub use space::Space; +pub use svg::Svg; pub use text::Text; pub use text_input::TextInput; pub use toggler::Toggler; diff --git a/pure/src/widget/svg.rs b/pure/src/widget/svg.rs new file mode 100644 index 00000000..2758c5b1 --- /dev/null +++ b/pure/src/widget/svg.rs @@ -0,0 +1,62 @@ +use crate::widget::{Tree, Widget}; +use crate::Element; + +use iced_native::layout::{self, Layout}; +use iced_native::renderer; +use iced_native::widget::svg; +use iced_native::{Length, Point, Rectangle}; + +pub use iced_native::svg::Handle; +pub use svg::Svg; + +impl<Message, Renderer> Widget<Message, Renderer> for Svg +where + Renderer: iced_native::svg::Renderer, +{ + fn width(&self) -> Length { + <Self as iced_native::Widget<Message, Renderer>>::width(self) + } + + fn height(&self) -> Length { + <Self as iced_native::Widget<Message, Renderer>>::height(self) + } + + fn layout( + &self, + renderer: &Renderer, + limits: &layout::Limits, + ) -> layout::Node { + <Self as iced_native::Widget<Message, Renderer>>::layout( + self, renderer, limits, + ) + } + + fn draw( + &self, + _tree: &Tree, + renderer: &mut Renderer, + style: &renderer::Style, + layout: Layout<'_>, + cursor_position: Point, + viewport: &Rectangle, + ) { + <Self as iced_native::Widget<Message, Renderer>>::draw( + self, + renderer, + style, + layout, + cursor_position, + viewport, + ) + } +} + +impl<'a, Message, Renderer> Into<Element<'a, Message, Renderer>> for Svg +where + Message: Clone + 'a, + Renderer: iced_native::svg::Renderer + 'a, +{ + fn into(self) -> Element<'a, Message, Renderer> { + Element::new(self) + } +} diff --git a/src/pure/widget.rs b/src/pure/widget.rs index 39ccd090..6628b1fb 100644 --- a/src/pure/widget.rs +++ b/src/pure/widget.rs @@ -151,6 +151,9 @@ pub mod image { pub type Image = iced_pure::widget::Image<Handle>; } +#[cfg(feature = "svg")] +pub use iced_pure::widget::svg; + #[cfg(feature = "canvas")] pub use canvas::Canvas; @@ -159,3 +162,6 @@ pub use qr_code::QRCode; #[cfg(feature = "image")] pub use image::Image; + +#[cfg(feature = "svg")] +pub use svg::Svg; |