From ef44adea69fe891d5b2837740536d6c0f86fa691 Mon Sep 17 00:00:00 2001 From: Ivan Molodetskikh Date: Fri, 23 May 2025 22:59:04 +0300 Subject: Set pointer contents straight to nothing when disabling pointer --- src/niri.rs | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/niri.rs b/src/niri.rs index 79d20639..fd8d586a 100644 --- a/src/niri.rs +++ b/src/niri.rs @@ -929,7 +929,7 @@ impl State { let pointer = &self.niri.seat.get_pointer().unwrap(); let location = pointer.current_location(); - let under = match self.niri.pointer_visibility { + let mut under = match self.niri.pointer_visibility { PointerVisibility::Disabled => PointContents::default(), _ => self.niri.contents_under(location), }; @@ -943,6 +943,14 @@ impl State { // Disable the hidden pointer if the contents underneath have changed. if !self.niri.pointer_visibility.is_visible() { self.niri.pointer_visibility = PointerVisibility::Disabled; + + // When setting PointerVisibility::Hidden together with pointer contents changing, + // we can change straight to nothing to avoid one frame of hover. Notably, this can + // be triggered through warp-mouse-to-focus combined with hide-when-typing. + under = PointContents::default(); + if self.niri.pointer_contents == under { + return false; + } } self.niri.pointer_contents.clone_from(&under); -- cgit