Introduce is_mouse_over_scrollbar to StyleSheet::hovered for Scrollable

This commit is contained in:
Héctor Ramón Jiménez 2023-03-27 15:51:32 +02:00
parent c337bf297d
commit c407b4504c
No known key found for this signature in database
GPG key ID: 140CC052C94F138E
4 changed files with 74 additions and 67 deletions

View file

@ -339,22 +339,36 @@ impl scrollable::StyleSheet for ScrollbarCustomStyle {
style.active(&theme::Scrollable::Default) style.active(&theme::Scrollable::Default)
} }
fn hovered(&self, style: &Self::Style) -> Scrollbar { fn hovered(
style.hovered(&theme::Scrollable::Default) &self,
style: &Self::Style,
is_mouse_over_scrollbar: bool,
) -> Scrollbar {
style.hovered(&theme::Scrollable::Default, is_mouse_over_scrollbar)
} }
fn hovered_horizontal(&self, style: &Self::Style) -> Scrollbar { fn hovered_horizontal(
Scrollbar { &self,
background: style.active(&theme::Scrollable::default()).background, style: &Self::Style,
border_radius: 0.0, is_mouse_over_scrollbar: bool,
border_width: 0.0, ) -> Scrollbar {
border_color: Default::default(), if is_mouse_over_scrollbar {
scroller: Scroller { Scrollbar {
color: Color::from_rgb8(250, 85, 134), background: style
.active(&theme::Scrollable::default())
.background,
border_radius: 0.0, border_radius: 0.0,
border_width: 0.0, border_width: 0.0,
border_color: Default::default(), border_color: Default::default(),
}, scroller: Scroller {
color: Color::from_rgb8(250, 85, 134),
border_radius: 0.0,
border_width: 0.0,
border_color: Default::default(),
},
}
} else {
self.active(style)
} }
} }
} }

View file

