Use PhysicalPosition in PixelDelta event

This removes the `LogicalPosition` from the `PixelDelta`, since all
other APIs have been switched to use `PhysicalPosition` instead.

Fixes #1406.
This commit is contained in:
Christian Duerr 2020-07-26 22:16:21 +00:00 committed by GitHub
parent 55dff53a98
commit 40232d48ba
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 31 additions and 19 deletions

View file

@ -10,6 +10,11 @@
- On android added support for `run_return`. - On android added support for `run_return`.
- On MacOS, Fixed fullscreen and dialog support for `run_return`. - On MacOS, Fixed fullscreen and dialog support for `run_return`.
- On Windows, fix bug where we'd try to emit `MainEventsCleared` events during nested win32 event loops. - On Windows, fix bug where we'd try to emit `MainEventsCleared` events during nested win32 event loops.
- On Windows, `set_ime_position` is now a no-op instead of a runtime crash.
- On Android, `set_fullscreen` is now a no-op instead of a runtime crash.
- On iOS and Android, `set_inner_size` is now a no-op instead of a runtime crash.
- **Breaking:** On Web, `set_cursor_position` and `set_cursor_grab` will now always return an error.
- **Breaking:** `PixelDelta` scroll events now return a `PhysicalPosition`.
# 0.22.2 (2020-05-16) # 0.22.2 (2020-05-16)
@ -49,10 +54,6 @@
- on macOS, fix incorrect ReceivedCharacter events for some key combinations. - on macOS, fix incorrect ReceivedCharacter events for some key combinations.
- **Breaking:** Use `i32` instead of `u32` for position type in `WindowEvent::Moved`. - **Breaking:** Use `i32` instead of `u32` for position type in `WindowEvent::Moved`.
- On macOS, a mouse motion event is now generated before every mouse click. - On macOS, a mouse motion event is now generated before every mouse click.
- On Windows, `set_ime_position` is now a no-op instead of a runtime crash.
- On Android, `set_fullscreen` is now a no-op instead of a runtime crash.
- On iOS and Android, `set_inner_size` is now a no-op instead of a runtime crash.
- **Breaking:** On Web, `set_cursor_position` and `set_cursor_grab` will now always return an error.
# 0.21.0 (2020-02-04) # 0.21.0 (2020-02-04)

View file

@ -37,7 +37,7 @@ use instant::Instant;
use std::path::PathBuf; use std::path::PathBuf;
use crate::{ use crate::{
dpi::{LogicalPosition, PhysicalPosition, PhysicalSize}, dpi::{PhysicalPosition, PhysicalSize},
platform_impl, platform_impl,
window::{Theme, WindowId}, window::{Theme, WindowId},
}; };
@ -764,7 +764,7 @@ pub enum MouseScrollDelta {
/// Scroll events are expressed as a PixelDelta if /// Scroll events are expressed as a PixelDelta if
/// supported by the device (eg. a touchpad) and /// supported by the device (eg. a touchpad) and
/// platform. /// platform.
PixelDelta(LogicalPosition<f64>), PixelDelta(PhysicalPosition<f64>),
} }
/// Symbolic name for a keyboard key. /// Symbolic name for a keyboard key.

View file

