summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLeonardo Sobral Cunha <leo.cunha@nokia.com>2010-02-11 20:08:02 (GMT)
committerLeonardo Sobral Cunha <leo.cunha@nokia.com>2010-02-11 22:48:57 (GMT)
commit5624c360505a11b9380d2d1e47b2b3477ccc229c (patch)
treece5a88b4f678a367cc3ca9aa89ef0e9da4bf6710
parentc3996d0dc64b0815968a86d44866d9fe45de731b (diff)
downloadQt-5624c360505a11b9380d2d1e47b2b3477ccc229c.zip
Qt-5624c360505a11b9380d2d1e47b2b3477ccc229c.tar.gz
Qt-5624c360505a11b9380d2d1e47b2b3477ccc229c.tar.bz2
Animations are running by default when used as property source value
When you assign an animation to a property (used as source value), the animation will automatically start running, which is the most common behavior for this use case. Reviewed-by: Michael Brasser
-rw-r--r--src/declarative/util/qmlanimation.cpp10
-rw-r--r--src/declarative/util/qmlanimation_p_p.h3
-rw-r--r--tests/auto/declarative/animations/data/valuesource.qml14
-rw-r--r--tests/auto/declarative/animations/data/valuesource2.qml14
-rw-r--r--tests/auto/declarative/animations/tst_animations.cpp30
5 files changed, 69 insertions, 2 deletions
diff --git a/src/declarative/util/qmlanimation.cpp b/src/declarative/util/qmlanimation.cpp
index ba096b3..abffefe 100644
--- a/src/declarative/util/qmlanimation.cpp
+++ b/src/declarative/util/qmlanimation.cpp
@@ -201,7 +201,8 @@ QmlAbstractAnimation::QmlAbstractAnimation(QmlAbstractAnimationPrivate &dd, QObj
Animations can also be started and stopped imperatively from JavaScript
using the \c start() and \c stop() methods.
- By default, animations are not running.
+ By default, animations are not running. Though, when the animations are assigned to properties,
+ as property value sources, they are set to running by default.
*/
bool QmlAbstractAnimation::isRunning() const
{
@@ -237,6 +238,10 @@ QmlMetaProperty QmlAbstractAnimationPrivate::createProperty(QObject *obj, const
void QmlAbstractAnimation::setRunning(bool r)
{
Q_D(QmlAbstractAnimation);
+
+ if (r == false)
+ d->avoidPropertyValueSourceStart = true;
+
if (d->running == r)
return;
@@ -531,6 +536,9 @@ void QmlAbstractAnimation::setTarget(const QmlMetaProperty &p)
Q_D(QmlAbstractAnimation);
if (d->userProperty.isNull)
d->userProperty = p;
+
+ if (!d->avoidPropertyValueSourceStart)
+ setRunning(true);
}
//prepare is called before an animation begins
diff --git a/src/declarative/util/qmlanimation_p_p.h b/src/declarative/util/qmlanimation_p_p.h
index 2f911b4..d680194 100644
--- a/src/declarative/util/qmlanimation_p_p.h
+++ b/src/declarative/util/qmlanimation_p_p.h
@@ -205,7 +205,7 @@ public:
QmlAbstractAnimationPrivate()
: running(false), paused(false), alwaysRunToEnd(false), repeat(false),
connectedTimeLine(false), componentComplete(true), startOnCompletion(false),
- group(0) {}
+ avoidPropertyValueSourceStart(false), group(0) {}
bool running:1;
bool paused:1;
@@ -215,6 +215,7 @@ public:
bool componentComplete:1;
bool startOnCompletion:1;
+ bool avoidPropertyValueSourceStart:1;
void commence();
diff --git a/tests/auto/declarative/animations/data/valuesource.qml b/tests/auto/declarative/animations/data/valuesource.qml
new file mode 100644
index 0000000..c35063d
--- /dev/null
+++ b/tests/auto/declarative/animations/data/valuesource.qml
@@ -0,0 +1,14 @@
+import Qt 4.6
+
+Rectangle {
+ width: 400
+ height: 400
+ Rectangle {
+ id: rect
+ objectName: "MyRect"
+ color: "red"
+ width: 50; height: 50
+ x: 100; y: 100
+ x: NumberAnimation { id: anim; objectName: "MyAnim"; to: 200 }
+ }
+}
diff --git a/tests/auto/declarative/animations/data/valuesource2.qml b/tests/auto/declarative/animations/data/valuesource2.qml
new file mode 100644
index 0000000..1a60542
--- /dev/null
+++ b/tests/auto/declarative/animations/data/valuesource2.qml
@@ -0,0 +1,14 @@
+import Qt 4.6
+
+Rectangle {
+ width: 400
+ height: 400
+ Rectangle {
+ id: rect
+ objectName: "MyRect"
+ color: "red"
+ width: 50; height: 50
+ x: 100; y: 100
+ x: NumberAnimation { id: anim; objectName: "MyAnim"; running: false; to: 200 }
+ }
+}
diff --git a/tests/auto/declarative/animations/tst_animations.cpp b/tests/auto/declarative/animations/tst_animations.cpp
index 5026f6f..17085af 100644
--- a/tests/auto/declarative/animations/tst_animations.cpp
+++ b/tests/auto/declarative/animations/tst_animations.cpp
@@ -68,6 +68,7 @@ private slots:
void easingStringConversion();
void invalidDuration();
void attached();
+ void propertyValueSourceDefaultStart();
};
#define QTIMED_COMPARE(lhs, rhs) do { \
@@ -576,6 +577,35 @@ void tst_animations::attached()
QVERIFY(rect);
}
+void tst_animations::propertyValueSourceDefaultStart()
+{
+ {
+ QmlEngine engine;
+
+ QmlComponent c(&engine, QUrl::fromLocalFile(SRCDIR "/data/valuesource.qml"));
+
+ QmlGraphicsRectangle *rect = qobject_cast<QmlGraphicsRectangle*>(c.create());
+ QVERIFY(rect);
+
+ QmlAbstractAnimation *myAnim = rect->findChild<QmlAbstractAnimation*>("MyAnim");
+ QVERIFY(myAnim);
+ QVERIFY(myAnim->isRunning());
+ }
+
+ {
+ QmlEngine engine;
+
+ QmlComponent c(&engine, QUrl::fromLocalFile(SRCDIR "/data/valuesource2.qml"));
+
+ QmlGraphicsRectangle *rect = qobject_cast<QmlGraphicsRectangle*>(c.create());
+ QVERIFY(rect);
+
+ QmlAbstractAnimation *myAnim = rect->findChild<QmlAbstractAnimation*>("MyAnim");
+ QVERIFY(myAnim);
+ QVERIFY(myAnim->isRunning() == false);
+ }
+}
+
QTEST_MAIN(tst_animations)
#include "tst_animations.moc"