@ -857,10 +857,8 @@ pub fn draw<Renderer>(
if let Some(scrollbar) = scrollbars.y { if let Some(scrollbar) = scrollbars.y {
let style = if state.y_scroller_grabbed_at.is_some() { let style = if state.y_scroller_grabbed_at.is_some() {
theme.dragging(style) theme.dragging(style)
} else if mouse_over_y_scrollbar {
theme.hovered_scrollbar(style)
} else if mouse_over_scrollable { } else if mouse_over_scrollable {
theme.hovered(style) theme.hovered(style, mouse_over_y_scrollbar)
} else { } else {
theme.active(style) theme.active(style)
}; };
@ -872,10 +870,8 @@ pub fn draw<Renderer>(
if let Some(scrollbar) = scrollbars.x { if let Some(scrollbar) = scrollbars.x {
let style = if state.x_scroller_grabbed_at.is_some() { let style = if state.x_scroller_grabbed_at.is_some() {
theme.dragging_horizontal(style) theme.dragging_horizontal(style)
} else if mouse_over_x_scrollbar {
theme.hovered_scrollbar_horizontal(style)
} else if mouse_over_scrollable { } else if mouse_over_scrollable {
theme.hovered_horizontal(style) theme.hovered_horizontal(style, mouse_over_x_scrollbar)
} else { } else {
theme.active_horizontal(style) theme.active_horizontal(style)
}; };

View file

@ -37,17 +37,16 @@ pub trait StyleSheet {
/// Produces the style of an active scrollbar. /// Produces the style of an active scrollbar.
fn active(&self, style: &Self::Style) -> Scrollbar; fn active(&self, style: &Self::Style) -> Scrollbar;
/// Produces the style of a hovered scrollbar. /// Produces the style of a scrollbar when the scrollable is being hovered.
fn hovered_scrollbar(&self, style: &Self::Style) -> Scrollbar; fn hovered(
&self,
style: &Self::Style,
is_mouse_over_scrollbar: bool,
) -> Scrollbar;
/// Produces the style of a scrollbar that is being dragged. /// Produces the style of a scrollbar that is being dragged.
fn dragging(&self, style: &Self::Style) -> Scrollbar { fn dragging(&self, style: &Self::Style) -> Scrollbar {
self.hovered_scrollbar(style) self.hovered(style, true)
}
/// Produces the style of a scrollbar when mouse is over the scrollable area.
fn hovered(&self, style: &Self::Style) -> Scrollbar {
self.active(style)
} }
/// Produces the style of an active horizontal scrollbar. /// Produces the style of an active horizontal scrollbar.
@ -55,18 +54,17 @@ pub trait StyleSheet {
self.active(style) self.active(style)
} }
/// Produces the style of a hovered horizontal scrollbar. /// Produces the style of a horizontal scrollbar when the scrollable is being hovered.
fn hovered_scrollbar_horizontal(&self, style: &Self::Style) -> Scrollbar { fn hovered_horizontal(
self.hovered_scrollbar(style) &self,
style: &Self::Style,
is_mouse_over_scrollbar: bool,
) -> Scrollbar {
self.hovered(style, is_mouse_over_scrollbar)
} }
/// Produces the style of a horizontal scrollbar that is being dragged. /// Produces the style of a horizontal scrollbar that is being dragged.
fn dragging_horizontal(&self, style: &Self::Style) -> Scrollbar { fn dragging_horizontal(&self, style: &Self::Style) -> Scrollbar {
self.hovered_scrollbar_horizontal(style) self.hovered(style, true)
}
/// Produces the style of a horizontal scrollbar when mouse is over the scrollable area.
fn hovered_horizontal(&self, style: &Self::Style) -> Scrollbar {
self.active_horizontal(style)
} }
} }

View file

@ -906,42 +906,45 @@ impl scrollable::StyleSheet for Theme {
} }
} }
fn hovered_scrollbar(&self, style: &Self::Style) -> scrollable::Scrollbar { fn hovered(
&self,
style: &Self::Style,
is_mouse_over_scrollbar: bool,
) -> scrollable::Scrollbar {
match style { match style {
Scrollable::Default => { Scrollable::Default => {
let palette = self.extended_palette(); if is_mouse_over_scrollbar {
let palette = self.extended_palette();
scrollable::Scrollbar { scrollable::Scrollbar {
background: palette.background.weak.color.into(), background: palette.background.weak.color.into(),
border_radius: 2.0,
border_width: 0.0,
border_color: Color::TRANSPARENT,
scroller: scrollable::Scroller {
color: palette.primary.strong.color,
border_radius: 2.0, border_radius: 2.0,
border_width: 0.0, border_width: 0.0,
border_color: Color::TRANSPARENT, border_color: Color::TRANSPARENT,
}, scroller: scrollable::Scroller {
color: palette.primary.strong.color,
border_radius: 2.0,
border_width: 0.0,
border_color: Color::TRANSPARENT,
},
}
} else {
self.active(style)
} }
} }
Scrollable::Custom(custom) => custom.hovered_scrollbar(self), Scrollable::Custom(custom) => {
custom.hovered(self, is_mouse_over_scrollbar)
}
} }
} }
fn dragging(&self, style: &Self::Style) -> scrollable::Scrollbar { fn dragging(&self, style: &Self::Style) -> scrollable::Scrollbar {
match style { match style {
Scrollable::Default => self.hovered_scrollbar(style), Scrollable::Default => self.hovered(style, true),
Scrollable::Custom(custom) => custom.dragging(self), Scrollable::Custom(custom) => custom.dragging(self),
} }
} }
fn hovered(&self, style: &Self::Style) -> scrollable::Scrollbar {
match style {
Scrollable::Default => self.active(style),
Scrollable::Custom(custom) => custom.hovered(self),
}
}
fn active_horizontal(&self, style: &Self::Style) -> scrollable::Scrollbar { fn active_horizontal(&self, style: &Self::Style) -> scrollable::Scrollbar {
match style { match style {
Scrollable::Default => self.active(style), Scrollable::Default => self.active(style),
@ -949,10 +952,16 @@ impl scrollable::StyleSheet for Theme {
} }
} }
fn hovered_scrollbar_horizontal(&self, style: &Self::Style) -> scrollable::Scrollbar { fn hovered_horizontal(
&self,
style: &Self::Style,
is_mouse_over_scrollbar: bool,
) -> scrollable::Scrollbar {
match style { match style {
Scrollable::Default => self.hovered_scrollbar(style), Scrollable::Default => self.hovered(style, is_mouse_over_scrollbar),
Scrollable::Custom(custom) => custom.hovered_scrollbar_horizontal(self), Scrollable::Custom(custom) => {
custom.hovered_horizontal(self, is_mouse_over_scrollbar)
}
} }
} }
@ -961,20 +970,10 @@ impl scrollable::StyleSheet for Theme {
style: &Self::Style, style: &Self::Style,
) -> scrollable::Scrollbar { ) -> scrollable::Scrollbar {
match style { match style {
Scrollable::Default => self.hovered_horizontal(style), Scrollable::Default => self.hovered_horizontal(style, true),
Scrollable::Custom(custom) => custom.dragging_horizontal(self), Scrollable::Custom(custom) => custom.dragging_horizontal(self),
} }
} }
fn hovered_horizontal(
&self,
style: &Self::Style,
) -> scrollable::Scrollbar {
match style {
Scrollable::Default => self.active_horizontal(style),
Scrollable::Custom(custom) => custom.hovered_horizontal(self),
}
}
} }
/// The style of text. /// The style of text.