summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMartin Jones <martin.jones@nokia.com>2009-11-05 07:42:20 (GMT)
committerMartin Jones <martin.jones@nokia.com>2009-11-05 07:42:20 (GMT)
commit5cd33a36efdcd8ee2a50d6d362c2523b4a942529 (patch)
tree71b6fffd1720856048dff836c9fdadd82fd57a07
parent7dc306a32b12dcd783714fbb6078e100bc52f32e (diff)
parentf8423b94bbf439831577644cd07d2aa4e997396a (diff)
downloadQt-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
-rw-r--r--demos/declarative/calculator/calculator.qml34
-rw-r--r--src/declarative/graphicsitems/qmlgraphicspositioners.cpp21
-rw-r--r--src/declarative/graphicsitems/qmlgraphicspositioners_p.h1
-rw-r--r--src/declarative/qml/qmlengine.cpp5
-rw-r--r--tests/auto/declarative/layouts/data/grid-animated.qml55
-rw-r--r--tests/auto/declarative/layouts/data/horizontal-animated.qml42
-rw-r--r--tests/auto/declarative/layouts/data/repeater.qml20
-rw-r--r--tests/auto/declarative/layouts/data/vertical-animated.qml42
-rw-r--r--tests/auto/declarative/layouts/tst_layouts.cpp229
-rw-r--r--tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.0.pngbin0 -> 10022 bytes
-rw-r--r--tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.1.pngbin0 -> 14142 bytes
-rw-r--r--tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.2.pngbin0 -> 14214 bytes
-rw-r--r--tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.qml783
-rw-r--r--tests/auto/declarative/visual/qmlgraphicsparticles/particles.qml48
-rw-r--r--tests/auto/declarative/visual/qmlgraphicsparticles/star.pngbin0 -> 262 bytes
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
new file mode 100644
index 0000000..30bdefd
--- /dev/null
+++ b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.0.png
Binary files differ
diff --git a/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.1.png b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.1.png
new file mode 100644
index 0000000..799e028
--- /dev/null
+++ b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.1.png
Binary files differ
diff --git a/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.2.png b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.2.png
new file mode 100644
index 0000000..ed267c2
--- /dev/null
+++ b/tests/auto/declarative/visual/qmlgraphicsparticles/data/particles.2.png
Binary files differ
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
new file mode 100644
index 0000000..defbde5
--- /dev/null
+++ b/tests/auto/declarative/visual/qmlgraphicsparticles/star.png
Binary files differ