summaryrefslogtreecommitdiff
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