diff options
| author | 2020-07-31 06:55:55 +0200 | |
|---|---|---|
| committer | 2020-07-31 06:55:55 +0200 | |
| commit | 72cfe85f7f2d3cc1221b788b7d86b99057bb58eb (patch) | |
| tree | 654a75aba4c364af4ec3a9bf76db63c7fc780f21 /native | |
| parent | 869fa6baa81b1e5fa52bec7f4d02ddf7e29167ff (diff) | |
| parent | ac74f354244bf6ecccd8b694dfe08c50cc2ec909 (diff) | |
| download | iced-72cfe85f7f2d3cc1221b788b7d86b99057bb58eb.tar.gz iced-72cfe85f7f2d3cc1221b788b7d86b99057bb58eb.tar.bz2 iced-72cfe85f7f2d3cc1221b788b7d86b99057bb58eb.zip | |
Merge pull request #463 from mobile-bungalow/titlebar_options
Added `always_show_controls` method to TitleBar
Diffstat (limited to '')
| -rw-r--r-- | native/src/widget/pane_grid/title_bar.rs | 41 | 
1 files changed, 29 insertions, 12 deletions
| diff --git a/native/src/widget/pane_grid/title_bar.rs b/native/src/widget/pane_grid/title_bar.rs index c74c9e20..1d4a32e9 100644 --- a/native/src/widget/pane_grid/title_bar.rs +++ b/native/src/widget/pane_grid/title_bar.rs @@ -11,6 +11,7 @@ pub struct TitleBar<'a, Message, Renderer: pane_grid::Renderer> {      title_size: Option<u16>,      controls: Option<Element<'a, Message, Renderer>>,      padding: u16, +    always_show_controls: bool,      style: Renderer::Style,  } @@ -18,7 +19,7 @@ impl<'a, Message, Renderer> TitleBar<'a, Message, Renderer>  where      Renderer: pane_grid::Renderer,  { -    /// Cretes a new [`TitleBar`] with the given title. +    /// Creates a new [`TitleBar`] with the given title.      ///      /// [`TitleBar`]: struct.TitleBar.html      pub fn new(title: impl Into<String>) -> Self { @@ -27,6 +28,7 @@ where              title_size: None,              controls: None,              padding: 0, +            always_show_controls: false,              style: Renderer::Style::default(),          }      } @@ -65,6 +67,20 @@ where          self.style = style.into();          self      } + +    /// Sets whether or not the [`controls`] attached to this [`TitleBar`] are +    /// always visible. +    /// +    /// By default, the controls are only visible when the [`Pane`] of this +    /// [`TitleBar`] is hovered. +    /// +    /// [`TitleBar`]: struct.TitleBar.html +    /// [`controls`]: struct.TitleBar.html#method.controls +    /// [`Pane`]: struct.Pane.html +    pub fn always_show_controls(mut self) -> Self { +        self.always_show_controls = true; +        self +    }  }  impl<'a, Message, Renderer> TitleBar<'a, Message, Renderer> @@ -92,17 +108,18 @@ where              let title_layout = children.next().unwrap();              let controls_layout = children.next().unwrap(); -            let (title_bounds, controls) = if show_controls { -                (title_layout.bounds(), Some((controls, controls_layout))) -            } else { -                ( -                    Rectangle { -                        width: padded.bounds().width, -                        ..title_layout.bounds() -                    }, -                    None, -                ) -            }; +            let (title_bounds, controls) = +                if show_controls || self.always_show_controls { +                    (title_layout.bounds(), Some((controls, controls_layout))) +                } else { +                    ( +                        Rectangle { +                            width: padded.bounds().width, +                            ..title_layout.bounds() +                        }, +                        None, +                    ) +                };              renderer.draw_title_bar(                  defaults, | 
