diff options
author | 2022-02-13 19:01:09 +0700 | |
---|---|---|
committer | 2022-02-13 19:01:09 +0700 | |
commit | 0fec0a2b77b6b9447117f2fea81c700a25fbca6d (patch) | |
tree | 1a3ae6c2711a31d512f725fe90545f4519632b26 /pure/src | |
parent | 3f1a45ca47dc086a5c4e45867d3f9c63a4e7ba19 (diff) | |
download | iced-0fec0a2b77b6b9447117f2fea81c700a25fbca6d.tar.gz iced-0fec0a2b77b6b9447117f2fea81c700a25fbca6d.tar.bz2 iced-0fec0a2b77b6b9447117f2fea81c700a25fbca6d.zip |
Implement `Toggler` in `iced_pure`
Diffstat (limited to 'pure/src')
-rw-r--r-- | pure/src/widget.rs | 2 | ||||
-rw-r--r-- | pure/src/widget/image.rs | 13 | ||||
-rw-r--r-- | pure/src/widget/toggler.rs | 123 |
3 files changed, 138 insertions, 0 deletions
diff --git a/pure/src/widget.rs b/pure/src/widget.rs index 009741a8..1c0633a6 100644 --- a/pure/src/widget.rs +++ b/pure/src/widget.rs @@ -10,6 +10,7 @@ mod scrollable; mod slider; mod text; mod text_input; +mod toggler; mod tree; pub use button::Button; @@ -23,6 +24,7 @@ pub use scrollable::Scrollable; pub use slider::Slider; pub use text::Text; pub use text_input::TextInput; +pub use toggler::Toggler; pub use tree::Tree; use iced_native::event::{self, Event}; diff --git a/pure/src/widget/image.rs b/pure/src/widget/image.rs index b33dad2b..51a24ed1 100644 --- a/pure/src/widget/image.rs +++ b/pure/src/widget/image.rs @@ -1,4 +1,5 @@ use crate::widget::{Tree, Widget}; +use crate::Element; use iced_native::layout::{self, Layout}; use iced_native::renderer; @@ -72,3 +73,15 @@ where ) } } + +impl<'a, Message, Renderer, Handle> Into<Element<'a, Message, Renderer>> + for Image<Handle> +where + Message: Clone + 'a, + Renderer: iced_native::image::Renderer<Handle = Handle> + 'a, + Handle: Clone + Hash + 'a, +{ + fn into(self) -> Element<'a, Message, Renderer> { + Element::new(self) + } +} diff --git a/pure/src/widget/toggler.rs b/pure/src/widget/toggler.rs new file mode 100644 index 00000000..ec86fff0 --- /dev/null +++ b/pure/src/widget/toggler.rs @@ -0,0 +1,123 @@ +use crate::widget::{Tree, Widget}; +use crate::Element; + +use iced_native::event::{self, Event}; +use iced_native::layout::{self, Layout}; +use iced_native::mouse; +use iced_native::renderer; +use iced_native::text; +use iced_native::{Clipboard, Hasher, Length, Point, Rectangle, Shell}; + +use std::any::{self, Any}; + +pub use iced_native::widget::toggler::{Style, StyleSheet, Toggler}; + +impl<'a, Message, Renderer> Widget<Message, Renderer> + for Toggler<'a, Message, Renderer> +where + Renderer: text::Renderer, +{ + fn tag(&self) -> any::TypeId { + any::TypeId::of::<()>() + } + + fn state(&self) -> Box<dyn Any> { + Box::new(()) + } + + fn children_state(&self) -> Vec<Tree> { + Vec::new() + } + + 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 hash_layout(&self, state: &mut Hasher) { + <Self as iced_native::Widget<Message, Renderer>>::hash_layout( + self, state, + ) + } + + fn layout( + &self, + renderer: &Renderer, + limits: &layout::Limits, + ) -> layout::Node { + <Self as iced_native::Widget<Message, Renderer>>::layout( + self, renderer, limits, + ) + } + + fn draw( + &self, + _state: &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, + ) + } + + fn mouse_interaction( + &self, + _state: &Tree, + layout: Layout<'_>, + cursor_position: Point, + viewport: &Rectangle, + renderer: &Renderer, + ) -> mouse::Interaction { + <Self as iced_native::Widget<Message, Renderer>>::mouse_interaction( + self, + layout, + cursor_position, + viewport, + renderer, + ) + } + + fn on_event( + &mut self, + _state: &mut Tree, + event: Event, + layout: Layout<'_>, + cursor_position: Point, + renderer: &Renderer, + clipboard: &mut dyn Clipboard, + shell: &mut Shell<'_, Message>, + ) -> event::Status { + <Self as iced_native::Widget<Message, Renderer>>::on_event( + self, + event, + layout, + cursor_position, + renderer, + clipboard, + shell, + ) + } +} + +impl<'a, Message, Renderer> Into<Element<'a, Message, Renderer>> + for Toggler<'a, Message, Renderer> +where + Message: 'a, + Renderer: text::Renderer + 'a, +{ + fn into(self) -> Element<'a, Message, Renderer> { + Element::new(self) + } +} |