blob: 37049b9b2f2aca307c89d0e26f73d3b1265b1533 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
From d25e5ac7089f2c81cc5ffe8e155ba8b3dfb11b97 Mon Sep 17 00:00:00 2001
From: Kurt Hindenburg <kurt.hindenburg@gmail.com>
Date: Wed, 7 Feb 2018 10:38:09 -0500
Subject: Fix mouse wheel scrolling with libinput
If the Libinput X server input driver is used we get a value for
pixelDelta for a physical mouse wheel scroll, so we check that the
source of the wheel event is actually a mouse, this was fixed in
Qt 5.9.5*
https://bugreports.qt.io/browse/QTBUG-59261
Patch by ahmadsamir
* fixed in Gentoo: Qt 5.9.4
BUG: 386762
Differential Revision: https://phabricator.kde.org/D9008
---
src/ScrollState.cpp | 19 +++++++++++++++----
1 file changed, 15 insertions(+), 4 deletions(-)
diff --git a/src/ScrollState.cpp b/src/ScrollState.cpp
index e5b486d..f71b142 100644
--- a/src/ScrollState.cpp
+++ b/src/ScrollState.cpp
@@ -25,10 +25,21 @@ using namespace Konsole;
void ScrollState::addWheelEvent(const QWheelEvent *wheel)
{
- if ((wheel->angleDelta().y() != 0) && (wheel->pixelDelta().y() == 0)) {
- _remainingScrollPixel = 0;
- } else {
- _remainingScrollPixel += wheel->pixelDelta().y();
+ // If the Libinput X server input driver is used we get a value for
+ // pixelDelta for a physical mouse wheel scroll, so we check that
+ // the source of the wheel event is actually a mouse, this has been
+ // fixed upstream in Qt 5.9.5: https://bugreports.qt.io/browse/QTBUG-59261
+ // Fixes Konsole BUG: https://bugs.kde.org/show_bug.cgi?id=386762
+#if (QT_VERSION < QT_VERSION_CHECK(5, 9, 4))
+ if (wheel->source() != Qt::MouseEventNotSynthesized) {
+#else
+ if (true) {
+#endif
+ if ((wheel->angleDelta().y() != 0) && (wheel->pixelDelta().y() == 0)) {
+ _remainingScrollPixel = 0;
+ } else {
+ _remainingScrollPixel += wheel->pixelDelta().y();
+ }
}
_remainingScrollAngle += wheel->angleDelta().y();
}
--
cgit v0.11.2
|