diff options
| author | 2023-07-27 01:02:28 +0200 | |
|---|---|---|
| committer | 2023-07-27 01:04:18 +0200 | |
| commit | e2ba7ece83f141c149659747977147392df008f4 (patch) | |
| tree | 5fa04524d0ca95c6289c4d5962af7a97098ec811 /core/src/widget | |
| parent | e29754f32d03efc4b075e9b63cc554d128bc2ccf (diff) | |
| download | iced-e2ba7ece83f141c149659747977147392df008f4.tar.gz iced-e2ba7ece83f141c149659747977147392df008f4.tar.bz2 iced-e2ba7ece83f141c149659747977147392df008f4.zip | |
Introduce `visible_bounds` operation for `Container`
Diffstat (limited to 'core/src/widget')
| -rw-r--r-- | core/src/widget/operation.rs | 32 | ||||
| -rw-r--r-- | core/src/widget/operation/focusable.rs | 6 | ||||
| -rw-r--r-- | core/src/widget/operation/scrollable.rs | 19 | ||||
| -rw-r--r-- | core/src/widget/operation/text_input.rs | 5 | 
4 files changed, 54 insertions, 8 deletions
| diff --git a/core/src/widget/operation.rs b/core/src/widget/operation.rs index ad188c36..b91cf9ac 100644 --- a/core/src/widget/operation.rs +++ b/core/src/widget/operation.rs @@ -8,6 +8,7 @@ pub use scrollable::Scrollable;  pub use text_input::TextInput;  use crate::widget::Id; +use crate::{Rectangle, Vector};  use std::any::Any;  use std::fmt; @@ -23,6 +24,7 @@ pub trait Operation<T> {      fn container(          &mut self,          id: Option<&Id>, +        bounds: Rectangle,          operate_on_children: &mut dyn FnMut(&mut dyn Operation<T>),      ); @@ -30,7 +32,14 @@ pub trait Operation<T> {      fn focusable(&mut self, _state: &mut dyn Focusable, _id: Option<&Id>) {}      /// Operates on a widget that can be scrolled. -    fn scrollable(&mut self, _state: &mut dyn Scrollable, _id: Option<&Id>) {} +    fn scrollable( +        &mut self, +        _state: &mut dyn Scrollable, +        _id: Option<&Id>, +        _bounds: Rectangle, +        _translation: Vector, +    ) { +    }      /// Operates on a widget that has text input.      fn text_input(&mut self, _state: &mut dyn TextInput, _id: Option<&Id>) {} @@ -92,6 +101,7 @@ where          fn container(              &mut self,              id: Option<&Id>, +            bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<B>),          ) {              struct MapRef<'a, A> { @@ -102,11 +112,12 @@ where                  fn container(                      &mut self,                      id: Option<&Id>, +                    bounds: Rectangle,                      operate_on_children: &mut dyn FnMut(&mut dyn Operation<B>),                  ) {                      let Self { operation, .. } = self; -                    operation.container(id, &mut |operation| { +                    operation.container(id, bounds, &mut |operation| {                          operate_on_children(&mut MapRef { operation });                      });                  } @@ -115,8 +126,10 @@ where                      &mut self,                      state: &mut dyn Scrollable,                      id: Option<&Id>, +                    bounds: Rectangle, +                    translation: Vector,                  ) { -                    self.operation.scrollable(state, id); +                    self.operation.scrollable(state, id, bounds, translation);                  }                  fn focusable( @@ -145,15 +158,21 @@ where              MapRef {                  operation: operation.as_mut(),              } -            .container(id, operate_on_children); +            .container(id, bounds, operate_on_children);          }          fn focusable(&mut self, state: &mut dyn Focusable, id: Option<&Id>) {              self.operation.focusable(state, id);          } -        fn scrollable(&mut self, state: &mut dyn Scrollable, id: Option<&Id>) { -            self.operation.scrollable(state, id); +        fn scrollable( +            &mut self, +            state: &mut dyn Scrollable, +            id: Option<&Id>, +            bounds: Rectangle, +            translation: Vector, +        ) { +            self.operation.scrollable(state, id, bounds, translation);          }          fn text_input(&mut self, state: &mut dyn TextInput, id: Option<&Id>) { @@ -197,6 +216,7 @@ pub fn scope<T: 'static>(          fn container(              &mut self,              id: Option<&Id>, +            _bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<Message>),          ) {              if id == Some(&self.target) { diff --git a/core/src/widget/operation/focusable.rs b/core/src/widget/operation/focusable.rs index 312e4894..ab1b677e 100644 --- a/core/src/widget/operation/focusable.rs +++ b/core/src/widget/operation/focusable.rs @@ -1,6 +1,7 @@  //! Operate on widgets that can be focused.  use crate::widget::operation::{Operation, Outcome};  use crate::widget::Id; +use crate::Rectangle;  /// The internal state of a widget that can be focused.  pub trait Focusable { @@ -45,6 +46,7 @@ pub fn focus<T>(target: Id) -> impl Operation<T> {          fn container(              &mut self,              _id: Option<&Id>, +            _bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<T>),          ) {              operate_on_children(self) @@ -80,6 +82,7 @@ where          fn container(              &mut self,              _id: Option<&Id>, +            _bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<T>),          ) {              operate_on_children(self) @@ -126,6 +129,7 @@ pub fn focus_previous<T>() -> impl Operation<T> {          fn container(              &mut self,              _id: Option<&Id>, +            _bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<T>),          ) {              operate_on_children(self) @@ -159,6 +163,7 @@ pub fn focus_next<T>() -> impl Operation<T> {          fn container(              &mut self,              _id: Option<&Id>, +            _bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<T>),          ) {              operate_on_children(self) @@ -185,6 +190,7 @@ pub fn find_focused() -> impl Operation<Id> {          fn container(              &mut self,              _id: Option<&Id>, +            _bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<Id>),          ) {              operate_on_children(self) diff --git a/core/src/widget/operation/scrollable.rs b/core/src/widget/operation/scrollable.rs index f947344d..4f8b2a98 100644 --- a/core/src/widget/operation/scrollable.rs +++ b/core/src/widget/operation/scrollable.rs @@ -1,5 +1,6 @@  //! Operate on widgets that can be scrolled.  use crate::widget::{Id, Operation}; +use crate::{Rectangle, Vector};  /// The internal state of a widget that can be scrolled.  pub trait Scrollable { @@ -22,12 +23,19 @@ pub fn snap_to<T>(target: Id, offset: RelativeOffset) -> impl Operation<T> {          fn container(              &mut self,              _id: Option<&Id>, +            _bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<T>),          ) {              operate_on_children(self)          } -        fn scrollable(&mut self, state: &mut dyn Scrollable, id: Option<&Id>) { +        fn scrollable( +            &mut self, +            state: &mut dyn Scrollable, +            id: Option<&Id>, +            _bounds: Rectangle, +            _translation: Vector, +        ) {              if Some(&self.target) == id {                  state.snap_to(self.offset);              } @@ -49,12 +57,19 @@ pub fn scroll_to<T>(target: Id, offset: AbsoluteOffset) -> impl Operation<T> {          fn container(              &mut self,              _id: Option<&Id>, +            _bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<T>),          ) {              operate_on_children(self)          } -        fn scrollable(&mut self, state: &mut dyn Scrollable, id: Option<&Id>) { +        fn scrollable( +            &mut self, +            state: &mut dyn Scrollable, +            id: Option<&Id>, +            _bounds: Rectangle, +            _translation: Vector, +        ) {              if Some(&self.target) == id {                  state.scroll_to(self.offset);              } diff --git a/core/src/widget/operation/text_input.rs b/core/src/widget/operation/text_input.rs index 4c773e99..a9ea2e81 100644 --- a/core/src/widget/operation/text_input.rs +++ b/core/src/widget/operation/text_input.rs @@ -1,6 +1,7 @@  //! Operate on widgets that have text input.  use crate::widget::operation::Operation;  use crate::widget::Id; +use crate::Rectangle;  /// The internal state of a widget that has text input.  pub trait TextInput { @@ -34,6 +35,7 @@ pub fn move_cursor_to_front<T>(target: Id) -> impl Operation<T> {          fn container(              &mut self,              _id: Option<&Id>, +            _bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<T>),          ) {              operate_on_children(self) @@ -63,6 +65,7 @@ pub fn move_cursor_to_end<T>(target: Id) -> impl Operation<T> {          fn container(              &mut self,              _id: Option<&Id>, +            _bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<T>),          ) {              operate_on_children(self) @@ -93,6 +96,7 @@ pub fn move_cursor_to<T>(target: Id, position: usize) -> impl Operation<T> {          fn container(              &mut self,              _id: Option<&Id>, +            _bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<T>),          ) {              operate_on_children(self) @@ -121,6 +125,7 @@ pub fn select_all<T>(target: Id) -> impl Operation<T> {          fn container(              &mut self,              _id: Option<&Id>, +            _bounds: Rectangle,              operate_on_children: &mut dyn FnMut(&mut dyn Operation<T>),          ) {              operate_on_children(self) | 
