mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-11 05:21:31 +11:00
Rename DeviceEventFilter
to DeviceEvents
The use of `Filter` was confusing so it was removed inverting the behavior of the enum and methods using it. Co-authored-by: Kirill Chibisov <contact@kchibisov.com>
This commit is contained in:
parent
de5327477a
commit
8bb004a1d9
|
@ -8,6 +8,9 @@ And please only add new entries to the top of this list, right below the `# Unre
|
||||||
|
|
||||||
# Unreleased
|
# Unreleased
|
||||||
|
|
||||||
|
- **Breaking** Rename `DeviceEventFilter` to `DeviceEvents` reversing the behavior of variants.
|
||||||
|
- **Breaking** Rename `EventLoopWindowTarget::set_device_event_filter` to `listen_device_events`.
|
||||||
|
- On X11, fix `EventLoopWindowTarget::listen_device_events` effect being reversed.
|
||||||
- **Breaking:** Remove all deprecated `modifiers` fields.
|
- **Breaking:** Remove all deprecated `modifiers` fields.
|
||||||
- **Breaking:** Overhaul keyboard input handling.
|
- **Breaking:** Overhaul keyboard input handling.
|
||||||
- Replace `KeyboardInput` with `KeyEvent` and `RawKeyEvent`.
|
- Replace `KeyboardInput` with `KeyEvent` and `RawKeyEvent`.
|
||||||
|
|
|
@ -6,7 +6,7 @@ use simple_logger::SimpleLogger;
|
||||||
use winit::{
|
use winit::{
|
||||||
dpi::LogicalSize,
|
dpi::LogicalSize,
|
||||||
event::{ElementState, Event, KeyEvent, WindowEvent},
|
event::{ElementState, Event, KeyEvent, WindowEvent},
|
||||||
event_loop::{DeviceEventFilter, EventLoop},
|
event_loop::{DeviceEvents, EventLoop},
|
||||||
keyboard::Key,
|
keyboard::Key,
|
||||||
window::{WindowBuilder, WindowButtons},
|
window::{WindowBuilder, WindowButtons},
|
||||||
};
|
};
|
||||||
|
@ -26,7 +26,7 @@ fn main() {
|
||||||
eprintln!(" (G) Toggle maximize button");
|
eprintln!(" (G) Toggle maximize button");
|
||||||
eprintln!(" (H) Toggle minimize button");
|
eprintln!(" (H) Toggle minimize button");
|
||||||
|
|
||||||
event_loop.set_device_event_filter(DeviceEventFilter::Never);
|
event_loop.listen_device_events(DeviceEvents::Always);
|
||||||
|
|
||||||
event_loop.run(move |event, _, control_flow| {
|
event_loop.run(move |event, _, control_flow| {
|
||||||
control_flow.set_wait();
|
control_flow.set_wait();
|
||||||
|
|
|
@ -6,7 +6,7 @@ use simple_logger::SimpleLogger;
|
||||||
use winit::{
|
use winit::{
|
||||||
dpi::{LogicalSize, PhysicalSize},
|
dpi::{LogicalSize, PhysicalSize},
|
||||||
event::{DeviceEvent, ElementState, Event, KeyEvent, RawKeyEvent, WindowEvent},
|
event::{DeviceEvent, ElementState, Event, KeyEvent, RawKeyEvent, WindowEvent},
|
||||||
event_loop::{DeviceEventFilter, EventLoop},
|
event_loop::{DeviceEvents, EventLoop},
|
||||||
keyboard::{Key, KeyCode},
|
keyboard::{Key, KeyCode},
|
||||||
window::{Fullscreen, WindowBuilder},
|
window::{Fullscreen, WindowBuilder},
|
||||||
};
|
};
|
||||||
|
@ -33,7 +33,7 @@ fn main() {
|
||||||
let mut minimized = false;
|
let mut minimized = false;
|
||||||
let mut visible = true;
|
let mut visible = true;
|
||||||
|
|
||||||
event_loop.set_device_event_filter(DeviceEventFilter::Never);
|
event_loop.listen_device_events(DeviceEvents::Always);
|
||||||
|
|
||||||
event_loop.run(move |event, _, control_flow| {
|
event_loop.run(move |event, _, control_flow| {
|
||||||
control_flow.set_wait();
|
control_flow.set_wait();
|
||||||
|
|
|
@ -352,20 +352,20 @@ impl<T> EventLoopWindowTarget<T> {
|
||||||
.map(|inner| MonitorHandle { inner })
|
.map(|inner| MonitorHandle { inner })
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Change [`DeviceEvent`] filter mode.
|
/// Change if or when [`DeviceEvent`]s are captured.
|
||||||
///
|
///
|
||||||
/// Since the [`DeviceEvent`] capture can lead to high CPU usage for unfocused windows, winit
|
/// Since the [`DeviceEvent`] capture can lead to high CPU usage for unfocused windows, winit
|
||||||
/// will ignore them by default for unfocused windows on Linux/BSD. This method allows changing
|
/// will ignore them by default for unfocused windows on Linux/BSD. This method allows changing
|
||||||
/// this filter at runtime to explicitly capture them again.
|
/// this at runtime to explicitly capture them again.
|
||||||
///
|
///
|
||||||
/// ## Platform-specific
|
/// ## Platform-specific
|
||||||
///
|
///
|
||||||
/// - **Wayland / macOS / iOS / Android / Web / Orbital:** Unsupported.
|
/// - **Wayland / macOS / iOS / Android / Web / Orbital:** Unsupported.
|
||||||
///
|
///
|
||||||
/// [`DeviceEvent`]: crate::event::DeviceEvent
|
/// [`DeviceEvent`]: crate::event::DeviceEvent
|
||||||
pub fn set_device_event_filter(&self, _filter: DeviceEventFilter) {
|
pub fn listen_device_events(&self, _allowed: DeviceEvents) {
|
||||||
#[cfg(any(x11_platform, wayland_platform, windows))]
|
#[cfg(any(x11_platform, wayland_platform, windows))]
|
||||||
self.p.set_device_event_filter(_filter);
|
self.p.listen_device_events(_allowed);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -423,19 +423,14 @@ impl<T> fmt::Display for EventLoopClosed<T> {
|
||||||
|
|
||||||
impl<T: fmt::Debug> error::Error for EventLoopClosed<T> {}
|
impl<T: fmt::Debug> error::Error for EventLoopClosed<T> {}
|
||||||
|
|
||||||
/// Filter controlling the propagation of device events.
|
/// Control when device events are captured.
|
||||||
#[derive(Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Hash, Debug)]
|
#[derive(Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Hash, Debug, Default)]
|
||||||
pub enum DeviceEventFilter {
|
pub enum DeviceEvents {
|
||||||
/// Always filter out device events.
|
/// Report device events regardless of window focus.
|
||||||
Always,
|
Always,
|
||||||
/// Filter out device events while the window is not focused.
|
/// Only capture device events while the window is focused.
|
||||||
Unfocused,
|
#[default]
|
||||||
/// Report all device events regardless of window focus.
|
WhenFocused,
|
||||||
|
/// Never capture device events.
|
||||||
Never,
|
Never,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Default for DeviceEventFilter {
|
|
||||||
fn default() -> Self {
|
|
||||||
Self::Unfocused
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -30,9 +30,7 @@ use crate::{
|
||||||
dpi::{PhysicalPosition, PhysicalSize, Position, Size},
|
dpi::{PhysicalPosition, PhysicalSize, Position, Size},
|
||||||
error::{ExternalError, NotSupportedError, OsError as RootOsError},
|
error::{ExternalError, NotSupportedError, OsError as RootOsError},
|
||||||
event::{Event, KeyEvent},
|
event::{Event, KeyEvent},
|
||||||
event_loop::{
|
event_loop::{ControlFlow, DeviceEvents, EventLoopClosed, EventLoopWindowTarget as RootELW},
|
||||||
ControlFlow, DeviceEventFilter, EventLoopClosed, EventLoopWindowTarget as RootELW,
|
|
||||||
},
|
|
||||||
icon::Icon,
|
icon::Icon,
|
||||||
keyboard::{Key, KeyCode},
|
keyboard::{Key, KeyCode},
|
||||||
platform::{modifier_supplement::KeyEventExtModifierSupplement, scancode::KeyCodeExtScancode},
|
platform::{modifier_supplement::KeyEventExtModifierSupplement, scancode::KeyCodeExtScancode},
|
||||||
|
@ -894,12 +892,12 @@ impl<T> EventLoopWindowTarget<T> {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_device_event_filter(&self, _filter: DeviceEventFilter) {
|
pub fn listen_device_events(&self, _allowed: DeviceEvents) {
|
||||||
match *self {
|
match *self {
|
||||||
#[cfg(wayland_platform)]
|
#[cfg(wayland_platform)]
|
||||||
EventLoopWindowTarget::Wayland(_) => (),
|
EventLoopWindowTarget::Wayland(_) => (),
|
||||||
#[cfg(x11_platform)]
|
#[cfg(x11_platform)]
|
||||||
EventLoopWindowTarget::X(ref evlp) => evlp.set_device_event_filter(_filter),
|
EventLoopWindowTarget::X(ref evlp) => evlp.set_listen_device_events(_allowed),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -813,7 +813,7 @@ impl<T: 'static> EventProcessor<T> {
|
||||||
if self.active_window != Some(xev.event) {
|
if self.active_window != Some(xev.event) {
|
||||||
self.active_window = Some(xev.event);
|
self.active_window = Some(xev.event);
|
||||||
|
|
||||||
wt.update_device_event_filter(true);
|
wt.update_listen_device_events(true);
|
||||||
|
|
||||||
let window_id = mkwid(xev.event);
|
let window_id = mkwid(xev.event);
|
||||||
let position = PhysicalPosition::new(xev.event_x, xev.event_y);
|
let position = PhysicalPosition::new(xev.event_x, xev.event_y);
|
||||||
|
@ -877,7 +877,7 @@ impl<T: 'static> EventProcessor<T> {
|
||||||
if self.active_window.take() == Some(xev.event) {
|
if self.active_window.take() == Some(xev.event) {
|
||||||
let window_id = mkwid(xev.event);
|
let window_id = mkwid(xev.event);
|
||||||
|
|
||||||
wt.update_device_event_filter(false);
|
wt.update_listen_device_events(false);
|
||||||
|
|
||||||
// Issue key release events for all pressed keys
|
// Issue key release events for all pressed keys
|
||||||
Self::handle_pressed_keys(
|
Self::handle_pressed_keys(
|
||||||
|
|
|
@ -46,9 +46,7 @@ use super::common::xkb_state::KbdState;
|
||||||
use crate::{
|
use crate::{
|
||||||
error::OsError as RootOsError,
|
error::OsError as RootOsError,
|
||||||
event::{Event, StartCause},
|
event::{Event, StartCause},
|
||||||
event_loop::{
|
event_loop::{ControlFlow, DeviceEvents, EventLoopClosed, EventLoopWindowTarget as RootELW},
|
||||||
ControlFlow, DeviceEventFilter, EventLoopClosed, EventLoopWindowTarget as RootELW,
|
|
||||||
},
|
|
||||||
platform_impl::{
|
platform_impl::{
|
||||||
platform::{sticky_exit_callback, WindowId},
|
platform::{sticky_exit_callback, WindowId},
|
||||||
PlatformSpecificWindowBuilderAttributes,
|
PlatformSpecificWindowBuilderAttributes,
|
||||||
|
@ -107,7 +105,7 @@ pub struct EventLoopWindowTarget<T> {
|
||||||
ime: RefCell<Ime>,
|
ime: RefCell<Ime>,
|
||||||
windows: RefCell<HashMap<WindowId, Weak<UnownedWindow>>>,
|
windows: RefCell<HashMap<WindowId, Weak<UnownedWindow>>>,
|
||||||
redraw_sender: WakeSender<WindowId>,
|
redraw_sender: WakeSender<WindowId>,
|
||||||
device_event_filter: Cell<DeviceEventFilter>,
|
device_events: Cell<DeviceEvents>,
|
||||||
_marker: ::std::marker::PhantomData<T>,
|
_marker: ::std::marker::PhantomData<T>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -266,11 +264,11 @@ impl<T: 'static> EventLoop<T> {
|
||||||
sender: redraw_sender, // not used again so no clone
|
sender: redraw_sender, // not used again so no clone
|
||||||
waker: waker.clone(),
|
waker: waker.clone(),
|
||||||
},
|
},
|
||||||
device_event_filter: Default::default(),
|
device_events: Default::default(),
|
||||||
};
|
};
|
||||||
|
|
||||||
// Set initial device event filter.
|
// Set initial device event filter.
|
||||||
window_target.update_device_event_filter(true);
|
window_target.update_listen_device_events(true);
|
||||||
|
|
||||||
let target = Rc::new(RootELW {
|
let target = Rc::new(RootELW {
|
||||||
p: super::EventLoopWindowTarget::X(window_target),
|
p: super::EventLoopWindowTarget::X(window_target),
|
||||||
|
@ -573,17 +571,17 @@ impl<T> EventLoopWindowTarget<T> {
|
||||||
&self.xconn
|
&self.xconn
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_device_event_filter(&self, filter: DeviceEventFilter) {
|
pub fn set_listen_device_events(&self, allowed: DeviceEvents) {
|
||||||
self.device_event_filter.set(filter);
|
self.device_events.set(allowed);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Update the device event filter based on window focus.
|
/// Update the device event based on window focus.
|
||||||
pub fn update_device_event_filter(&self, focus: bool) {
|
pub fn update_listen_device_events(&self, focus: bool) {
|
||||||
let filter_events = self.device_event_filter.get() == DeviceEventFilter::Never
|
let device_events = self.device_events.get() == DeviceEvents::Always
|
||||||
|| (self.device_event_filter.get() == DeviceEventFilter::Unfocused && !focus);
|
|| (focus && self.device_events.get() == DeviceEvents::WhenFocused);
|
||||||
|
|
||||||
let mut mask = 0;
|
let mut mask = 0;
|
||||||
if !filter_events {
|
if device_events {
|
||||||
mask = ffi::XI_RawMotionMask
|
mask = ffi::XI_RawMotionMask
|
||||||
| ffi::XI_RawButtonPressMask
|
| ffi::XI_RawButtonPressMask
|
||||||
| ffi::XI_RawButtonReleaseMask
|
| ffi::XI_RawButtonReleaseMask
|
||||||
|
|
|
@ -76,9 +76,7 @@ use windows_sys::Win32::{
|
||||||
use crate::{
|
use crate::{
|
||||||
dpi::{PhysicalPosition, PhysicalSize},
|
dpi::{PhysicalPosition, PhysicalSize},
|
||||||
event::{DeviceEvent, Event, Force, Ime, RawKeyEvent, Touch, TouchPhase, WindowEvent},
|
event::{DeviceEvent, Event, Force, Ime, RawKeyEvent, Touch, TouchPhase, WindowEvent},
|
||||||
event_loop::{
|
event_loop::{ControlFlow, DeviceEvents, EventLoopClosed, EventLoopWindowTarget as RootELW},
|
||||||
ControlFlow, DeviceEventFilter, EventLoopClosed, EventLoopWindowTarget as RootELW,
|
|
||||||
},
|
|
||||||
keyboard::{KeyCode, ModifiersState},
|
keyboard::{KeyCode, ModifiersState},
|
||||||
platform::scancode::KeyCodeExtScancode,
|
platform::scancode::KeyCodeExtScancode,
|
||||||
platform_impl::platform::{
|
platform_impl::platform::{
|
||||||
|
@ -344,8 +342,8 @@ impl<T> EventLoopWindowTarget<T> {
|
||||||
RawDisplayHandle::Windows(WindowsDisplayHandle::empty())
|
RawDisplayHandle::Windows(WindowsDisplayHandle::empty())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_device_event_filter(&self, filter: DeviceEventFilter) {
|
pub fn listen_device_events(&self, allowed: DeviceEvents) {
|
||||||
raw_input::register_all_mice_and_keyboards_for_raw_input(self.thread_msg_target, filter);
|
raw_input::register_all_mice_and_keyboards_for_raw_input(self.thread_msg_target, allowed);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@ use windows_sys::Win32::{
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
use crate::{event::ElementState, event_loop::DeviceEventFilter, platform_impl::platform::util};
|
use crate::{event::ElementState, event_loop::DeviceEvents, platform_impl::platform::util};
|
||||||
|
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
pub fn get_raw_input_device_list() -> Option<Vec<RAWINPUTDEVICELIST>> {
|
pub fn get_raw_input_device_list() -> Option<Vec<RAWINPUTDEVICELIST>> {
|
||||||
|
@ -140,18 +140,18 @@ pub fn register_raw_input_devices(devices: &[RAWINPUTDEVICE]) -> bool {
|
||||||
|
|
||||||
pub fn register_all_mice_and_keyboards_for_raw_input(
|
pub fn register_all_mice_and_keyboards_for_raw_input(
|
||||||
mut window_handle: HWND,
|
mut window_handle: HWND,
|
||||||
filter: DeviceEventFilter,
|
filter: DeviceEvents,
|
||||||
) -> bool {
|
) -> bool {
|
||||||
// RIDEV_DEVNOTIFY: receive hotplug events
|
// RIDEV_DEVNOTIFY: receive hotplug events
|
||||||
// RIDEV_INPUTSINK: receive events even if we're not in the foreground
|
// RIDEV_INPUTSINK: receive events even if we're not in the foreground
|
||||||
// RIDEV_REMOVE: don't receive device events (requires NULL hwndTarget)
|
// RIDEV_REMOVE: don't receive device events (requires NULL hwndTarget)
|
||||||
let flags = match filter {
|
let flags = match filter {
|
||||||
DeviceEventFilter::Always => {
|
DeviceEvents::Never => {
|
||||||
window_handle = 0;
|
window_handle = 0;
|
||||||
RIDEV_REMOVE
|
RIDEV_REMOVE
|
||||||
}
|
}
|
||||||
DeviceEventFilter::Unfocused => RIDEV_DEVNOTIFY,
|
DeviceEvents::WhenFocused => RIDEV_DEVNOTIFY,
|
||||||
DeviceEventFilter::Never => RIDEV_DEVNOTIFY | RIDEV_INPUTSINK,
|
DeviceEvents::Always => RIDEV_DEVNOTIFY | RIDEV_INPUTSINK,
|
||||||
};
|
};
|
||||||
|
|
||||||
let devices: [RAWINPUTDEVICE; 2] = [
|
let devices: [RAWINPUTDEVICE; 2] = [
|
||||||
|
|
Loading…
Reference in a new issue