summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/declarative/util/qmlpropertychanges.cpp28
-rw-r--r--src/declarative/util/qmlstateoperations.cpp7
-rw-r--r--tests/auto/declarative/states/data/explicit.qml14
-rw-r--r--tests/auto/declarative/states/data/parentChange4.qml30
-rw-r--r--tests/auto/declarative/states/data/parentChange5.qml30
-rw-r--r--tests/auto/declarative/states/data/restoreEntryValues.qml14
-rw-r--r--tests/auto/declarative/states/tst_states.cpp82
-rw-r--r--tests/auto/declarative/visual/animation/bindinganimation/bindinganimation.qml2
-rw-r--r--tests/auto/declarative/visual/animation/bindinganimation/data/bindinganimation.4.pngbin814 -> 813 bytes
-rw-r--r--tests/auto/declarative/visual/animation/bindinganimation/data/bindinganimation.qml98
10 files changed, 252 insertions, 53 deletions
diff --git a/src/declarative/util/qmlpropertychanges.cpp b/src/declarative/util/qmlpropertychanges.cpp
index 75c9f80..a18db46 100644
--- a/src/declarative/util/qmlpropertychanges.cpp
+++ b/src/declarative/util/qmlpropertychanges.cpp
@@ -287,6 +287,15 @@ void QmlPropertyChanges::setObject(QObject *o)
d->object = o;
}
+/*!
+ \qmlproperty bool PropertyChanges::restoreEntryValues
+
+ Whether or not the previous values should be restored when
+ leaving the state. By default, restoreEntryValues is true.
+
+ By setting restoreEntryValues to false, you can create a temporary state
+ that has permanent effects on property values.
+*/
bool QmlPropertyChanges::restoreEntryValues() const
{
Q_D(const QmlPropertyChanges);
@@ -380,6 +389,25 @@ QmlPropertyChanges::ActionList QmlPropertyChanges::actions()
return list;
}
+/*!
+ \qmlproperty bool PropertyChanges::explicit
+
+ If explicit is set to true, any potential bindings will be interpreted as
+ once-off assignments that occur when the state is entered.
+
+ In the following example, the addition of explicit prevents myItem.width from
+ being bound to parent.width. Instead, it is assigned the value of parent.width
+ at the time of the state change.
+ \qml
+ PropertyChanges {
+ target: myItem
+ explicit: true
+ width: parent.width
+ }
+ \endqml
+
+ By default, explicit is false.
+*/
bool QmlPropertyChanges::isExplicit() const
{
Q_D(const QmlPropertyChanges);
diff --git a/src/declarative/util/qmlstateoperations.cpp b/src/declarative/util/qmlstateoperations.cpp
index 03337cb..d1aa748 100644
--- a/src/declarative/util/qmlstateoperations.cpp
+++ b/src/declarative/util/qmlstateoperations.cpp
@@ -76,18 +76,19 @@ void QmlParentChangePrivate::doChange(QmlGraphicsItem *targetParent, QmlGraphics
const QTransform &transform = target->itemTransform(targetParent, &ok);
if (transform.type() >= QTransform::TxShear || !ok) {
qmlInfo(q) << QObject::tr("Unable to preserve appearance under complex transform");
+ ok = false;
}
qreal scale = 1;
qreal rotation = 0;
- if (transform.type() != QTransform::TxRotate) {
+ if (ok && transform.type() != QTransform::TxRotate) {
if (transform.m11() == transform.m22())
scale = transform.m11();
else {
qmlInfo(q) << QObject::tr("Unable to preserve appearance under non-uniform scale");
ok = false;
}
- } else if (transform.type() == QTransform::TxRotate) {
+ } else if (ok && transform.type() == QTransform::TxRotate) {
if (transform.m11() == transform.m22())
scale = qSqrt(transform.m11()*transform.m11() + transform.m12()*transform.m12());
else {
@@ -105,7 +106,7 @@ void QmlParentChangePrivate::doChange(QmlGraphicsItem *targetParent, QmlGraphics
qreal xt = transform.dx();
qreal yt = transform.dy();
- if (target->transformOrigin() != QmlGraphicsItem::TopLeft) {
+ if (ok && target->transformOrigin() != QmlGraphicsItem::TopLeft) {
qreal tempxt = target->transformOriginPoint().x();
qreal tempyt = target->transformOriginPoint().y();
QTransform t;
diff --git a/tests/auto/declarative/states/data/explicit.qml b/tests/auto/declarative/states/data/explicit.qml
new file mode 100644
index 0000000..271115a
--- /dev/null
+++ b/tests/auto/declarative/states/data/explicit.qml
@@ -0,0 +1,14 @@
+import Qt 4.6
+Rectangle {
+ id: MyRectangle
+ property color sourceColor: "blue"
+ width: 100; height: 100
+ color: "red"
+ states: State {
+ name: "blue"
+ PropertyChanges {
+ target: MyRectangle; explicit: true
+ color: sourceColor
+ }
+ }
+}
diff --git a/tests/auto/declarative/states/data/parentChange4.qml b/tests/auto/declarative/states/data/parentChange4.qml
new file mode 100644
index 0000000..ee75176
--- /dev/null
+++ b/tests/auto/declarative/states/data/parentChange4.qml
@@ -0,0 +1,30 @@
+import Qt 4.6
+
+Rectangle {
+ width: 400; height: 400
+ Rectangle {
+ id: myRect
+ objectName: "MyRect"
+ x: 5; y: 5
+ width: 100; height: 100
+ color: "red"
+ }
+ MouseRegion {
+ id: Clickable
+ anchors.fill: parent
+ }
+
+ Item {
+ id: newParent
+ transform: Scale { xScale: .5; yScale: .7}
+ }
+
+ states: State {
+ name: "reparented"
+ when: Clickable.pressed
+ ParentChange {
+ target: myRect
+ parent: newParent
+ }
+ }
+}
diff --git a/tests/auto/declarative/states/data/parentChange5.qml b/tests/auto/declarative/states/data/parentChange5.qml
new file mode 100644
index 0000000..47b733b
--- /dev/null
+++ b/tests/auto/declarative/states/data/parentChange5.qml
@@ -0,0 +1,30 @@
+import Qt 4.6
+
+Rectangle {
+ width: 400; height: 400
+ Rectangle {
+ id: myRect
+ objectName: "MyRect"
+ x: 5; y: 5
+ width: 100; height: 100
+ color: "red"
+ }
+ MouseRegion {
+ id: Clickable
+ anchors.fill: parent
+ }
+
+ Item {
+ id: newParent
+ transform: Rotation { angle: 30; axis { x: 0; y: 1; z: 0 } }
+ }
+
+ states: State {
+ name: "reparented"
+ when: Clickable.pressed
+ ParentChange {
+ target: myRect
+ parent: newParent
+ }
+ }
+}
diff --git a/tests/auto/declarative/states/data/restoreEntryValues.qml b/tests/auto/declarative/states/data/restoreEntryValues.qml
new file mode 100644
index 0000000..d86f033
--- /dev/null
+++ b/tests/auto/declarative/states/data/restoreEntryValues.qml
@@ -0,0 +1,14 @@
+import Qt 4.6
+Rectangle {
+ id: MyRectangle
+ width: 100; height: 100
+ color: "red"
+ states: State {
+ name: "blue"
+ PropertyChanges {
+ target: MyRectangle
+ restoreEntryValues: false
+ color: "blue"
+ }
+ }
+}
diff --git a/tests/auto/declarative/states/tst_states.cpp b/tests/auto/declarative/states/tst_states.cpp
index 40e9aa8..3d8f303 100644
--- a/tests/auto/declarative/states/tst_states.cpp
+++ b/tests/auto/declarative/states/tst_states.cpp
@@ -56,8 +56,11 @@ private slots:
void signalOverride();
void signalOverrideCrash();
void parentChange();
+ void parentChangeErrors();
void anchorChanges();
void script();
+ void restoreEntryValues();
+ void explicitChanges();
};
void tst_states::basicChanges()
@@ -425,6 +428,43 @@ void tst_states::parentChange()
}
}
+void tst_states::parentChangeErrors()
+{
+ QmlEngine engine;
+
+ {
+ QmlComponent rectComponent(&engine, SRCDIR "/data/parentChange4.qml");
+ QmlGraphicsRectangle *rect = qobject_cast<QmlGraphicsRectangle*>(rectComponent.create());
+ QVERIFY(rect != 0);
+
+ QmlGraphicsRectangle *innerRect = qobject_cast<QmlGraphicsRectangle*>(rect->findChild<QmlGraphicsRectangle*>("MyRect"));
+ QVERIFY(innerRect != 0);
+
+ QTest::ignoreMessage(QtWarningMsg, "QML QmlParentChange (file://" SRCDIR "/data/parentChange4.qml:25:9) Unable to preserve appearance under non-uniform scale");
+ rect->setState("reparented");
+ QCOMPARE(innerRect->rotation(), qreal(0));
+ QCOMPARE(innerRect->scale(), qreal(1));
+ QCOMPARE(innerRect->x(), qreal(5));
+ QCOMPARE(innerRect->y(), qreal(5));
+ }
+
+ {
+ QmlComponent rectComponent(&engine, SRCDIR "/data/parentChange5.qml");
+ QmlGraphicsRectangle *rect = qobject_cast<QmlGraphicsRectangle*>(rectComponent.create());
+ QVERIFY(rect != 0);
+
+ QmlGraphicsRectangle *innerRect = qobject_cast<QmlGraphicsRectangle*>(rect->findChild<QmlGraphicsRectangle*>("MyRect"));
+ QVERIFY(innerRect != 0);
+
+ QTest::ignoreMessage(QtWarningMsg, "QML QmlParentChange (file://" SRCDIR "/data/parentChange5.qml:25:9) Unable to preserve appearance under complex transform");
+ rect->setState("reparented");
+ QCOMPARE(innerRect->rotation(), qreal(0));
+ QCOMPARE(innerRect->scale(), qreal(1));
+ QCOMPARE(innerRect->x(), qreal(5));
+ QCOMPARE(innerRect->y(), qreal(5));
+ }
+}
+
void tst_states::anchorChanges()
{
QmlEngine engine;
@@ -479,6 +519,48 @@ void tst_states::script()
}
}
+void tst_states::restoreEntryValues()
+{
+ QmlEngine engine;
+
+ QmlComponent rectComponent(&engine, SRCDIR "/data/restoreEntryValues.qml");
+ QmlGraphicsRectangle *rect = qobject_cast<QmlGraphicsRectangle*>(rectComponent.create());
+ QVERIFY(rect != 0);
+
+ QCOMPARE(rect->color(),QColor("red"));
+
+ rect->setState("blue");
+ QCOMPARE(rect->color(),QColor("blue"));
+
+ rect->setState("");
+ QCOMPARE(rect->color(),QColor("blue"));
+}
+
+void tst_states::explicitChanges()
+{
+ QmlEngine engine;
+
+ QmlComponent rectComponent(&engine, SRCDIR "/data/explicit.qml");
+ QmlGraphicsRectangle *rect = qobject_cast<QmlGraphicsRectangle*>(rectComponent.create());
+ QVERIFY(rect != 0);
+
+ QCOMPARE(rect->color(),QColor("red"));
+
+ rect->setState("blue");
+ QCOMPARE(rect->color(),QColor("blue"));
+
+ rect->setProperty("sourceColor", QColor("green"));
+ QCOMPARE(rect->color(),QColor("blue"));
+
+ rect->setState("");
+ QCOMPARE(rect->color(),QColor("red"));
+ rect->setProperty("sourceColor", QColor("yellow"));
+ QCOMPARE(rect->color(),QColor("red"));
+
+ rect->setState("blue");
+ QCOMPARE(rect->color(),QColor("yellow"));
+}
+
QTEST_MAIN(tst_states)
#include "tst_states.moc"
diff --git a/tests/auto/declarative/visual/animation/bindinganimation/bindinganimation.qml b/tests/auto/declarative/visual/animation/bindinganimation/bindinganimation.qml
index eabba73..1afd4cd 100644
--- a/tests/auto/declarative/visual/animation/bindinganimation/bindinganimation.qml
+++ b/tests/auto/declarative/visual/animation/bindinganimation/bindinganimation.qml
@@ -17,7 +17,7 @@ Rectangle {
name: "hello"
PropertyChanges {
target: MyRectangle
- x: 100
+ x: 50 + 50
}
PropertyChanges {
target: MyMouseRegion
diff --git a/tests/auto/declarative/visual/animation/bindinganimation/data/bindinganimation.4.png b/tests/auto/declarative/visual/animation/bindinganimation/data/bindinganimation.4.png
index bba04a9..2ddde86 100644
--- a/tests/auto/declarative/visual/animation/bindinganimation/data/bindinganimation.4.png
+++ b/tests/auto/declarative/visual/animation/bindinganimation/data/bindinganimation.4.png
Binary files differ
diff --git a/tests/auto/declarative/visual/animation/bindinganimation/data/bindinganimation.qml b/tests/auto/declarative/visual/animation/bindinganimation/data/bindinganimation.qml
index a90f99e..8297c5a 100644
--- a/tests/auto/declarative/visual/animation/bindinganimation/data/bindinganimation.qml
+++ b/tests/auto/declarative/visual/animation/bindinganimation/data/bindinganimation.qml
@@ -1230,19 +1230,19 @@ VisualTest {
}
Frame {
msec: 4400
- hash: "8006ceaa02d22b5fdfeab400d39a0caf"
+ hash: "6f48d1a9977b77cafd38a5903017605b"
}
Frame {
msec: 4416
- hash: "6f48d1a9977b77cafd38a5903017605b"
+ hash: "69058485ced6bc992a1a7c5ee34add4c"
}
Frame {
msec: 4432
- hash: "69058485ced6bc992a1a7c5ee34add4c"
+ hash: "dafcce427161a70c3513841ac22aea00"
}
Frame {
msec: 4448
- hash: "dafcce427161a70c3513841ac22aea00"
+ hash: "3223ed179c828fadb3eca9c6373176c1"
}
Mouse {
type: 2
@@ -1254,27 +1254,27 @@ VisualTest {
}
Frame {
msec: 4464
- hash: "3223ed179c828fadb3eca9c6373176c1"
+ hash: "b08811b237ce7a460c80d285f04d53d8"
}
Frame {
msec: 4480
- hash: "b08811b237ce7a460c80d285f04d53d8"
+ hash: "fcae0317f81a3ddd713f4db1349a9da0"
}
Frame {
msec: 4496
- hash: "fcae0317f81a3ddd713f4db1349a9da0"
+ hash: "772396bb23c713f34ea5c23bfbcb115e"
}
Frame {
msec: 4512
- hash: "772396bb23c713f34ea5c23bfbcb115e"
+ hash: "ecda10356cca33901c2acd0a702fee46"
}
Frame {
msec: 4528
- hash: "ecda10356cca33901c2acd0a702fee46"
+ hash: "575d30ac088448b01f49082519bbb3a1"
}
Frame {
msec: 4544
- hash: "575d30ac088448b01f49082519bbb3a1"
+ hash: "abc2ec0bc7a93e75b5823310e6284db1"
}
Mouse {
type: 3
@@ -1286,27 +1286,27 @@ VisualTest {
}
Frame {
msec: 4560
- hash: "575d30ac088448b01f49082519bbb3a1"
+ hash: "abc2ec0bc7a93e75b5823310e6284db1"
}
Frame {
msec: 4576
- hash: "d9af30557f99b086bb1a185a946b580d"
+ hash: "575d30ac088448b01f49082519bbb3a1"
}
Frame {
msec: 4592
- hash: "82363265ed2b611a54f8d48b2af22f11"
+ hash: "ecda10356cca33901c2acd0a702fee46"
}
Frame {
msec: 4608
- hash: "f9deee3a204c939562b896a6179743d2"
+ hash: "772396bb23c713f34ea5c23bfbcb115e"
}
Frame {
msec: 4624
- hash: "42f65c58b1f5f4b5ba70855f4aaa7d2f"
+ hash: "fcae0317f81a3ddd713f4db1349a9da0"
}
Frame {
msec: 4640
- hash: "56c72b5da44bd5efdc47c3b9c3eac409"
+ hash: "b08811b237ce7a460c80d285f04d53d8"
}
Mouse {
type: 4
@@ -1318,27 +1318,27 @@ VisualTest {
}
Frame {
msec: 4656
- hash: "72731478d80f024076ea639b55152360"
+ hash: "17c46242c17983478f34cb49cb91ca6e"
}
Frame {
msec: 4672
- hash: "4279c814163af3bd069ce21b3cd1c729"
+ hash: "dafcce427161a70c3513841ac22aea00"
}
Frame {
msec: 4688
- hash: "72a0c017a2fa90a4aeadfa6e552ff573"
+ hash: "69058485ced6bc992a1a7c5ee34add4c"
}
Frame {
msec: 4704
- hash: "391ad7ff2362e059f6170dfe306f94a7"
+ hash: "6f48d1a9977b77cafd38a5903017605b"
}
Frame {
msec: 4720
- hash: "0b0c6419e1e5b016d9c22bd98fd452b1"
+ hash: "ddb65481469c38f2331546ee03a44206"
}
Frame {
msec: 4736
- hash: "365c824c330398d267ea52ae9468b9ee"
+ hash: "a21aa1984f068650cce2a124a82c12be"
}
Mouse {
type: 3
@@ -1350,15 +1350,15 @@ VisualTest {
}
Frame {
msec: 4752
- hash: "365c824c330398d267ea52ae9468b9ee"
+ hash: "a21aa1984f068650cce2a124a82c12be"
}
Frame {
msec: 4768
- hash: "365c824c330398d267ea52ae9468b9ee"
+ hash: "8006ceaa02d22b5fdfeab400d39a0caf"
}
Frame {
msec: 4784
- hash: "ddb65481469c38f2331546ee03a44206"
+ hash: "6f48d1a9977b77cafd38a5903017605b"
}
Frame {
msec: 4800
@@ -1366,7 +1366,7 @@ VisualTest {
}
Frame {
msec: 4816
- hash: "69058485ced6bc992a1a7c5ee34add4c"
+ hash: "56125a260a79bc38bb0ef44fd65ba49b"
}
Mouse {
type: 2
@@ -1378,31 +1378,31 @@ VisualTest {
}
Frame {
msec: 4832
- hash: "dafcce427161a70c3513841ac22aea00"
+ hash: "56c72b5da44bd5efdc47c3b9c3eac409"
}
Frame {
msec: 4848
- hash: "3223ed179c828fadb3eca9c6373176c1"
+ hash: "42f65c58b1f5f4b5ba70855f4aaa7d2f"
}
Frame {
msec: 4864
- hash: "b08811b237ce7a460c80d285f04d53d8"
+ hash: "6a74d6dc91a8b370200d3765c55c1136"
}
Frame {
msec: 4880
- hash: "f9deee3a204c939562b896a6179743d2"
+ hash: "9413dffb7ee853ba0125ac22ab22abbd"
}
Frame {
msec: 4896
- hash: "9413dffb7ee853ba0125ac22ab22abbd"
+ hash: "527b1f9e7a222483134675a73f9cf5b7"
}
Frame {
msec: 4912
- hash: "5fae0bdc65c609cb766ce585b8c649db"
+ hash: "ffeb3db6d3f177acf6f92049359a9025"
}
Frame {
msec: 4928
- hash: "ffeb3db6d3f177acf6f92049359a9025"
+ hash: "a39c80859a7643c9879da9c77b644703"
}
Mouse {
type: 3
@@ -1414,63 +1414,63 @@ VisualTest {
}
Frame {
msec: 4944
- hash: "ffeb3db6d3f177acf6f92049359a9025"
+ hash: "a39c80859a7643c9879da9c77b644703"
}
Frame {
msec: 4960
- hash: "527b1f9e7a222483134675a73f9cf5b7"
+ hash: "ffeb3db6d3f177acf6f92049359a9025"
}
Frame {
msec: 4976
- hash: "5edaad77f334e6a01982ee89a733b1f8"
+ hash: "527b1f9e7a222483134675a73f9cf5b7"
}
Frame {
msec: 4992
- hash: "6a74d6dc91a8b370200d3765c55c1136"
+ hash: "9413dffb7ee853ba0125ac22ab22abbd"
}
Frame {
msec: 5008
- hash: "4f41101378a104e72228eeb4ba395ca8"
+ hash: "6a74d6dc91a8b370200d3765c55c1136"
}
Frame {
msec: 5024
- hash: "37739777a5979f3ebf85e47e63341660"
+ hash: "4f41101378a104e72228eeb4ba395ca8"
}
Frame {
msec: 5040
- hash: "f4fe2cc93d65e086ba8ded1438269eb2"
+ hash: "56c72b5da44bd5efdc47c3b9c3eac409"
}
Frame {
msec: 5056
- hash: "d245b288eb3eb7067c25f4475c47d2f7"
+ hash: "72731478d80f024076ea639b55152360"
}
Frame {
msec: 5072
- hash: "7f465a99fca50503736e470a0b4e1c7a"
+ hash: "07f751ea4cf877ba72fbb36f9da268d7"
}
Frame {
msec: 5088
- hash: "1d5cd86ab732da3705a7bb1deab77923"
+ hash: "a2cebc35e5c2c709a2cd83e1df6eaeab"
}
Frame {
msec: 5104
- hash: "ddb65481469c38f2331546ee03a44206"
+ hash: "8006ceaa02d22b5fdfeab400d39a0caf"
}
Frame {
msec: 5120
- hash: "a21aa1984f068650cce2a124a82c12be"
+ hash: "f9f74a2e38b52c9266f33e428b6acd9d"
}
Frame {
msec: 5136
- hash: "65ad7e0189c096792331bd1bb0daf0db"
+ hash: "a93f930ec8528f954cd4a770c9a8171b"
}
Frame {
msec: 5152
- hash: "48eb78c29227a399f9c1c95c7d77c9d9"
+ hash: "bfa51b7c19753ef7b16d78afffc7b9dd"
}
Frame {
msec: 5168
- hash: "51f228440001d23e294da1dde07a1577"
+ hash: "df62027b6b53c69a071cb3dc09c3a7ed"
}
Frame {
msec: 5184
@@ -1611,7 +1611,7 @@ VisualTest {
Key {
type: 6
key: 16777249
- modifiers: 67108864
+ modifiers: 0
text: ""
autorep: false
count: 1