diff options
author | Yoann Laissus <yoann.laissus@gmail.com> | 2012-08-16 14:59:53 +0200 |
---|---|---|
committer | Yoann Laissus <yoann.laissus@gmail.com> | 2012-08-16 15:14:15 +0200 |
commit | 46152144132f5e915c8a4a90f903c4f477ebff15 (patch) | |
tree | 3c8893bbdef2fa75af5cc323741eaf8d814f8882 /src/zoombar.cpp | |
parent | Make sure to add all MainWindow before a new tab. (diff) | |
download | rekonq-46152144132f5e915c8a4a90f903c4f477ebff15.tar.xz |
- Choose the correct MainView in ZoomBar::updateSlider()
It fixes issue for the first tab of new windows in case of a "wheel" zoom.
- Move the zoom bounding logic from WebView::wheelEvent() to ZoomBar::setValue()
It'll avoid Ctrl -/+ to exceed the max value of the slider
- Use the round() method instead of my previous hack to compute zoom ratio for wheel events
Diffstat (limited to 'src/zoombar.cpp')
-rw-r--r-- | src/zoombar.cpp | 26 |
1 files changed, 20 insertions, 6 deletions
diff --git a/src/zoombar.cpp b/src/zoombar.cpp index 292ef413..2cf30617 100644 --- a/src/zoombar.cpp +++ b/src/zoombar.cpp @@ -159,8 +159,10 @@ void ZoomBar::zoomNormal() void ZoomBar::updateSlider(int webview) { WebTab *tab = 0; - if (!rApp->mainWindowList().isEmpty()) - tab = rApp->mainWindow()->mainView()->webTab(webview); + MainView *mainView = static_cast<MainView *>(sender()); + + if (mainView) + tab = mainView->webTab(webview); if (!tab) return; @@ -172,12 +174,24 @@ void ZoomBar::updateSlider(int webview) void ZoomBar::setValue(int value) { - m_zoomSlider->setValue(value); - m_percentage->setText(i18nc("percentage of the website zoom", "%1%", QString::number(value * 10))); + int boundedValue = value; + + // Don't exceed the slider min/max value + if (value < 1) + { + boundedValue = 1; + } + else if (value > 19) + { + boundedValue = 19; + } + + m_zoomSlider->setValue(boundedValue); + m_percentage->setText(i18nc("percentage of the website zoom", "%1%", QString::number(boundedValue * 10))); WebTab *tab = rApp->mainWindow()->currentTab(); - saveZoomValue(tab->url().host(), value); - tab->view()->setZoomFactor(QVariant(value).toReal() / 10); // Don't allox max +1 values + saveZoomValue(tab->url().host(), boundedValue); + tab->view()->setZoomFactor(QVariant(boundedValue).toReal() / 10); // Don't allox max +1 values } |