swipeTracker: Use unaccelerated deltas
Unaccelerated deltas make sure the gesture works the same regardless of how fast the fingers move; this is what we were already doing for scrolling. Remove the swipe multiplier as the deltas already match scrolling other than the 1/10 multiplier Clutter applies to scrolling specifically. Part-of: <https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/1763>
This commit is contained in:
parent
20d99c69cb
commit
b156cabdc9
@ -16,7 +16,6 @@ const TOUCHPAD_BASE_WIDTH = 400;
|
|||||||
const EVENT_HISTORY_THRESHOLD_MS = 150;
|
const EVENT_HISTORY_THRESHOLD_MS = 150;
|
||||||
|
|
||||||
const SCROLL_MULTIPLIER = 10;
|
const SCROLL_MULTIPLIER = 10;
|
||||||
const SWIPE_MULTIPLIER = 0.5;
|
|
||||||
|
|
||||||
const MIN_ANIMATION_DURATION = 100;
|
const MIN_ANIMATION_DURATION = 100;
|
||||||
const MAX_ANIMATION_DURATION = 400;
|
const MAX_ANIMATION_DURATION = 400;
|
||||||
@ -139,7 +138,7 @@ const TouchpadSwipeGesture = GObject.registerClass({
|
|||||||
let time = event.get_time();
|
let time = event.get_time();
|
||||||
|
|
||||||
const [x, y] = event.get_coords();
|
const [x, y] = event.get_coords();
|
||||||
let [dx, dy] = event.get_gesture_motion_delta();
|
const [dx, dy] = event.get_gesture_motion_delta_unaccelerated();
|
||||||
|
|
||||||
if (this._state === TouchpadState.NONE) {
|
if (this._state === TouchpadState.NONE) {
|
||||||
if (dx === 0 && dy === 0)
|
if (dx === 0 && dy === 0)
|
||||||
@ -151,8 +150,8 @@ const TouchpadSwipeGesture = GObject.registerClass({
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (this._state === TouchpadState.PENDING) {
|
if (this._state === TouchpadState.PENDING) {
|
||||||
this._cumulativeX += dx * SWIPE_MULTIPLIER;
|
this._cumulativeX += dx;
|
||||||
this._cumulativeY += dy * SWIPE_MULTIPLIER;
|
this._cumulativeY += dy;
|
||||||
|
|
||||||
const cdx = this._cumulativeX;
|
const cdx = this._cumulativeX;
|
||||||
const cdy = this._cumulativeY;
|
const cdy = this._cumulativeY;
|
||||||
@ -179,7 +178,7 @@ const TouchpadSwipeGesture = GObject.registerClass({
|
|||||||
}
|
}
|
||||||
|
|
||||||
const vertical = this.orientation === Clutter.Orientation.VERTICAL;
|
const vertical = this.orientation === Clutter.Orientation.VERTICAL;
|
||||||
let delta = (vertical ? dy : dx) * SWIPE_MULTIPLIER;
|
let delta = vertical ? dy : dx;
|
||||||
const distance = vertical ? TOUCHPAD_BASE_HEIGHT : TOUCHPAD_BASE_WIDTH;
|
const distance = vertical ? TOUCHPAD_BASE_HEIGHT : TOUCHPAD_BASE_WIDTH;
|
||||||
|
|
||||||
switch (event.get_gesture_phase()) {
|
switch (event.get_gesture_phase()) {
|
||||||
|
Loading…
Reference in New Issue
Block a user