From 0b140488b425a7d1fd45ca41592de25b28d3ac17 Mon Sep 17 00:00:00 2001 From: cossonleo Date: Fri, 15 Jan 2021 22:40:16 +0800 Subject: [PATCH 1/2] add focus event --- native/src/window/event.rs | 3 +++ winit/src/conversion.rs | 3 +++ 2 files changed, 6 insertions(+) diff --git a/native/src/window/event.rs b/native/src/window/event.rs index b177141a..d649760b 100644 --- a/native/src/window/event.rs +++ b/native/src/window/event.rs @@ -29,4 +29,7 @@ pub enum Event { /// There will be a single `FilesHoveredLeft` event triggered even if /// multiple files were hovered. FilesHoveredLeft, + + /// A window was focused or not + Focused(bool), } diff --git a/winit/src/conversion.rs b/winit/src/conversion.rs index f073c474..5265b844 100644 --- a/winit/src/conversion.rs +++ b/winit/src/conversion.rs @@ -121,6 +121,9 @@ pub fn window_event( WindowEvent::Touch(touch) => { Some(Event::Touch(touch_event(*touch, scale_factor))) } + WindowEvent::Focused(focused) => { + Some(Event::Window(window::Event::Focused(*focused))) + } _ => None, } } From 45dc02e9bd0b4f2c6cc65781b850f460cddf6171 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?H=C3=A9ctor=20Ram=C3=B3n=20Jim=C3=A9nez?= Date: Fri, 15 Jan 2021 18:21:44 +0100 Subject: [PATCH 2/2] Split `window::Event::Focused` into two variants --- native/src/window/event.rs | 11 +++++++---- winit/src/conversion.rs | 8 +++++--- 2 files changed, 12 insertions(+), 7 deletions(-) diff --git a/native/src/window/event.rs b/native/src/window/event.rs index d649760b..fc746781 100644 --- a/native/src/window/event.rs +++ b/native/src/window/event.rs @@ -3,7 +3,7 @@ use std::path::PathBuf; /// A window-related event. #[derive(PartialEq, Clone, Debug)] pub enum Event { - /// A window was resized + /// A window was resized. Resized { /// The new width of the window (in units) width: u32, @@ -12,6 +12,12 @@ pub enum Event { height: u32, }, + /// A window was focused. + Focused, + + /// A window was unfocused. + Unfocused, + /// A file is being hovered over the window. /// /// When the user hovers multiple files at once, this event will be emitted @@ -29,7 +35,4 @@ pub enum Event { /// There will be a single `FilesHoveredLeft` event triggered even if /// multiple files were hovered. FilesHoveredLeft, - - /// A window was focused or not - Focused(bool), } diff --git a/winit/src/conversion.rs b/winit/src/conversion.rs index 5265b844..0e04b35d 100644 --- a/winit/src/conversion.rs +++ b/winit/src/conversion.rs @@ -109,6 +109,11 @@ pub fn window_event( WindowEvent::ModifiersChanged(new_modifiers) => Some(Event::Keyboard( keyboard::Event::ModifiersChanged(self::modifiers(*new_modifiers)), )), + WindowEvent::Focused(focused) => Some(Event::Window(if *focused { + window::Event::Focused + } else { + window::Event::Unfocused + })), WindowEvent::HoveredFile(path) => { Some(Event::Window(window::Event::FileHovered(path.clone()))) } @@ -121,9 +126,6 @@ pub fn window_event( WindowEvent::Touch(touch) => { Some(Event::Touch(touch_event(*touch, scale_factor))) } - WindowEvent::Focused(focused) => { - Some(Event::Window(window::Event::Focused(*focused))) - } _ => None, } }