From ec6384711a5cd4805657cb42eda0dc17f46b95e1 Mon Sep 17 00:00:00 2001 From: Felix Rohrbach Date: Wed, 5 Jan 2011 09:45:49 +0100 Subject: Horizontal scroll wheel may now be used to navigate through history (Disabled by default). --- src/webview.cpp | 82 +++++++++++++++++++++++++++++++++------------------------ 1 file changed, 48 insertions(+), 34 deletions(-) (limited to 'src/webview.cpp') diff --git a/src/webview.cpp b/src/webview.cpp index 2c0b59ea..4fcf5417 100644 --- a/src/webview.cpp +++ b/src/webview.cpp @@ -617,42 +617,56 @@ void WebView::keyPressEvent(QKeyEvent *event) void WebView::wheelEvent(QWheelEvent *event) { - // To let some websites (eg: google maps) to handle wheel events - int prevPos = page()->currentFrame()->scrollPosition().y(); - KWebView::wheelEvent(event); - int newPos = page()->currentFrame()->scrollPosition().y(); - - // Sync with the zoom slider - if (event->modifiers() == Qt::ControlModifier) + if( event->orientation() == Qt::Vertical || !ReKonfig::hScrollWheelHistory() ) { - // Limits of the slider - if (zoomFactor() > 1.9) - setZoomFactor(1.9); - else if (zoomFactor() < 0.1) - setZoomFactor(0.1); - - // Round the factor (Fix slider's end value) - int newFactor = zoomFactor() * 10; - if ((zoomFactor() * 10 - newFactor) > 0.5) - newFactor++; - - emit zoomChanged(newFactor); + // To let some websites (eg: google maps) to handle wheel events + int prevPos = page()->currentFrame()->scrollPosition().y(); + KWebView::wheelEvent(event); + int newPos = page()->currentFrame()->scrollPosition().y(); + + // Sync with the zoom slider + if (event->modifiers() == Qt::ControlModifier) + { + // Limits of the slider + if (zoomFactor() > 1.9) + setZoomFactor(1.9); + else if (zoomFactor() < 0.1) + setZoomFactor(0.1); + + // Round the factor (Fix slider's end value) + int newFactor = zoomFactor() * 10; + if ((zoomFactor() * 10 - newFactor) > 0.5) + newFactor++; + + emit zoomChanged(newFactor); + } + else if (ReKonfig::smoothScrolling() && prevPos != newPos) + { + + page()->currentFrame()->setScrollPosition(QPoint(page()->currentFrame()->scrollPosition().x(), prevPos)); + + if ((event->delta() > 0) != !m_scrollBottom) + stopScrolling(); + + if (event->delta() > 0) + m_scrollBottom = false; + else + m_scrollBottom = true; + + + setupSmoothScrolling(abs(newPos - prevPos)); + } } - else if (ReKonfig::smoothScrolling() && prevPos != newPos) - { - - page()->currentFrame()->setScrollPosition(QPoint(page()->currentFrame()->scrollPosition().x(), prevPos)); - - if ((event->delta() > 0) != !m_scrollBottom) - stopScrolling(); - - if (event->delta() > 0) - m_scrollBottom = false; - else - m_scrollBottom = true; - - - setupSmoothScrolling(abs(newPos - prevPos)); + // use horizontal wheel events to go back and forward in tab history + else { + // left -> go to previous page + if( event->delta() > 0 ){ + emit openPreviousInHistory(); + } + // right -> go to next page + if( event->delta() < 0 ){ + emit openNextInHistory(); + } } } -- cgit v1.2.1