diff options
| author | 2020-10-22 14:07:07 -0500 | |
|---|---|---|
| committer | 2020-10-22 14:07:07 -0500 | |
| commit | 09e67c5c2701e7eeeb0bdb924966f8442c698b6a (patch) | |
| tree | b46bec5f9bea50e74d83a31eed67499004048137 /native | |
| parent | 23647d2f50f0e177b93cf09c72886a90702df982 (diff) | |
| download | iced-09e67c5c2701e7eeeb0bdb924966f8442c698b6a.tar.gz iced-09e67c5c2701e7eeeb0bdb924966f8442c698b6a.tar.bz2 iced-09e67c5c2701e7eeeb0bdb924966f8442c698b6a.zip | |
Replace hard-coded params with struct members
Diffstat (limited to '')
| -rw-r--r-- | native/src/renderer/null.rs | 3 | ||||
| -rw-r--r-- | native/src/widget/scrollable.rs | 58 | 
2 files changed, 59 insertions, 2 deletions
| diff --git a/native/src/renderer/null.rs b/native/src/renderer/null.rs index 2aee0da1..b06b0e28 100644 --- a/native/src/renderer/null.rs +++ b/native/src/renderer/null.rs @@ -89,6 +89,9 @@ impl scrollable::Renderer for Null {          _bounds: Rectangle,          _content_bounds: Rectangle,          _offset: u32, +        _scrollbar_width: u16, +        _scrollbar_margin: u16, +        _scroller_width: u16,      ) -> Option<scrollable::Scrollbar> {          None      } diff --git a/native/src/widget/scrollable.rs b/native/src/widget/scrollable.rs index 75e97027..1cbc2bbf 100644 --- a/native/src/widget/scrollable.rs +++ b/native/src/widget/scrollable.rs @@ -13,6 +13,9 @@ pub struct Scrollable<'a, Message, Renderer: self::Renderer> {      state: &'a mut State,      height: Length,      max_height: u32, +    scrollbar_width: u16, +    scrollbar_margin: u16, +    scroller_width: u16,      content: Column<'a, Message, Renderer>,      style: Renderer::Style,  } @@ -27,6 +30,9 @@ impl<'a, Message, Renderer: self::Renderer> Scrollable<'a, Message, Renderer> {              state,              height: Length::Shrink,              max_height: u32::MAX, +            scrollbar_width: 10, +            scrollbar_margin: 2, +            scroller_width: 10,              content: Column::new(),              style: Renderer::Style::default(),          } @@ -90,6 +96,32 @@ impl<'a, Message, Renderer: self::Renderer> Scrollable<'a, Message, Renderer> {          self      } +    /// Sets the scrollbar width of the [`Scrollable`] . +    /// Silently enforces a minimum value of 1. +    /// +    /// [`Scrollable`]: struct.Scrollable.html +    pub fn scrollbar_width(mut self, scrollbar_width: u16) -> Self { +        self.scrollbar_width = scrollbar_width.max(1); +        self +    } + +    /// Sets the scrollbar margin of the [`Scrollable`] . +    /// +    /// [`Scrollable`]: struct.Scrollable.html +    pub fn scrollbar_margin(mut self, scrollbar_margin: u16) -> Self { +        self.scrollbar_margin = scrollbar_margin; +        self +    } + +    /// Sets the scroller width of the [`Scrollable`] . +    /// Silently enforces a minimum value of 1. +    /// +    /// [`Scrollable`]: struct.Scrollable.html +    pub fn scroller_width(mut self, scroller_width: u16) -> Self { +        self.scroller_width = scroller_width.max(1); +        self +    } +      /// Sets the style of the [`Scrollable`] .      ///      /// [`Scrollable`]: struct.Scrollable.html @@ -178,7 +210,14 @@ where          }          let offset = self.state.offset(bounds, content_bounds); -        let scrollbar = renderer.scrollbar(bounds, content_bounds, offset); +        let scrollbar = renderer.scrollbar( +            bounds, +            content_bounds, +            offset, +            self.scrollbar_width, +            self.scrollbar_margin, +            self.scroller_width, +        );          let is_mouse_over_scrollbar = scrollbar              .as_ref()              .map(|scrollbar| scrollbar.is_mouse_over(cursor_position)) @@ -269,7 +308,14 @@ where          let content_layout = layout.children().next().unwrap();          let content_bounds = content_layout.bounds();          let offset = self.state.offset(bounds, content_bounds); -        let scrollbar = renderer.scrollbar(bounds, content_bounds, offset); +        let scrollbar = renderer.scrollbar( +            bounds, +            content_bounds, +            offset, +            self.scrollbar_width, +            self.scrollbar_margin, +            self.scroller_width, +        );          let is_mouse_over = bounds.contains(cursor_position);          let is_mouse_over_scrollbar = scrollbar @@ -418,6 +464,11 @@ pub struct Scrollbar {      /// [`Scrollbar`]: struct.Scrollbar.html      pub bounds: Rectangle, +    /// The margin within the [`Scrollbar`]. +    /// +    /// [`Scrollbar`]: struct.Scrollbar.html +    pub margin: u16, +      /// The bounds of the [`Scroller`].      ///      /// [`Scroller`]: struct.Scroller.html @@ -486,6 +537,9 @@ pub trait Renderer: column::Renderer + Sized {          bounds: Rectangle,          content_bounds: Rectangle,          offset: u32, +        scrollbar_width: u16, +        scrollbar_margin: u16, +        scroller_width: u16,      ) -> Option<Scrollbar>;      /// Draws the [`Scrollable`]. | 