@ -170,14 +170,15 @@ pub fn implement_pointer(
wl_pointer::Axis::HorizontalScroll => x += value as f32, wl_pointer::Axis::HorizontalScroll => x += value as f32,
_ => unreachable!(), _ => unreachable!(),
} }
let scale_factor = surface::get_dpi_factor(&surface) as f64;
let delta = LogicalPosition::new(x as f64, y as f64)
.to_physical(scale_factor);
sink.send_window_event( sink.send_window_event(
WindowEvent::MouseWheel { WindowEvent::MouseWheel {
device_id: crate::event::DeviceId( device_id: crate::event::DeviceId(
crate::platform_impl::DeviceId::Wayland(DeviceId), crate::platform_impl::DeviceId::Wayland(DeviceId),
), ),
delta: MouseScrollDelta::PixelDelta( delta: MouseScrollDelta::PixelDelta(delta),
(x as f64, y as f64).into(),
),
phase: TouchPhase::Moved, phase: TouchPhase::Moved,
modifiers: modifiers_tracker.lock().unwrap().clone(), modifiers: modifiers_tracker.lock().unwrap().clone(),
}, },
@ -210,21 +211,21 @@ pub fn implement_pointer(
device_id: crate::event::DeviceId( device_id: crate::event::DeviceId(
crate::platform_impl::DeviceId::Wayland(DeviceId), crate::platform_impl::DeviceId::Wayland(DeviceId),
), ),
delta: MouseScrollDelta::LineDelta(x as f32, y as f32), delta: MouseScrollDelta::LineDelta(x, y),
phase: axis_state, phase: axis_state,
modifiers: modifiers_tracker.lock().unwrap().clone(), modifiers: modifiers_tracker.lock().unwrap().clone(),
}, },
wid, wid,
); );
} else if let Some((x, y)) = axis_buffer { } else if let Some((x, y)) = axis_buffer {
let scale_factor = surface::get_dpi_factor(&surface) as f64;
let delta = LogicalPosition::new(x, y).to_physical(scale_factor);
sink.send_window_event( sink.send_window_event(
WindowEvent::MouseWheel { WindowEvent::MouseWheel {
device_id: crate::event::DeviceId( device_id: crate::event::DeviceId(
crate::platform_impl::DeviceId::Wayland(DeviceId), crate::platform_impl::DeviceId::Wayland(DeviceId),
), ),
delta: MouseScrollDelta::PixelDelta( delta: MouseScrollDelta::PixelDelta(delta),
(x as f64, y as f64).into(),
),
phase: axis_state, phase: axis_state,
modifiers: modifiers_tracker.lock().unwrap().clone(), modifiers: modifiers_tracker.lock().unwrap().clone(),
}, },
@ -238,11 +239,11 @@ pub fn implement_pointer(
axis_state = TouchPhase::Ended; axis_state = TouchPhase::Ended;
} }
PtrEvent::AxisDiscrete { axis, discrete } => { PtrEvent::AxisDiscrete { axis, discrete } => {
let (mut x, mut y) = axis_discrete_buffer.unwrap_or((0, 0)); let (mut x, mut y) = axis_discrete_buffer.unwrap_or((0.0, 0.0));
match axis { match axis {
// wayland vertical sign convention is the inverse of winit // wayland vertical sign convention is the inverse of winit
wl_pointer::Axis::VerticalScroll => y -= discrete, wl_pointer::Axis::VerticalScroll => y -= discrete as f32,
wl_pointer::Axis::HorizontalScroll => x += discrete, wl_pointer::Axis::HorizontalScroll => x += discrete as f32,
_ => unreachable!(), _ => unreachable!(),
} }
axis_discrete_buffer = Some((x, y)); axis_discrete_buffer = Some((x, y));

View file

@ -999,10 +999,14 @@ extern "C" fn scroll_wheel(this: &Object, _sel: Sel, event: id) {
mouse_motion(this, event); mouse_motion(this, event);
unsafe { unsafe {
let state_ptr: *mut c_void = *this.get_ivar("winitState");
let state = &mut *(state_ptr as *mut ViewState);
let delta = { let delta = {
let (x, y) = (event.scrollingDeltaX(), event.scrollingDeltaY()); let (x, y) = (event.scrollingDeltaX(), event.scrollingDeltaY());
if event.hasPreciseScrollingDeltas() == YES { if event.hasPreciseScrollingDeltas() == YES {
MouseScrollDelta::PixelDelta((x as f64, y as f64).into()) let delta = LogicalPosition::new(x, y).to_physical(state.get_scale_factor());
MouseScrollDelta::PixelDelta(delta)
} else { } else {
MouseScrollDelta::LineDelta(x as f32, y as f32) MouseScrollDelta::LineDelta(x as f32, y as f32)
} }

View file

@ -36,7 +36,10 @@ pub fn mouse_scroll_delta(event: &MouseWheelEvent) -> Option<MouseScrollDelta> {
match event.delta_mode() { match event.delta_mode() {
MouseWheelDeltaMode::Line => Some(MouseScrollDelta::LineDelta(x as f32, y as f32)), MouseWheelDeltaMode::Line => Some(MouseScrollDelta::LineDelta(x as f32, y as f32)),
MouseWheelDeltaMode::Pixel => Some(MouseScrollDelta::PixelDelta(LogicalPosition { x, y })), MouseWheelDeltaMode::Pixel => {
let delta = LogicalPosition::new(x, y).to_physical(super::scale_factor());
Some(MouseScrollDelta::PixelDelta(delta))
}
MouseWheelDeltaMode::Page => None, MouseWheelDeltaMode::Page => None,
} }
} }

View file

@ -35,7 +35,10 @@ pub fn mouse_scroll_delta(event: &WheelEvent) -> Option<MouseScrollDelta> {
match event.delta_mode() { match event.delta_mode() {
WheelEvent::DOM_DELTA_LINE => Some(MouseScrollDelta::LineDelta(x as f32, y as f32)), WheelEvent::DOM_DELTA_LINE => Some(MouseScrollDelta::LineDelta(x as f32, y as f32)),
WheelEvent::DOM_DELTA_PIXEL => Some(MouseScrollDelta::PixelDelta(LogicalPosition { x, y })), WheelEvent::DOM_DELTA_PIXEL => {
let delta = LogicalPosition::new(x, y).to_physical(super::scale_factor());
Some(MouseScrollDelta::PixelDelta(delta))
}
_ => None, _ => None,
} }
} }