aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortv <tv@krebsco.de>2023-08-05 21:08:38 +0200
committerGitHub <noreply@github.com>2023-08-05 19:08:38 +0000
commit34b3be775df196bd2cfb1193d88cfea0b8d6d9b8 (patch)
tree8dd1a64a1505d11a8b30f57dd7cef1b9716fc76c
parent7b9f32300ee0a249c0872302c97635b460e45ba5 (diff)
downloadalacritty-34b3be775df196bd2cfb1193d88cfea0b8d6d9b8.tar.gz
alacritty-34b3be775df196bd2cfb1193d88cfea0b8d6d9b8.zip
Ignore scrolling multiplier on touchscreens
-rw-r--r--CHANGELOG.md1
-rw-r--r--alacritty/src/input.rs20
2 files changed, 11 insertions, 10 deletions
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 7db85331..095cd311 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -42,6 +42,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/).
- `OptionAsAlt` with `OnlyLeft`/`OnlyRight` settings not working properly on macOS
- Default Vi key bindings for `Last`/`First` actions not working on X11/Wayland
- Cut off wide characters in preedit string
+- Scrolling on touchscreens
### Removed
diff --git a/alacritty/src/input.rs b/alacritty/src/input.rs
index 56832aff..dc46a316 100644
--- a/alacritty/src/input.rs
+++ b/alacritty/src/input.rs
@@ -63,9 +63,6 @@ const MIN_SELECTION_SCROLLING_HEIGHT: f64 = 5.;
/// Number of pixels for increasing the selection scrolling speed factor by one.
const SELECTION_SCROLLING_STEP: f64 = 20.;
-/// Touch scroll speed.
-const TOUCH_SCROLL_FACTOR: f64 = 0.35;
-
/// Distance before a touch input is considered a drag.
const MAX_TAP_DISTANCE: f64 = 20.;
@@ -650,11 +647,16 @@ impl<T: EventListener, A: ActionContext<T>> Processor<T, A> {
}
pub fn mouse_wheel_input(&mut self, delta: MouseScrollDelta, phase: TouchPhase) {
+ let multiplier = self.ctx.config().terminal_config.scrolling.multiplier;
match delta {
MouseScrollDelta::LineDelta(columns, lines) => {
let new_scroll_px_x = columns * self.ctx.size_info().cell_width();
let new_scroll_px_y = lines * self.ctx.size_info().cell_height();
- self.scroll_terminal(new_scroll_px_x as f64, new_scroll_px_y as f64);
+ self.scroll_terminal(
+ new_scroll_px_x as f64,
+ new_scroll_px_y as f64,
+ multiplier as f64,
+ );
},
MouseScrollDelta::PixelDelta(mut lpos) => {
match phase {
@@ -671,7 +673,7 @@ impl<T: EventListener, A: ActionContext<T>> Processor<T, A> {
lpos.x = 0.;
}
- self.scroll_terminal(lpos.x, lpos.y);
+ self.scroll_terminal(lpos.x, lpos.y, multiplier as f64);
},
_ => (),
}
@@ -679,7 +681,7 @@ impl<T: EventListener, A: ActionContext<T>> Processor<T, A> {
}
}
- fn scroll_terminal(&mut self, new_scroll_x_px: f64, new_scroll_y_px: f64) {
+ fn scroll_terminal(&mut self, new_scroll_x_px: f64, new_scroll_y_px: f64, multiplier: f64) {
const MOUSE_WHEEL_UP: u8 = 64;
const MOUSE_WHEEL_DOWN: u8 = 65;
const MOUSE_WHEEL_LEFT: u8 = 66;
@@ -712,8 +714,6 @@ impl<T: EventListener, A: ActionContext<T>> Processor<T, A> {
.contains(TermMode::ALT_SCREEN | TermMode::ALTERNATE_SCROLL)
&& !self.ctx.modifiers().state().shift_key()
{
- let multiplier = f64::from(self.ctx.config().terminal_config.scrolling.multiplier);
-
self.ctx.mouse_mut().accumulated_scroll.x += new_scroll_x_px * multiplier;
self.ctx.mouse_mut().accumulated_scroll.y += new_scroll_y_px * multiplier;
@@ -740,7 +740,6 @@ impl<T: EventListener, A: ActionContext<T>> Processor<T, A> {
self.ctx.write_to_pty(content);
} else {
- let multiplier = f64::from(self.ctx.config().terminal_config.scrolling.multiplier);
self.ctx.mouse_mut().accumulated_scroll.y += new_scroll_y_px * multiplier;
let lines = (self.ctx.mouse().accumulated_scroll.y / height) as i32;
@@ -828,7 +827,8 @@ impl<T: EventListener, A: ActionContext<T>> Processor<T, A> {
let delta_y = touch.location.y - last_touch.location.y;
*touch_purpose = TouchPurpose::Scroll(touch);
- self.scroll_terminal(0., delta_y * TOUCH_SCROLL_FACTOR);
+ // Use a fixed scroll factor for touchscreens, to accurately track finger motion.
+ self.scroll_terminal(0., delta_y, 1.0);
},
TouchPurpose::Select(_) => self.mouse_moved(touch.location),
TouchPurpose::Invalid(_) => (),