summaryrefslogtreecommitdiff
path: root/src/zoombar.cpp
diff options
context:
space:
mode:
authorYoann Laissus <yoann.laissus@gmail.com>2012-08-16 14:59:53 +0200
committerYoann Laissus <yoann.laissus@gmail.com>2012-08-16 15:14:15 +0200
commit46152144132f5e915c8a4a90f903c4f477ebff15 (patch)
tree3c8893bbdef2fa75af5cc323741eaf8d814f8882 /src/zoombar.cpp
parentMake sure to add all MainWindow before a new tab. (diff)
downloadrekonq-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.cpp26
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
}