diff options
author | 2025-02-03 05:45:51 +0100 | |
---|---|---|
committer | 2025-02-03 05:45:51 +0100 | |
commit | 0c0651de5b1722194d48c19cd645e747fb72ccb6 (patch) | |
tree | 09cd27c82871be6b252c4654addf5b11e85fe359 /core | |
parent | 3029481b72a2ca975a9bb915e23c0461334ba54f (diff) | |
download | iced-0c0651de5b1722194d48c19cd645e747fb72ccb6.tar.gz iced-0c0651de5b1722194d48c19cd645e747fb72ccb6.tar.bz2 iced-0c0651de5b1722194d48c19cd645e747fb72ccb6.zip |
Introduce `Levitating` variant for `mouse::Cursor`
Diffstat (limited to 'core')
-rw-r--r-- | core/src/mouse/cursor.rs | 39 |
1 files changed, 32 insertions, 7 deletions
diff --git a/core/src/mouse/cursor.rs b/core/src/mouse/cursor.rs index 616cd315..9388a578 100644 --- a/core/src/mouse/cursor.rs +++ b/core/src/mouse/cursor.rs @@ -1,13 +1,14 @@ use crate::{Point, Rectangle, Transformation, Vector}; -use std::ops::Mul; - /// The mouse cursor state. #[derive(Debug, Clone, Copy, PartialEq, Default)] pub enum Cursor { /// The cursor has a defined position. Available(Point), + /// The cursor has a defined position, but it's levitating over a layer above. + Levitating(Point), + /// The cursor is currently unavailable (i.e. out of bounds or busy). #[default] Unavailable, @@ -18,7 +19,7 @@ impl Cursor { pub fn position(self) -> Option<Point> { match self { Cursor::Available(position) => Some(position), - Cursor::Unavailable => None, + Cursor::Levitating(_) | Cursor::Unavailable => None, } } @@ -51,17 +52,41 @@ impl Cursor { pub fn is_over(self, bounds: Rectangle) -> bool { self.position_over(bounds).is_some() } + + /// Returns true if the [`Cursor`] is levitating over a layer above. + pub fn is_levitating(self) -> bool { + matches!(self, Self::Levitating(_)) + } + + /// Makes the [`Cursor`] levitate over a layer above. + pub fn levitate(self) -> Self { + match self { + Self::Available(position) => Self::Levitating(position), + _ => self, + } + } + + /// Brings the [`Cursor`] back to the current layer. + pub fn land(self) -> Self { + match self { + Cursor::Levitating(position) => Cursor::Available(position), + _ => self, + } + } } -impl Mul<Transformation> for Cursor { +impl std::ops::Mul<Transformation> for Cursor { type Output = Self; fn mul(self, transformation: Transformation) -> Self { match self { - Cursor::Unavailable => Cursor::Unavailable, - Cursor::Available(point) => { - Cursor::Available(point * transformation) + Self::Available(position) => { + Self::Available(position * transformation) + } + Self::Levitating(position) => { + Self::Levitating(position * transformation) } + Self::Unavailable => Self::Unavailable, } } } |