I have a Column
with three elements and one element can change its visibility if the user hits the spacebar. To make the visibility change look smoothly I can add a move
transition:
ApplicationWindow {
title: qsTr("Hello World")
width: 640
height: 480
visible: true
Column {
spacing: 2
Rectangle { color: "red"; width: 50; height: 50 }
Rectangle { id: greenRect; color: "green"; width: 20; height: 50 }
Rectangle { color: "blue"; width: 50; height: 20 }
move: Transition {
NumberAnimation { properties: "x,y"; duration: 1000 }
}
focus: true
Keys.onSpacePressed: greenRect.visible = !greenRect.visible
}
}
This works. But if I center the Column
in its parent the visibility change also results in a new height
for the Column
and therefore also to a new y
position.
Now I don't want the Column
to 'jump' to its new position but also to move smoothly. So I added this to the Column
:
anchors.centerIn: parent
Behavior on y {
NumberAnimation { duration: 1000 }
}
But the y
position change is still not animated. How to achieve this?
Property changes induced by
anchors
don't seem to triggerBehaviour
s.As a workaround, manually center the
Column
: