Use case - Animations In QML▲
Qt Quick provides the ability to animate properties. Animating properties allows property values to move through intermediate values instead of immediately changing to the target value. To animate the position of an item, you can animate the properties that control the item's position, x and y for example, so that the item's position changes each frame on the way to the target position.
Fluid UIs▲
QML was designed to facilitate the creation of fluid UIs. These are user interfaces where the UI components animate instead of appearing, disappearing, or jumping abruptly. Qt Quick provides two simple ways to have UI components move with animation instead of instantly appearing at their new location.
States and Transitions▲
Qt Quick allows you to declare various UI states in State objects. These states are comprised of property changes from a base state, and can be a useful way of organizing your UI logic. Transitions are objects you can associate with an item to define how its properties will animate when they change due to a state change.
States and transitions for an item can be declared with the Item::states and Item::transitions properties. States are declared inside the states list property of an item, usually the root item of the component. Transitions defined on the same item are used to animate the changes in the state. Here is an example.
Item
{
id
:
container
width
:
320
height
:
120
Rectangle
{
id
:
rect
color
:
"red"
width
:
120
height
:
120
TapHandler {
onTapped
:
container.state ===
''
? container.state =
'other'
:
container.state =
''
}
}
states
:
[
// This adds a second state to the container where the rectangle is farther to the right
State
{
name
:
"other"
PropertyChanges
{
target
:
rect
x
:
200
}
}
]
transitions
:
[
// This adds a transition that defaults to applying to all state changes
Transition
{
// This applies a default NumberAnimation to any changes a state change makes to x or y properties
NumberAnimation
{
properties
:
"x,y"
}
}
]
}
Animating Property Changes.▲
Behaviors can be used to specify an animation for a property to use when it changes. This is then applied to all changes, regardless of their source. The following example animates a button moving around the screen using behaviors.
Item
{
width
:
320
height
:
120
Rectangle
{
color
:
"green"
width
:
120
height
:
120
// This is the behavior, and it applies a NumberAnimation to any attempt to set the x property
Behavior
on
x
{
NumberAnimation
{
//This specifies how long the animation takes
duration
:
600
//This selects an easing curve to interpolate with, the default is Easing.Linear
easing.type
:
Easing.OutBounce
}
}
TapHandler {
onTapped
:
parent.x ==
0
? parent.x =
200
:
parent.x =
0
}
}
}
Other Animations▲
Not all animations have to be tied to a specific property or state. You can also create animations more generally, and specify target items and properties inside the animation. Here are some examples of different ways to do this:
Item
{
width
:
320
height
:
120
Rectangle
{
color
:
"blue"
width
:
120
height
:
120
// By setting this SequentialAnimation on x, it and animations within it will automatically animate
// the x property of this element
SequentialAnimation
on
x
{
id
:
xAnim
// Animations on properties start running by default
running
:
false
loops
:
Animation.Infinite // The animation is set to loop indefinitely
NumberAnimation
{
from
:
0
; to
:
200
; duration
:
500
; easing.type
:
Easing.InOutQuad }
NumberAnimation
{
from
:
200
; to
:
0
; duration
:
500
; easing.type
:
Easing.InOutQuad }
PauseAnimation
{
duration
:
250
}
// This puts a bit of time between the loop
}
TapHandler {
// The animation starts running when you click within the rectangle
onTapped
:
xAnim.running =
true
}
}
}
Item
{
width
:
320
height
:
120
Rectangle
{
id
:
rectangle
color
:
"yellow"
width
:
120
height
:
120
TapHandler {
// The animation starts running when you click within the rectangle
onTapped
:
anim.running =
true
;
}
}
// This animation specifically targets the Rectangle's properties to animate
SequentialAnimation
{
id
:
anim
// Animations on their own are not running by default
// The default number of loops is one, restart the animation to see it again
NumberAnimation
{
target
:
rectangle; property
:
"x"
; from
:
0
; to
:
200
; duration
:
500
}
NumberAnimation
{
target
:
rectangle; property
:
"x"
; from
:
200
; to
:
0
; duration
:
500
}
}
}
More information about animations can be found on the Important Concepts in Qt Quick - States, Transitions and Animations page.