diff options
| author | 2024-02-12 19:36:45 +0100 | |
|---|---|---|
| committer | 2024-02-12 19:36:45 +0100 | |
| commit | 7615b2240c360fea21ef041bfd5b1deb73fc03d1 (patch) | |
| tree | 3d4056ab100186b46f6f4423f0584afcfc32e8ac /widget | |
| parent | 891f29eea0cb32f0bee49fbace1757b82e1937f3 (diff) | |
| parent | 88e2e26ef4517933442af3dbdca30db2a1bf7ace (diff) | |
| download | iced-7615b2240c360fea21ef041bfd5b1deb73fc03d1.tar.gz iced-7615b2240c360fea21ef041bfd5b1deb73fc03d1.tar.bz2 iced-7615b2240c360fea21ef041bfd5b1deb73fc03d1.zip | |
Merge pull request #2239 from dtzxporter/scrollable-quad-fill
Introduce an appearance for a scrollable, ability to customize the scrollbar gap.
Diffstat (limited to '')
| -rw-r--r-- | widget/src/scrollable.rs | 85 | 
1 files changed, 63 insertions, 22 deletions
| diff --git a/widget/src/scrollable.rs b/widget/src/scrollable.rs index 207b2539..3814c590 100644 --- a/widget/src/scrollable.rs +++ b/widget/src/scrollable.rs @@ -1,4 +1,5 @@  //! Navigate an endless amount of content with a scrollbar. +use crate::container;  use crate::core::event::{self, Event};  use crate::core::keyboard;  use crate::core::layout; @@ -15,7 +16,9 @@ use crate::core::{  };  use crate::runtime::Command; -pub use crate::style::scrollable::{Scrollbar, Scroller, StyleSheet}; +pub use crate::style::scrollable::{ +    Appearance, Scrollbar, Scroller, StyleSheet, +};  pub use operation::scrollable::{AbsoluteOffset, RelativeOffset};  /// A widget that can vertically display an infinite amount of content with a @@ -878,6 +881,24 @@ pub fn draw<Theme, Renderer>(          _ => mouse::Cursor::Unavailable,      }; +    let appearance = if state.y_scroller_grabbed_at.is_some() +        || state.x_scroller_grabbed_at.is_some() +    { +        theme.dragging(style) +    } else if cursor_over_scrollable.is_some() { +        theme.hovered(style, mouse_over_y_scrollbar || mouse_over_x_scrollbar) +    } else { +        theme.active(style) +    }; + +    let idle_scrollbar = theme.active(style).scrollbar; + +    container::draw_background( +        renderer, +        &appearance.container, +        layout.bounds(), +    ); +      // Draw inner content      if scrollbars.active() {          renderer.with_layer(bounds, |renderer| { @@ -902,7 +923,6 @@ pub fn draw<Theme, Renderer>(              |renderer: &mut Renderer,               style: Scrollbar,               scrollbar: &internals::Scrollbar| { -                //track                  if scrollbar.bounds.width > 0.0                      && scrollbar.bounds.height > 0.0                      && (style.background.is_some() @@ -921,7 +941,6 @@ pub fn draw<Theme, Renderer>(                      );                  } -                //thumb                  if scrollbar.scroller.bounds.width > 0.0                      && scrollbar.scroller.bounds.height > 0.0                      && (style.scroller.color != Color::TRANSPARENT @@ -946,30 +965,52 @@ pub fn draw<Theme, Renderer>(                  ..bounds              },              |renderer| { -                //draw y scrollbar                  if let Some(scrollbar) = scrollbars.y { -                    let style = if state.y_scroller_grabbed_at.is_some() { -                        theme.dragging(style) -                    } else if cursor_over_scrollable.is_some() { -                        theme.hovered(style, mouse_over_y_scrollbar) -                    } else { -                        theme.active(style) -                    }; - -                    draw_scrollbar(renderer, style, &scrollbar); +                    draw_scrollbar( +                        renderer, +                        if mouse_over_y_scrollbar +                            || state.y_scroller_grabbed_at.is_some() +                        { +                            appearance.scrollbar +                        } else { +                            idle_scrollbar +                        }, +                        &scrollbar, +                    );                  } -                //draw x scrollbar                  if let Some(scrollbar) = scrollbars.x { -                    let style = if state.x_scroller_grabbed_at.is_some() { -                        theme.dragging_horizontal(style) -                    } else if cursor_over_scrollable.is_some() { -                        theme.hovered_horizontal(style, mouse_over_x_scrollbar) -                    } else { -                        theme.active_horizontal(style) -                    }; +                    draw_scrollbar( +                        renderer, +                        if mouse_over_x_scrollbar +                            || state.x_scroller_grabbed_at.is_some() +                        { +                            appearance.scrollbar +                        } else { +                            idle_scrollbar +                        }, +                        &scrollbar, +                    ); +                } -                    draw_scrollbar(renderer, style, &scrollbar); +                if let (Some(x), Some(y)) = (scrollbars.x, scrollbars.y) { +                    let background = +                        appearance.gap.or(appearance.container.background); + +                    if let Some(background) = background { +                        renderer.fill_quad( +                            renderer::Quad { +                                bounds: Rectangle { +                                    x: y.bounds.x, +                                    y: x.bounds.y, +                                    width: y.bounds.width, +                                    height: x.bounds.height, +                                }, +                                ..renderer::Quad::default() +                            }, +                            background, +                        ); +                    }                  }              },          ); | 
