summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorGabriel de Dietrich <gabriel.dietrich-de@nokia.com>2012-10-19 16:35:54 +0200
committerThe Qt Project <gerrit-noreply@qt-project.org>2012-10-19 17:53:26 +0200
commitc4ff5c53efc213d9ce4fe0cfe9ab3d6c13cd8716 (patch)
tree233a9687e4559a9e95a0cc354c2525c99201ec7d /src
parent4c41cb48d0356a28190c300fd4cc5e03f824b870 (diff)
Mac: Adapt scrollbar fadeout animation for QStyleAnimation
Change-Id: I39f1089e8d6ba1bb412d33aa4ebc0971aba52681 Reviewed-by: Jens Bache-Wiig <jens.bache-wiig@digia.com>
Diffstat (limited to 'src')
-rw-r--r--src/widgets/styles/qmacstyle_mac.mm9
-rw-r--r--src/widgets/styles/qmacstyle_mac_p.h4
2 files changed, 11 insertions, 2 deletions
diff --git a/src/widgets/styles/qmacstyle_mac.mm b/src/widgets/styles/qmacstyle_mac.mm
index 38f4dc3abc..2b6f271a40 100644
--- a/src/widgets/styles/qmacstyle_mac.mm
+++ b/src/widgets/styles/qmacstyle_mac.mm
@@ -1739,7 +1739,6 @@ bool QMacStylePrivate::addWidget(QWidget *w)
bool isScrollBar = (qobject_cast<QScrollBar *>(w));
if (isScrollBar) {
w->installEventFilter(q);
- startAnimate(AquaScrollBar, w);
return true;
}
}
@@ -5106,6 +5105,14 @@ void QMacStyle::drawComplexControl(ComplexControl cc, const QStyleOptionComplex
QMacStylePrivate::ScrollBarFadeOutDuration);
info.cleared = opacity <= 0.0;
+ if (info.animating && info.cleared) {
+ d->stopAnimation(slider->styleObject);
+ info.animating = false;
+ } else if (!info.animating && !info.cleared) {
+ d->startAnimation(new QStyleAnimation(slider->styleObject));
+ info.animating = true;
+ }
+
CGContextBeginTransparencyLayerWithRect(cg, qt_hirectForQRect(slider->rect), NULL);
CGContextSetAlpha(cg, opacity);
diff --git a/src/widgets/styles/qmacstyle_mac_p.h b/src/widgets/styles/qmacstyle_mac_p.h
index 812c79e158..66691c63f7 100644
--- a/src/widgets/styles/qmacstyle_mac_p.h
+++ b/src/widgets/styles/qmacstyle_mac_p.h
@@ -211,7 +211,8 @@ public:
lastUpdate(QDateTime::currentMSecsSinceEpoch()),
hovered(false),
lastHovered(0),
- cleared(false)
+ cleared(false),
+ animating(false)
{}
int lastValue;
int lastMinimum;
@@ -221,6 +222,7 @@ public:
bool hovered;
qint64 lastHovered;
bool cleared;
+ bool animating;
};
mutable QMap<const QWidget*, OverlayScrollBarInfo> scrollBarInfos;