diff options
author | Martin Jones <martin.jones@nokia.com> | 2009-11-05 07:42:20 (GMT) |
---|---|---|
committer | Martin Jones <martin.jones@nokia.com> | 2009-11-05 07:42:20 (GMT) |
commit | 5cd33a36efdcd8ee2a50d6d362c2523b4a942529 (patch) | |
tree | 71b6fffd1720856048dff836c9fdadd82fd57a07 | |
parent | 7dc306a32b12dcd783714fbb6078e100bc52f32e (diff) | |
parent | f8423b94bbf439831577644cd07d2aa4e997396a (diff) | |
download | Qt-5cd33a36efdcd8ee2a50d6d362c2523b4a942529.zip Qt-5cd33a36efdcd8ee2a50d6d362c2523b4a942529.tar.gz Qt-5cd33a36efdcd8ee2a50d6d362c2523b4a942529.tar.bz2 |
Merge branch 'kinetic-declarativeui' of git@scm.dev.nokia.troll.no:qt/kinetic into kinetic-declarativeui
15 files changed, 1253 insertions, 27 deletions
diff --git a/demos/declarative/calculator/calculator.qml b/demos/declarative/calculator/calculator.qml index 18ee5b9..54af7ad 100644 --- a/demos/declarative/calculator/calculator.qml +++ b/demos/declarative/calculator/calculator.qml @@ -45,7 +45,7 @@ Rectangle { } Item { - width: 320 + width: 320; height: 160 Item { id: basicButtons @@ -106,23 +106,19 @@ Rectangle { } } - states: [ - State { - name: "Advanced"; when: advancedCheckBox.toggled == true - PropertyChanges { target: basicButtons; x: 0 } - PropertyChanges { target: simpleOperations; y: 32 } - PropertyChanges { target: bksp; opacity: 1 } - PropertyChanges { target: c; x: 69; width: 67 } - PropertyChanges { target: ac; x: 138; width: 67 } - PropertyChanges { target: equals; width: 50 } - PropertyChanges { target: advancedButtons; x: 210; opacity: 1 } - } - ] + states: State { + name: "Advanced"; when: advancedCheckBox.toggled == true + PropertyChanges { target: basicButtons; x: 0 } + PropertyChanges { target: simpleOperations; y: 32 } + PropertyChanges { target: bksp; opacity: 1 } + PropertyChanges { target: c; x: 69; width: 67 } + PropertyChanges { target: ac; x: 138; width: 67 } + PropertyChanges { target: equals; width: 50 } + PropertyChanges { target: advancedButtons; x: 210; opacity: 1 } + } - transitions: [ - Transition { - NumberAnimation { properties: "x,y,width"; easing: "easeOutBounce"; duration: 500 } - NumberAnimation { properties: "opacity"; easing: "easeInOutQuad"; duration: 500 } - } - ] + transitions: Transition { + NumberAnimation { properties: "x,y,width"; easing: "easeOutBounce"; duration: 500 } + NumberAnimation { properties: "opacity"; easing: "easeInOutQuad"; duration: 500 } + } } diff --git a/src/declarative/graphicsitems/qmlgraphicspositioners.cpp b/src/declarative/graphicsitems/qmlgraphicspositioners.cpp index d6f1fb9..3b975ba 100644 --- a/src/declarative/graphicsitems/qmlgraphicspositioners.cpp +++ b/src/declarative/graphicsitems/qmlgraphicspositioners.cpp @@ -209,7 +209,12 @@ void QmlGraphicsBasePositioner::prePositioning() QCoreApplication::postEvent(this, new QEvent(QEvent::User)); } QSet<QmlGraphicsItem *> allItems; + //Need to order children by creation order modified by stacking order + //###can we avoid using the QGraphicsItemPrivate? QList<QGraphicsItem *> children = childItems(); + qSort(children.begin(), children.end(), d->insertionOrder); + positionedItems = QList<QmlGraphicsItem*>(); + for (int ii = 0; ii < children.count(); ++ii) { QmlGraphicsItem *child = qobject_cast<QmlGraphicsItem *>(children.at(ii)); if (!child) @@ -234,6 +239,7 @@ void QmlGraphicsBasePositioner::prePositioning() d->_newItems+=child; } allItems += child; + positionedItems << child; } QSet<QmlGraphicsItem *> deletedItems = d->_items - allItems; foreach(QmlGraphicsItem *child, d->_items){ @@ -497,9 +503,9 @@ void QmlGraphicsColumn::doPositioning() } } - QList<QGraphicsItem *> children = childItems(); + QList<QmlGraphicsItem *> children = positionedItems; for (int ii = 0; ii < children.count(); ++ii) { - QmlGraphicsItem *child = qobject_cast<QmlGraphicsItem *>(children.at(ii)); + QmlGraphicsItem *child = children.at(ii); if (!child || isInvisible(child)) continue; @@ -653,9 +659,9 @@ void QmlGraphicsRow::doPositioning() applyRemove(changes, item); } } - QList<QGraphicsItem *> children = childItems(); + QList<QmlGraphicsItem *> children = positionedItems; for (int ii = 0; ii < children.count(); ++ii) { - QmlGraphicsItem *child = qobject_cast<QmlGraphicsItem *>(children.at(ii)); + QmlGraphicsItem *child = children.at(ii); if (!child || isInvisible(child)) continue; @@ -859,7 +865,7 @@ void QmlGraphicsGrid::doPositioning() QList<int> maxColWidth; QList<int> maxRowHeight; int childIndex =0; - QList<QGraphicsItem *> children = childItems(); + QList<QmlGraphicsItem *> children = positionedItems; for (int i=0; i<r; i++){ for (int j=0; j<c; j++){ if (j==0) @@ -869,7 +875,7 @@ void QmlGraphicsGrid::doPositioning() if (childIndex == children.count()) continue; - QmlGraphicsItem *child = qobject_cast<QmlGraphicsItem *>(children.at(childIndex++)); + QmlGraphicsItem *child = children.at(childIndex++); if (!child || isInvisible(child)) continue; if (child->width() > maxColWidth[j]) @@ -889,8 +895,7 @@ void QmlGraphicsGrid::doPositioning() applyRemove(changes, item); } } - foreach(QGraphicsItem* schild, children){ - QmlGraphicsItem *child = qobject_cast<QmlGraphicsItem *>(schild); + foreach(QmlGraphicsItem* child, children){ if (!child || isInvisible(child)) continue; bool needMove = (child->x()!=xoffset)||(child->y()!=yoffset); diff --git a/src/declarative/graphicsitems/qmlgraphicspositioners_p.h b/src/declarative/graphicsitems/qmlgraphicspositioners_p.h index 0011ec5..56adc8b 100644 --- a/src/declarative/graphicsitems/qmlgraphicspositioners_p.h +++ b/src/declarative/graphicsitems/qmlgraphicspositioners_p.h @@ -104,6 +104,7 @@ private Q_SLOTS: protected: QmlGraphicsBasePositioner(QmlGraphicsBasePositionerPrivate &dd, AutoUpdateType at, QmlGraphicsItem *parent); void setMovingItem(QmlGraphicsItem *); + QList<QmlGraphicsItem *> positionedItems; private: void applyTransition(const QList<QPair<QString, QVariant> >& changes, QmlGraphicsItem* target, diff --git a/src/declarative/qml/qmlengine.cpp b/src/declarative/qml/qmlengine.cpp index 3df04b2..e46205d 100644 --- a/src/declarative/qml/qmlengine.cpp +++ b/src/declarative/qml/qmlengine.cpp @@ -626,6 +626,11 @@ QScriptValue QmlEnginePrivate::createQmlObject(QScriptContext *ctxt, QScriptEngi url = QUrl(ctxt->argument(2).toString()); QObject *parentArg = activeEnginePriv->objectClass->toQObject(ctxt->argument(1)); QmlContext *qmlCtxt = qmlContext(parentArg); + if(!parentArg || !qmlCtxt){ + //TODO: Could use a qmlInfo() like function for script functions + qWarning() << "createQmlObject called with invalid parent object"; + return engine->nullValue(); + } if (url.isEmpty()) { url = qmlCtxt->resolvedUrl(QUrl(QLatin1String("<Unknown File>"))); } else { diff --git a/tests/auto/declarative/layouts/data/grid-animated.qml b/tests/auto/declarative/layouts/data/grid-animated.qml new file mode 100644 index 0000000..9edccaf --- /dev/null +++ b/tests/auto/declarative/layouts/data/grid-animated.qml @@ -0,0 +1,55 @@ +import Qt 4.6 + +Item { + width: 640 + height: 480 + Grid { + columns: 3 + add: Transition { + NumberAnimation { + properties: "x,y"; from: -100 + } + } + remove: Transition { + NumberAnimation { + properties: "x,y"; to: -100 + } + } + move: Transition { + NumberAnimation { + properties: "x,y"; + } + } + Rectangle { + objectName: "one" + color: "red" + width: 50 + height: 50 + } + Rectangle { + objectName: "two" + opacity: 0 + color: "green" + width: 50 + height: 50 + } + Rectangle { + objectName: "three" + color: "blue" + width: 50 + height: 50 + } + Rectangle { + objectName: "four" + color: "cyan" + width: 50 + height: 50 + } + Rectangle { + objectName: "five" + color: "magenta" + width: 50 + height: 50 + } + } +} diff --git a/tests/auto/declarative/layouts/data/horizontal-animated.qml b/tests/auto/declarative/layouts/data/horizontal-animated.qml new file mode 100644 index 0000000..f757d18 --- /dev/null +++ b/tests/auto/declarative/layouts/data/horizontal-animated.qml @@ -0,0 +1,42 @@ +import Qt 4.6 + +Item { + width: 640 + height: 480 + Row { + add: Transition { + NumberAnimation { + properties: "x"; from: -100 + } + } + remove: Transition { + NumberAnimation { + properties: "x"; to: -100 + } + } + move: Transition { + NumberAnimation { + properties: "x"; + } + } + Rectangle { + objectName: "one" + color: "red" + width: 50 + height: 50 + } + Rectangle { + objectName: "two" + color: "blue" + opacity: 0 + width: 50 + height: 50 + } + Rectangle { + objectName: "three" + color: "red" + width: 50 + height: 50 + } + } +} diff --git a/tests/auto/declarative/layouts/data/repeater.qml b/tests/auto/declarative/layouts/data/repeater.qml new file mode 100644 index 0000000..2bc5e94 --- /dev/null +++ b/tests/auto/declarative/layouts/data/repeater.qml @@ -0,0 +1,20 @@ +import Qt 4.6 + +Item { + width: 640 + height: 480 + Row { + Repeater{ model: 3; + delegate: Component { + Rectangle { + color: "red" + width: 50 + height: 50 + z: {if(index == 0){2;}else if(index == 1){1;} else{3;}} + objectName: {if(index == 0){"one";}else if(index == 1){"two";} else{"three";}} + + } + } + } + } +} diff --git a/tests/auto/declarative/layouts/data/vertical-animated.qml b/tests/auto/declarative/layouts/data/vertical-animated.qml new file mode 100644 index 0000000..f52a78a --- /dev/null +++ b/tests/auto/declarative/layouts/data/vertical-animated.qml @@ -0,0 +1,42 @@ +import Qt 4.6 + +Item { + width: 640 + height: 480 + Column { + add: Transition { + NumberAnimation { + properties: "y"; from: -100 + } + } + remove: Transition { + NumberAnimation { + properties: "y"; to: -100 + } + } + move: Transition { + NumberAnimation { + properties: "y"; + } + } + Rectangle { + objectName: "one" + color: "red" + width: 50 + height: 50 + } + Rectangle { + objectName: "two" + color: "blue" + opacity: 0 + width: 50 + height: 50 + } + Rectangle { + objectName: "three" + color: "red" + width: 50 + height: 50 + } + } +} diff --git a/tests/auto/declarative/layouts/tst_layouts.cpp b/tests/auto/declarative/layouts/tst_layouts.cpp index b0df57ea..c0c067a 100644 --- a/tests/auto/declarative/layouts/tst_layouts.cpp +++ b/tests/auto/declarative/layouts/tst_layouts.cpp @@ -53,11 +53,15 @@ public: private slots: void test_horizontal(); void test_horizontal_spacing(); + void test_horizontal_animated(); void test_vertical(); void test_vertical_spacing(); + void test_vertical_animated(); void test_grid(); void test_grid_spacing(); + void test_grid_animated(); + void test_repeater(); private: QmlView *createView(const QString &filename); }; @@ -114,6 +118,57 @@ void tst_QmlGraphicsLayouts::test_horizontal_spacing() QCOMPARE(three->y(), 0.0); } +void tst_QmlGraphicsLayouts::test_horizontal_animated() +{ + QmlView *canvas = createView(SRCDIR "/data/horizontal-animated.qml"); + + canvas->execute(); + qApp->processEvents(); + + QTest::qWait(0);//Let the animation start + //Note that one and three animate in + QmlGraphicsRectangle *one = canvas->root()->findChild<QmlGraphicsRectangle*>("one"); + QVERIFY(one != 0); + QCOMPARE(one->x(), -100.0); + + QmlGraphicsRectangle *two = canvas->root()->findChild<QmlGraphicsRectangle*>("two"); + QVERIFY(two != 0); + QCOMPARE(two->x(), 0.0); + + QmlGraphicsRectangle *three = canvas->root()->findChild<QmlGraphicsRectangle*>("three"); + QVERIFY(three != 0); + QCOMPARE(three->x(), -100.0); + + QTest::qWait(300);//Let the animation complete + + QCOMPARE(one->x(), 0.0); + QCOMPARE(one->y(), 0.0); + QCOMPARE(two->opacity(), 0.0); + QCOMPARE(two->x(), 0.0); + QCOMPARE(two->y(), 0.0); + QCOMPARE(three->x(), 50.0); + QCOMPARE(three->y(), 0.0); + + //Add 'two' + two->setOpacity(1.0); + QCOMPARE(two->opacity(), 1.0); + QTest::qWait(0);//Let the animation start + QCOMPARE(two->x(), -100.0); + QCOMPARE(three->x(), 50.0); + QTest::qWait(300);//Let the animation complete + QCOMPARE(two->x(), 50.0); + QCOMPARE(three->x(), 100.0); + + //Remove 'two' + two->setOpacity(0.0); + QCOMPARE(two->opacity(), 0.0); + QCOMPARE(two->x(), 50.0); + QCOMPARE(three->x(), 100.0); + QTest::qWait(300);//Let the animation complete + QCOMPARE(two->x(), 50.0); + QCOMPARE(three->x(), 50.0); +} + void tst_QmlGraphicsLayouts::test_vertical() { QmlView *canvas = createView(SRCDIR "/data/vertical.qml"); @@ -162,6 +217,57 @@ void tst_QmlGraphicsLayouts::test_vertical_spacing() QCOMPARE(three->y(), 80.0); } +void tst_QmlGraphicsLayouts::test_vertical_animated() +{ + QmlView *canvas = createView(SRCDIR "/data/vertical-animated.qml"); + + canvas->execute(); + qApp->processEvents(); + + QTest::qWait(0);//Let the animation start + //Note that one and three animate in + QmlGraphicsRectangle *one = canvas->root()->findChild<QmlGraphicsRectangle*>("one"); + QVERIFY(one != 0); + QCOMPARE(one->y(), -100.0); + + QmlGraphicsRectangle *two = canvas->root()->findChild<QmlGraphicsRectangle*>("two"); + QVERIFY(two != 0); + QCOMPARE(two->y(), 0.0); + + QmlGraphicsRectangle *three = canvas->root()->findChild<QmlGraphicsRectangle*>("three"); + QVERIFY(three != 0); + QCOMPARE(three->y(), -100.0); + + QTest::qWait(300);//Let the animation complete + + QCOMPARE(one->y(), 0.0); + QCOMPARE(one->x(), 0.0); + QCOMPARE(two->opacity(), 0.0); + QCOMPARE(two->y(), 0.0); + QCOMPARE(two->x(), 0.0); + QCOMPARE(three->y(), 50.0); + QCOMPARE(three->x(), 0.0); + + //Add 'two' + two->setOpacity(1.0); + QCOMPARE(two->opacity(), 1.0); + QTest::qWait(0);//Let the animation start + QCOMPARE(two->y(), -100.0); + QCOMPARE(three->y(), 50.0); + QTest::qWait(300);//Let the animation complete + QCOMPARE(two->y(), 50.0); + QCOMPARE(three->y(), 100.0); + + //Remove 'two' + two->setOpacity(0.0); + QCOMPARE(two->opacity(), 0.0); + QCOMPARE(two->y(), 50.0); + QCOMPARE(three->y(), 100.0); + QTest::qWait(300);//Let the animation complete + QCOMPARE(two->y(), 50.0); + QCOMPARE(three->y(), 50.0); +} + void tst_QmlGraphicsLayouts::test_grid() { QmlView *canvas = createView("data/grid.qml"); @@ -222,6 +328,129 @@ void tst_QmlGraphicsLayouts::test_grid_spacing() QCOMPARE(five->y(), 54.0); } +void tst_QmlGraphicsLayouts::test_grid_animated() +{ + QmlView *canvas = createView(SRCDIR "/data/grid-animated.qml"); + canvas->execute(); + qApp->processEvents(); + + QTest::qWait(0);//Let the animation start + //Note that all but two animate in + QmlGraphicsRectangle *one = canvas->root()->findChild<QmlGraphicsRectangle*>("one"); + QVERIFY(one != 0); + QCOMPARE(one->x(), -100.0); + QCOMPARE(one->y(), -100.0); + + QmlGraphicsRectangle *two = canvas->root()->findChild<QmlGraphicsRectangle*>("two"); + QVERIFY(two != 0); + QCOMPARE(two->x(), 0.0); + QCOMPARE(two->y(), 0.0); + + QmlGraphicsRectangle *three = canvas->root()->findChild<QmlGraphicsRectangle*>("three"); + QVERIFY(three != 0); + QCOMPARE(three->x(), -100.0); + QCOMPARE(three->y(), -100.0); + + QmlGraphicsRectangle *four = canvas->root()->findChild<QmlGraphicsRectangle*>("four"); + QVERIFY(four != 0); + QCOMPARE(four->x(), -100.0); + QCOMPARE(four->y(), -100.0); + + QmlGraphicsRectangle *five = canvas->root()->findChild<QmlGraphicsRectangle*>("five"); + QVERIFY(five != 0); + QCOMPARE(five->x(), -100.0); + QCOMPARE(five->y(), -100.0); + + QTest::qWait(300);//Let the animation complete + + QCOMPARE(one->y(), 0.0); + QCOMPARE(one->x(), 0.0); + QCOMPARE(two->opacity(), 0.0); + QCOMPARE(two->y(), 0.0); + QCOMPARE(two->x(), 0.0); + QCOMPARE(three->y(), 0.0); + QCOMPARE(three->x(), 50.0); + QCOMPARE(four->y(), 0.0); + QCOMPARE(four->x(), 100.0); + QCOMPARE(five->y(), 50.0); + QCOMPARE(five->x(), 0.0); + + //Add 'two' + two->setOpacity(1.0); + QCOMPARE(two->opacity(), 1.0); + QTest::qWait(0);//Let the animation start + QCOMPARE(two->x(), -100.0); + QCOMPARE(two->y(), -100.0); + QCOMPARE(one->x(), 0.0); + QCOMPARE(one->y(), 0.0); + QCOMPARE(three->x(), 50.0); + QCOMPARE(three->y(), 0.0); + QCOMPARE(four->x(), 100.0); + QCOMPARE(four->y(), 0.0); + QCOMPARE(five->x(), 0.0); + QCOMPARE(five->y(), 50.0); + QTest::qWait(300);//Let the animation complete + QCOMPARE(two->x(), 50.0); + QCOMPARE(two->y(), 0.0); + QCOMPARE(one->x(), 0.0); + QCOMPARE(one->y(), 0.0); + QCOMPARE(three->x(), 100.0); + QCOMPARE(three->y(), 0.0); + QCOMPARE(four->x(), 0.0); + QCOMPARE(four->y(), 50.0); + QCOMPARE(five->x(), 50.0); + QCOMPARE(five->y(), 50.0); + + //Remove 'two' + two->setOpacity(0.0); + QCOMPARE(two->opacity(), 0.0); + QCOMPARE(two->x(), 50.0); + QCOMPARE(two->y(), 0.0); + QCOMPARE(one->x(), 0.0); + QCOMPARE(one->y(), 0.0); + QCOMPARE(three->x(), 100.0); + QCOMPARE(three->y(), 0.0); + QCOMPARE(four->x(), 0.0); + QCOMPARE(four->y(), 50.0); + QCOMPARE(five->x(), 50.0); + QCOMPARE(five->y(), 50.0); + QTest::qWait(300);//Let the animation complete + QCOMPARE(two->x(), 50.0); + QCOMPARE(two->y(), 0.0); + QCOMPARE(one->x(), 0.0); + QCOMPARE(one->y(), 0.0); + QCOMPARE(three->x(), 50.0); + QCOMPARE(three->y(), 0.0); + QCOMPARE(four->x(), 100.0); + QCOMPARE(four->y(), 0.0); + QCOMPARE(five->x(), 0.0); + QCOMPARE(five->y(), 50.0); +} + +void tst_QmlGraphicsLayouts::test_repeater() +{ + QmlView *canvas = createView("data/repeater.qml"); + + canvas->execute(); + qApp->processEvents(); + + QmlGraphicsRectangle *one = canvas->root()->findChild<QmlGraphicsRectangle*>("one"); + QVERIFY(one != 0); + + QmlGraphicsRectangle *two = canvas->root()->findChild<QmlGraphicsRectangle*>("two"); + QVERIFY(two != 0); + + QmlGraphicsRectangle *three = canvas->root()->findChild<QmlGraphicsRectangle*>("three"); + QVERIFY(three != 0); + + QCOMPARE(one->x(), 0.0); + QCOMPARE(one->y(), 0.0); + QCOMPARE(two->x(), 50.0); + QCOMPARE(two->y(), 0.0); + QCOMPARE(three->x(), 100.0); + QCOMPARE(three->y(), 0.0); +} + QmlView *tst_QmlGraphicsLayouts::createView(const QString &filename) { QmlView *canvas = new QmlView(0); diff --git a/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.0.png b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.0.png Binary files differnew file mode 100644 index 0000000..30bdefd --- /dev/null +++ b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.0.png diff --git a/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.1.png b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.1.png Binary files differnew file mode 100644 index 0000000..799e028 --- /dev/null +++ b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.1.png diff --git a/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.2.png b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.2.png Binary files differnew file mode 100644 index 0000000..ed267c2 --- /dev/null +++ b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.2.png diff --git a/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.qml b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.qml new file mode 100644 index 0000000..3199f31 --- /dev/null +++ b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.qml @@ -0,0 +1,783 @@ +import Qt.VisualTest 4.6 + +VisualTest { + Frame { + msec: 0 + } + Frame { + msec: 16 + hash: "b4df49cbd7cf972af9879399808f6c53" + } + Frame { + msec: 32 + hash: "1c129b1c4a39412bed2f23d712f2bc90" + } + Frame { + msec: 48 + hash: "fbcc4bc3fea46a43453aa39b032264c6" + } + Frame { + msec: 64 + hash: "2cb13275faca414b7c8ba9d70067fd1f" + } + Frame { + msec: 80 + hash: "b017afb05f96085ee3395d62e62e457b" + } + Frame { + msec: 96 + hash: "642851d10c549c8ae72c057563e99e64" + } + Frame { + msec: 112 + hash: "494c0942f7410d455a4b113fb908e570" + } + Frame { + msec: 128 + hash: "cb0a2f9980f27757c0c1d62ef3dcfde0" + } + Frame { + msec: 144 + hash: "2fb9cf782ea106006af8bcd66c62869c" + } + Frame { + msec: 160 + hash: "bf68518323f03e4f407831e8b34f247b" + } + Frame { + msec: 176 + hash: "c99abe9c0384ae339fdfa0c75dc8047d" + } + Frame { + msec: 192 + hash: "96f2eb402633c1aca8a1a2b0d60af5fb" + } + Frame { + msec: 208 + hash: "6cba51a856f1ba54ee702761f196b915" + } + Frame { + msec: 224 + hash: "9188926caa6c6ba8cb3aee04de635b96" + } + Frame { + msec: 240 + hash: "81132a5e8768de0630311813170f166e" + } + Frame { + msec: 256 + hash: "a638698d7ccb73f20f6eeba3857f417c" + } + Frame { + msec: 272 + hash: "4761ba6847f6f0769b916106c5f3245b" + } + Frame { + msec: 288 + hash: "13bc0c681962bada7fcb3b722895ffaa" + } + Frame { + msec: 304 + hash: "505c5824be16d812b7c339f1f9b8a10b" + } + Frame { + msec: 320 + hash: "d191d502d9c685f8497583669147ee73" + } + Frame { + msec: 336 + hash: "c17f55cc5d7bf541e235791a157aa8b9" + } + Frame { + msec: 352 + hash: "3ef401f87830c53b9b277d4420a9a742" + } + Frame { + msec: 368 + hash: "d04816400e66ebbf797f9985a53f7cfb" + } + Frame { + msec: 384 + hash: "d7a7df7c2a92449f42d61c0572e7dbac" + } + Frame { + msec: 400 + hash: "f49a3bcf3842f554136ff9bd5bb470ef" + } + Frame { + msec: 416 + hash: "27bccc5933d7bfaad6d5f6a10efd283b" + } + Frame { + msec: 432 + hash: "3067ac00a4d58c67bb96d813c344871d" + } + Frame { + msec: 448 + hash: "d38d7192688feecc38fd63285d37ce49" + } + Frame { + msec: 464 + hash: "4172d1b74cdd6ea89be718977775a9e0" + } + Frame { + msec: 480 + hash: "2761a7e58cbfa46fc6d306c8270e4f10" + } + Frame { + msec: 496 + hash: "58a851b9fbcb98afc7c1bc58c2f45e4a" + } + Frame { + msec: 512 + hash: "0f7789f04bf20708d9d6f1e818b6b88a" + } + Frame { + msec: 528 + hash: "8d8b8d109dce4c7b05ecb603b4718859" + } + Frame { + msec: 544 + hash: "0fc6fde589932ac41787e8ebfe3fcbe3" + } + Frame { + msec: 560 + hash: "e08bffd5a56795488f090a475513e5db" + } + Frame { + msec: 576 + hash: "e089ab7c5feefd3d745bb665e2ff49ee" + } + Frame { + msec: 592 + hash: "e7b787fb1b21e991c19ec88b3d985b69" + } + Frame { + msec: 608 + hash: "a6f4f32287bd926e0eeff68717b80512" + } + Frame { + msec: 624 + hash: "3344ca9c97473bd922bd8efd5d6ab212" + } + Frame { + msec: 640 + hash: "a330510a9f62acb4f2163728939d0bb5" + } + Frame { + msec: 656 + hash: "1ec473936f2279f13675b6b5fe2ee392" + } + Frame { + msec: 672 + hash: "b193b7d2917ee00c4cb29bf244186bef" + } + Frame { + msec: 688 + hash: "75137e977941e357bad2ad9af2cbc898" + } + Frame { + msec: 704 + hash: "31773ba8979a31b1691860b7dafe28dc" + } + Frame { + msec: 720 + hash: "d8922452edbba4f1092b83e87c0330ea" + } + Frame { + msec: 736 + hash: "982c80305b54236d1259f5672098652d" + } + Frame { + msec: 752 + hash: "d8b23fb0867fb75558960216c8d0f2aa" + } + Frame { + msec: 768 + hash: "daf7833f93a216d1e025c9129b3a7caa" + } + Frame { + msec: 784 + hash: "bb08e8fe2ce74018fc702e5dad8927fe" + } + Frame { + msec: 800 + hash: "22a30051c87d4de7e734d9de6ce7eed8" + } + Frame { + msec: 816 + hash: "d8625628587feace367fc97c1f11aff8" + } + Frame { + msec: 832 + hash: "e9dbbf715fc094cb22ecd5c6df602f95" + } + Frame { + msec: 848 + hash: "ca69b2b9f8e6b16e3bc6d93598b6c75a" + } + Frame { + msec: 864 + hash: "87e09752e39df5042aef163fe4ed0b47" + } + Frame { + msec: 880 + hash: "80adfaf02838c8bd372e53d0483fbac5" + } + Frame { + msec: 896 + hash: "9934a1aece14ba7369b00cf2620cd207" + } + Frame { + msec: 912 + hash: "954a70a949fdcca4e4412174f30653c3" + } + Frame { + msec: 928 + hash: "850fa936516f8b145465eac39c9a74a6" + } + Frame { + msec: 944 + hash: "1d844e8a7c710ccbf31f47470cc9abf2" + } + Frame { + msec: 960 + image: "particles.0.png" + } + Frame { + msec: 976 + hash: "33f4eee3f6e3fb715463254d727ef898" + } + Frame { + msec: 992 + hash: "68648a3f75f58b34dd9770a9edc2caea" + } + Frame { + msec: 1008 + hash: "ad0d431ab7e6cfbb43053050a1cf5e40" + } + Frame { + msec: 1024 + hash: "d1ae74c9bf3826d30fb461ca2fd8e36a" + } + Frame { + msec: 1040 + hash: "bda9d77c68a30d491abdfbfcf854c5ea" + } + Frame { + msec: 1056 + hash: "386ea303f8102339f8cd5ae88fd5f6bc" + } + Frame { + msec: 1072 + hash: "8c81d3992851ebeb3cb820bc4510af66" + } + Frame { + msec: 1088 + hash: "566813e312ffdde4a7d3af4276bc8cdd" + } + Frame { + msec: 1104 + hash: "d9c8b391b12ee40aa393f4fb39c12a16" + } + Frame { + msec: 1120 + hash: "f2bf70bda626089437f0ab67ad62d8f6" + } + Frame { + msec: 1136 + hash: "88b2d1ecd7d51d0bf8c947a3433b7013" + } + Frame { + msec: 1152 + hash: "e93e0553c5dcc6dcd21dad0932d1e3fa" + } + Frame { + msec: 1168 + hash: "c1ec148772d399ea4934cdfc514f6980" + } + Frame { + msec: 1184 + hash: "14f286793de5452f4677e8b6fd5c1e7e" + } + Frame { + msec: 1200 + hash: "220a7df0af53fc9a2442956128091ad8" + } + Frame { + msec: 1216 + hash: "84c49512f5e9f138901b3833a5adbcab" + } + Frame { + msec: 1232 + hash: "b05410caa120f5a4191a44b84aa17a8c" + } + Frame { + msec: 1248 + hash: "e1f6db204f62394205c1d4d56bbf9f52" + } + Frame { + msec: 1264 + hash: "f45033d1350009e09f62e81aeec297a5" + } + Frame { + msec: 1280 + hash: "dfd88b1dba38ab8260e00b3810b89318" + } + Frame { + msec: 1296 + hash: "17503276f68e365cde03607d66fe4c8e" + } + Frame { + msec: 1312 + hash: "28f03c5c0fe5c4647c5b9d3b72a07c76" + } + Frame { + msec: 1328 + hash: "ea2082529b50543fab22497e01938102" + } + Frame { + msec: 1344 + hash: "a700a2f3721625b1ec68107884d1ce67" + } + Frame { + msec: 1360 + hash: "ce717f1f1d98158aeef1cc6a9485dc80" + } + Frame { + msec: 1376 + hash: "7febe7c67e1c159881de72f62800a505" + } + Frame { + msec: 1392 + hash: "474931cb44a8e18426b9c2cc9f6df482" + } + Frame { + msec: 1408 + hash: "1085b4873b9a4934882a163be72a2710" + } + Frame { + msec: 1424 + hash: "59e7911800e915e6f159cb111ce61a54" + } + Frame { + msec: 1440 + hash: "6d0d780ffc726b04f9885c25b08d1009" + } + Frame { + msec: 1456 + hash: "bf896d6403dc1ad26536cc1165e71e9e" + } + Frame { + msec: 1472 + hash: "86397c7dcf5ed34edbbaa465ae6eab43" + } + Frame { + msec: 1488 + hash: "ed1b4967bf14eead9cb4d2dcfbdb46c2" + } + Frame { + msec: 1504 + hash: "67b7e59c8f945d1f3bdb1944fa736ecf" + } + Frame { + msec: 1520 + hash: "b5f95e89f39d1c4821ba38547b0f2e3b" + } + Frame { + msec: 1536 + hash: "5bc91c9e35afa255a2dda28db9802b1e" + } + Frame { + msec: 1552 + hash: "84fab4042e0ff891ca1998cbfbb60e5a" + } + Frame { + msec: 1568 + hash: "7c5ef5025a06e990171dac3e8fd93977" + } + Frame { + msec: 1584 + hash: "ab4cd0e103d71a35250668ad850a5213" + } + Frame { + msec: 1600 + hash: "aa974c4b2290f7febb121344623de86d" + } + Frame { + msec: 1616 + hash: "ff6ee1b50ca356dc98038a459e318b32" + } + Frame { + msec: 1632 + hash: "022fe9c391514fdd98bc1c38bc383df2" + } + Frame { + msec: 1648 + hash: "b1a33c9c9cbdcc1c8c9c982eef041ccd" + } + Frame { + msec: 1664 + hash: "0945e66ab5aa81beacf662eb82ec39ed" + } + Frame { + msec: 1680 + hash: "ae293f675dbdd88dec8f924140033cc9" + } + Frame { + msec: 1696 + hash: "5ace5013e3d51a8db338f65011dd10f8" + } + Frame { + msec: 1712 + hash: "9466a4e96d647f2bd8845697fce89399" + } + Frame { + msec: 1728 + hash: "73bbbfc57e020c6a0acbd5fdfa711c30" + } + Frame { + msec: 1744 + hash: "d71d7182107c3d6b004a57a321caee96" + } + Frame { + msec: 1760 + hash: "0902867c89e536cffcde69bde2eb1994" + } + Frame { + msec: 1776 + hash: "39fc26943f6077272c36e93b7cbf6994" + } + Frame { + msec: 1792 + hash: "92931d5a6e57fb9df60785a64d3a6f78" + } + Frame { + msec: 1808 + hash: "fffd632552f88f2979ef85de0ce585c2" + } + Frame { + msec: 1824 + hash: "9f97bfcffbb5d127c5eee852b30a13c4" + } + Frame { + msec: 1840 + hash: "ea9ee0293fbc45d3467e29c09e42adcd" + } + Frame { + msec: 1856 + hash: "b5b75c50f8fae3fb3b88efad536c911b" + } + Frame { + msec: 1872 + hash: "25dcd3fa30c057d1a42c19cee1ce444b" + } + Frame { + msec: 1888 + hash: "862d42abe7abd49d4a38e38a8c33a657" + } + Frame { + msec: 1904 + hash: "a335f3c8c797c1bb5537b57f952c19d1" + } + Frame { + msec: 1920 + image: "particles.1.png" + } + Frame { + msec: 1936 + hash: "da1cf98fdfe5acbe30cfbe66389aa240" + } + Frame { + msec: 1952 + hash: "088f3209c0363c06cf0607c58d00ca2d" + } + Frame { + msec: 1968 + hash: "47ba3bf2604b21f331a2e00f05926aaf" + } + Frame { + msec: 1984 + hash: "5ff0de383abdefad76380af144bd9d80" + } + Frame { + msec: 2000 + hash: "b972d1c85d3d8777f84b54dc118172fd" + } + Frame { + msec: 2016 + hash: "37581c3fbef2088b7d14b6c7bbf3cdc3" + } + Frame { + msec: 2032 + hash: "4ad6a06ac6de9dea66e9ce873a6618c1" + } + Frame { + msec: 2048 + hash: "3a0379ad966235044508c144ffbc336b" + } + Frame { + msec: 2064 + hash: "cb5a9510400943d77c9a296066f037e2" + } + Frame { + msec: 2080 + hash: "7bd5673a1d2ad8079df2569149e5811e" + } + Frame { + msec: 2096 + hash: "bd327ff6b8a4081b3a41cb0035403037" + } + Frame { + msec: 2112 + hash: "f0f9f559251f7648cd60e66ac745962d" + } + Frame { + msec: 2128 + hash: "18827630a859b0ce497f682e33558fae" + } + Frame { + msec: 2144 + hash: "e22d8110cbe34acddba799942872645d" + } + Frame { + msec: 2160 + hash: "11564e7221524cc3655c2c5f1d7e42b6" + } + Frame { + msec: 2176 + hash: "6468721ee38209aaf2c82a320bcd122e" + } + Frame { + msec: 2192 + hash: "19772d0f422fd206645ae6cf0be30b59" + } + Frame { + msec: 2208 + hash: "48b6c7e1317b9a66238c17afceb5121f" + } + Frame { + msec: 2224 + hash: "82a1af78709b78cce2d9b4eed7f8477c" + } + Frame { + msec: 2240 + hash: "36e2366eccbdd2d16c19829c34fbff87" + } + Frame { + msec: 2256 + hash: "271db39ca46c59ddc279fb41a9d191af" + } + Frame { + msec: 2272 + hash: "ee279a90e86aa89b1c3d745ab030180d" + } + Frame { + msec: 2288 + hash: "14e8c72d770644f4cec99e65aeff0d75" + } + Frame { + msec: 2304 + hash: "56fa1756eb11a30f07f8f31c22c99973" + } + Frame { + msec: 2320 + hash: "165af677ff3921f06b89b2c8d76a7924" + } + Frame { + msec: 2336 + hash: "d64aa248d9b207b87e5ba14bdabf2f6c" + } + Frame { + msec: 2352 + hash: "33e9716eb9ca62fe5c5cb1b1ee0e9e68" + } + Frame { + msec: 2368 + hash: "cff2316820c469b84c3bacabfcf1a551" + } + Frame { + msec: 2384 + hash: "9f1359c4bab95244602254ca3954e2b7" + } + Frame { + msec: 2400 + hash: "d6246d2aaea895755eab4c839c35ca9d" + } + Frame { + msec: 2416 + hash: "d446e1ac91fec10482b0c6d38ce86d17" + } + Frame { + msec: 2432 + hash: "99f443af76a9e0d2d03638bc9927fda3" + } + Frame { + msec: 2448 + hash: "a9169e293b8154947332d9754fd23af3" + } + Frame { + msec: 2464 + hash: "cc6851cc5864615c000fbc8d552eb593" + } + Frame { + msec: 2480 + hash: "58a3a6edb5842c88cb73b79a8a187717" + } + Frame { + msec: 2496 + hash: "42bcf77c98c9a80508446bd8c66e935b" + } + Frame { + msec: 2512 + hash: "0f99350ae151591fbda95158c046e072" + } + Frame { + msec: 2528 + hash: "9e817e2fd8377b7117f908c4e87d4d57" + } + Frame { + msec: 2544 + hash: "72c105bce75feeeb7a86f823945b4ff9" + } + Frame { + msec: 2560 + hash: "653b858445bdd8afdf8abd27f5e53fb8" + } + Frame { + msec: 2576 + hash: "18bf39154fbf4b42c4d3303e018a2f27" + } + Frame { + msec: 2592 + hash: "5ed5d52ab7da7ae77e97f3ace09b3b8d" + } + Frame { + msec: 2608 + hash: "1d382462e5746ee9b6df980364b1c96b" + } + Frame { + msec: 2624 + hash: "2a0a561f38c113a0f177b1c2b99ee5e1" + } + Frame { + msec: 2640 + hash: "0605d3e2dd9132d9c1d25b75a870d647" + } + Frame { + msec: 2656 + hash: "a1def1576f386c90bb80d46e254bd384" + } + Frame { + msec: 2672 + hash: "cf38d4ae577047048d2bd0a4005abfe2" + } + Frame { + msec: 2688 + hash: "d7cb6715cd89978bbca5ce4c93b488e5" + } + Frame { + msec: 2704 + hash: "9a5075ee794af14d4f17a52bdbc47f1e" + } + Frame { + msec: 2720 + hash: "fd3d803a1e5e9e3eeae7d5edcddd0072" + } + Frame { + msec: 2736 + hash: "445114e7d10581a475989e469323d83d" + } + Frame { + msec: 2752 + hash: "58328c1d4c0ee7fca78b684697f1922c" + } + Frame { + msec: 2768 + hash: "433df4d872b9565b43af5afce1b42e15" + } + Frame { + msec: 2784 + hash: "3b694f15722a087c2c9a860cad8bb6de" + } + Frame { + msec: 2800 + hash: "1986c8036bd548ca06a32aa98ab4fc83" + } + Frame { + msec: 2816 + hash: "7845dbb0e38145f54a9e4e0bfbd608db" + } + Frame { + msec: 2832 + hash: "caed393910ae7467c307a314bdf459ef" + } + Frame { + msec: 2848 + hash: "f3f6b41b7ed04dbc1693c169bdae3b13" + } + Frame { + msec: 2864 + hash: "b9a87d15d48f951b0a1d6962fb1d5995" + } + Frame { + msec: 2880 + image: "particles.2.png" + } + Frame { + msec: 2896 + hash: "954300274b6a5785e03a6cdae67238e9" + } + Frame { + msec: 2912 + hash: "5b7f51afad796107289369c7d3494843" + } + Frame { + msec: 2928 + hash: "41164f28cbb94528eda719d590d1cf75" + } + Frame { + msec: 2944 + hash: "5953d4c9a4b4c83ba1dfd83a57ec2742" + } + Frame { + msec: 2960 + hash: "0be7c6187a26b44f12bf71587372a6c7" + } + Frame { + msec: 2976 + hash: "a7cab1faf0cdd5649c8ea3c26d2e80d0" + } + Frame { + msec: 2992 + hash: "5f91bef1865623030aea20805993319a" + } + Frame { + msec: 3008 + hash: "69d34e2a27c471ad44f8aba8d906a961" + } + Frame { + msec: 3024 + hash: "5a987879aff30d6c6712c0631bc2f43d" + } + Frame { + msec: 3040 + hash: "62b9132c58cd5fdcfe7f1bc5e64885cf" + } + Frame { + msec: 3056 + hash: "d394ef9b504abf94c1d28a9fb7f3c28b" + } + Frame { + msec: 3072 + hash: "a559cc25af950227fa5fdf70be7fd94c" + } + Frame { + msec: 3088 + hash: "318dde40fc72c5f8ee45b865a68922b1" + } + Frame { + msec: 3104 + hash: "3cbfd55773e52f48f01fe66c28c0b992" + } +} diff --git a/tests/auto/declarative/visual/qmlgraphicsparticles/particles.qml b/tests/auto/declarative/visual/qmlgraphicsparticles/particles.qml new file mode 100644 index 0000000..8fb793f --- /dev/null +++ b/tests/auto/declarative/visual/qmlgraphicsparticles/particles.qml @@ -0,0 +1,48 @@ +import Qt 4.6 + +Rectangle { + width: 640; height: 480; color: "black" + + Particles { id:particlesA + y:0; width: 260; height:30; source: "star.png"; + lifeSpan:1000; count: 50; angle:70; angleDeviation:36; + velocity:30; velocityDeviation:10; emissionRate: 10 + ParticleMotionWander { xvariance:30; pace:100 } + } + + Particles { id:particlesB + y:280; x:180; width:1; height:1; lifeSpan:1000; source: "star.png" + count: 100; angle:270; angleDeviation:45; velocity:50; velocityDeviation:30; + emissionRate: 0 + ParticleMotionGravity { yattractor: 1000; xattractor:0; acceleration:25 } + } + + Timer { running: true; interval: 1000; repeat: true; onTriggered: particlesB.burst(200, 2000); } + + Column{ + x: 340; + Repeater{ + model: 5 + delegate: Component{ + Item{ + width: 100; height: 100 + Rectangle{ + color: "blue" + width: 2; height: 2; + x: 49; y:49; + } + Particles{ + x: 50; y:50; width: 0; height: 0; + fadeInDuration: 0; fadeOutDuration: 0 + lifeSpan: 1000; lifeSpanDeviation:0; + source: "star.png" + count: -1; emissionRate: 120; + emissionVariance: index/2; + velocity: 250; velocityDeviation: 0; + angle: 0; angleDeviation: 0; + } + } + } + } + } +} diff --git a/tests/auto/declarative/visual/qmlgraphicsparticles/star.png b/tests/auto/declarative/visual/qmlgraphicsparticles/star.png Binary files differnew file mode 100644 index 0000000..defbde5 --- /dev/null +++ b/tests/auto/declarative/visual/qmlgraphicsparticles/star.png |