summaryrefslogtreecommitdiffstats
path: root/widget/src
diff options
context:
space:
mode:
authorLibravatar vawvaw <valentin@wiedekind1.de>2024-01-20 18:47:14 +0100
committerLibravatar Héctor Ramón Jiménez <hector@hecrj.dev>2024-02-07 11:56:43 +0100
commitbcdfbf487198b59f4432545288914f139cdcaf9d (patch)
tree3e6bc485948e94636c3e5beb2a202dc2fabda46e /widget/src
parentd3619b5f69e3688a9ea76b56a072e01f3ca9d9ab (diff)
downloadiced-bcdfbf487198b59f4432545288914f139cdcaf9d.tar.gz
iced-bcdfbf487198b59f4432545288914f139cdcaf9d.tar.bz2
iced-bcdfbf487198b59f4432545288914f139cdcaf9d.zip
Add `Interaction` overriding to `MouseArea`
Add the ability to use a custom `iced::mouse::Interaction` for a `iced::widget::MouseArea`.
Diffstat (limited to 'widget/src')
-rw-r--r--widget/src/mouse_area.rs20
1 files changed, 20 insertions, 0 deletions
diff --git a/widget/src/mouse_area.rs b/widget/src/mouse_area.rs
index f82a75f4..a5967077 100644
--- a/widget/src/mouse_area.rs
+++ b/widget/src/mouse_area.rs
@@ -31,6 +31,7 @@ pub struct MouseArea<
on_mouse_enter: Option<Message>,
on_mouse_move: Option<Box<dyn Fn(Point) -> Message>>,
on_mouse_exit: Option<Message>,
+ interaction: Option<mouse::Interaction>,
}
impl<'a, Message, Theme, Renderer> MouseArea<'a, Message, Theme, Renderer> {
@@ -99,6 +100,16 @@ impl<'a, Message, Theme, Renderer> MouseArea<'a, Message, Theme, Renderer> {
self.on_mouse_exit = Some(message);
self
}
+
+ /// The version of the cursor to use when hovering.
+ #[must_use]
+ pub fn mouse_interaction(
+ mut self,
+ interaction: mouse::Interaction,
+ ) -> Self {
+ self.interaction = Some(interaction);
+ self
+ }
}
/// Local state of the [`MouseArea`].
@@ -123,6 +134,7 @@ impl<'a, Message, Theme, Renderer> MouseArea<'a, Message, Theme, Renderer> {
on_mouse_enter: None,
on_mouse_move: None,
on_mouse_exit: None,
+ interaction: None,
}
}
}
@@ -214,6 +226,14 @@ where
viewport: &Rectangle,
renderer: &Renderer,
) -> mouse::Interaction {
+ if !cursor.is_over(layout.bounds()) {
+ return mouse::Interaction::default();
+ }
+
+ if let Some(interaction) = self.interaction {
+ return interaction;
+ }
+
self.content.as_widget().mouse_interaction(
&tree.children[0],
layout,