diff options
| author | 2024-01-16 12:02:42 +0100 | |
|---|---|---|
| committer | 2024-01-16 12:02:42 +0100 | |
| commit | 534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0 (patch) | |
| tree | 0ddc8f1b681cbade7e47293bd46a362896aa538a /widget/src/pane_grid | |
| parent | 17135cbd56316f31167eb62e026839450506573f (diff) | |
| parent | c4ba657de86d7606587dad5124f435141258f570 (diff) | |
| download | iced-534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0.tar.gz iced-534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0.tar.bz2 iced-534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0.zip | |
Merge branch 'master' into update-winit
Diffstat (limited to 'widget/src/pane_grid')
| -rw-r--r-- | widget/src/pane_grid/content.rs | 9 | ||||
| -rw-r--r-- | widget/src/pane_grid/state.rs | 17 | ||||
| -rw-r--r-- | widget/src/pane_grid/title_bar.rs | 18 | 
3 files changed, 31 insertions, 13 deletions
| diff --git a/widget/src/pane_grid/content.rs b/widget/src/pane_grid/content.rs index 826ea663..ee00f186 100644 --- a/widget/src/pane_grid/content.rs +++ b/widget/src/pane_grid/content.rs @@ -165,7 +165,7 @@ where              let title_bar_size = title_bar_layout.size(); -            let mut body_layout = self.body.as_widget().layout( +            let body_layout = self.body.as_widget().layout(                  &mut tree.children[0],                  renderer,                  &layout::Limits::new( @@ -177,11 +177,12 @@ where                  ),              ); -            body_layout.move_to(Point::new(0.0, title_bar_size.height)); -              layout::Node::with_children(                  max_size, -                vec![title_bar_layout, body_layout], +                vec![ +                    title_bar_layout, +                    body_layout.move_to(Point::new(0.0, title_bar_size.height)), +                ],              )          } else {              self.body.as_widget().layout( diff --git a/widget/src/pane_grid/state.rs b/widget/src/pane_grid/state.rs index 481cd770..5d1fe254 100644 --- a/widget/src/pane_grid/state.rs +++ b/widget/src/pane_grid/state.rs @@ -403,6 +403,15 @@ pub enum Action {      ///      /// [`PaneGrid`]: super::PaneGrid      Idle, +    /// A [`Pane`] in the [`PaneGrid`] is being clicked. +    /// +    /// [`PaneGrid`]: super::PaneGrid +    Clicking { +        /// The [`Pane`] being clicked. +        pane: Pane, +        /// The starting [`Point`] of the click interaction. +        origin: Point, +    },      /// A [`Pane`] in the [`PaneGrid`] is being dragged.      ///      /// [`PaneGrid`]: super::PaneGrid @@ -432,6 +441,14 @@ impl Action {          }      } +    /// Returns the current [`Pane`] that is being clicked, if any. +    pub fn clicked_pane(&self) -> Option<(Pane, Point)> { +        match *self { +            Action::Clicking { pane, origin, .. } => Some((pane, origin)), +            _ => None, +        } +    } +      /// Returns the current [`Split`] that is being dragged, if any.      pub fn picked_split(&self) -> Option<(Split, Axis)> {          match *self { diff --git a/widget/src/pane_grid/title_bar.rs b/widget/src/pane_grid/title_bar.rs index f4dbb6b1..eb21b743 100644 --- a/widget/src/pane_grid/title_bar.rs +++ b/widget/src/pane_grid/title_bar.rs @@ -217,7 +217,7 @@ where          renderer: &Renderer,          limits: &layout::Limits,      ) -> layout::Node { -        let limits = limits.pad(self.padding); +        let limits = limits.shrink(self.padding);          let max_size = limits.max();          let title_layout = self.content.as_widget().layout( @@ -228,8 +228,8 @@ where          let title_size = title_layout.size(); -        let mut node = if let Some(controls) = &self.controls { -            let mut controls_layout = controls.as_widget().layout( +        let node = if let Some(controls) = &self.controls { +            let controls_layout = controls.as_widget().layout(                  &mut tree.children[1],                  renderer,                  &layout::Limits::new(Size::ZERO, max_size), @@ -240,11 +240,13 @@ where              let height = title_size.height.max(controls_size.height); -            controls_layout.move_to(Point::new(space_before_controls, 0.0)); -              layout::Node::with_children(                  Size::new(max_size.width, height), -                vec![title_layout, controls_layout], +                vec![ +                    title_layout, +                    controls_layout +                        .move_to(Point::new(space_before_controls, 0.0)), +                ],              )          } else {              layout::Node::with_children( @@ -253,9 +255,7 @@ where              )          }; -        node.move_to(Point::new(self.padding.left, self.padding.top)); - -        layout::Node::with_children(node.size().pad(self.padding), vec![node]) +        layout::Node::container(node, self.padding)      }      pub(crate) fn operate( | 
