From b168f9a98bbe00643e15a49075ed80ac6c82fa74 Mon Sep 17 00:00:00 2001 From: Friso Smit Date: Mon, 6 Feb 2023 14:17:29 +0100 Subject: Fix zooming for high resolution scroll wheels BUG: 432671 --- src/views/dolphinview.cpp | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) (limited to 'src/views/dolphinview.cpp') diff --git a/src/views/dolphinview.cpp b/src/views/dolphinview.cpp index 250fe4cc7..1f61bcbf2 100644 --- a/src/views/dolphinview.cpp +++ b/src/views/dolphinview.cpp @@ -931,6 +931,11 @@ bool DolphinView::eventFilter(QObject *watched, QEvent *event) } } break; + case QEvent::KeyRelease: + if (static_cast(event)->key() == Qt::Key_Control) { + m_controlWheelAccumulatedDelta = 0; + } + break; case QEvent::FocusIn: if (watched == m_container) { setActive(true); @@ -969,10 +974,16 @@ bool DolphinView::eventFilter(QObject *watched, QEvent *event) void DolphinView::wheelEvent(QWheelEvent *event) { if (event->modifiers().testFlag(Qt::ControlModifier)) { - const QPoint numDegrees = event->angleDelta() / 8; - const QPoint numSteps = numDegrees / 15; + m_controlWheelAccumulatedDelta += event->angleDelta().y(); + + if (m_controlWheelAccumulatedDelta <= -QWheelEvent::DefaultDeltasPerStep) { + slotDecreaseZoom(); + m_controlWheelAccumulatedDelta += QWheelEvent::DefaultDeltasPerStep; + } else if (m_controlWheelAccumulatedDelta >= QWheelEvent::DefaultDeltasPerStep) { + slotIncreaseZoom(); + m_controlWheelAccumulatedDelta -= QWheelEvent::DefaultDeltasPerStep; + } - setZoomLevel(zoomLevel() + numSteps.y()); event->accept(); } else { event->ignore(); -- cgit v1.3