Timeline animation

The Timeline animation tutorial illustrates how to create timeline animations and bind them to properties in Qt Design Studio. First you create a keyframe animation which you control the running state of with a switch in the UI. Next, you create another keyframe animation where you use a slider in the UI to control the position of the playhead.

The starting point of this tutorial is the Animation Tutorial project, which you can download from here.

You can download the completed project from here.

To learn the basics of Qt Design Studio required to complete this tutorial, see Getting started.

Running the Tutorial Project

To open the tutorial project in Qt Design Studio, open the .qmlproject file located in the root folder of the downloaded project.

Creating a timeline animation

First, you create an animation where the ball bearing continuously rotates around its Y axis.

Adding a timeline and an animation

To add a timeline to your project:

  1. In the Timeline view, select the Plus button . This creates a timeline and one animation.
  2. On the Animation Settings tab in the Timeline Settings dialog:
    • Set Duration to 7500. This sets the duration of the animation in milliseconds.
    • Select Continuous. This sets the animation to start over again when it reaches the end.

  3. Select Close.

You can see the timeline in the Timeline and Navigator views.

Adding keyframes

Next, you add keyframes to animate the rotation of the ball bearing:

  1. In the Navigator view, select ballbearing1.
  2. In the Properties view, select the Action button (Actions) next to Rotation > Y.
  3. Select Insert Keyframe.

  4. In the Timeline view, select the Per Property Recording button to start recording property changes.

  5. In the Timeline view, move the playhead to the end of the animation (frame 1000).
  6. In the Properties view, set Rotation > Z to 360. This creates a second keyframe.
  7. Select the Per Property Recording button to end the per property recording. To preview the animation, drag the playhead along the timeline.

Controlling the running state of the animation

There is a toggle switch in the UI of this project. To use this switch to control the running state of the animation:

  1. In the Navigator view, select timelineAnimation.
  2. In the Connections view, go to the Bindings tab.
  3. Select the Plus button to create a binding.
  4. For the binding you created, set:
    • Property to paused.
    • Source Item to switch1.
    • Source Property to checked.

You can preview the animation and try the toggle switch in the live preview. To run the live preview, select Alt + P.

Creating a timeline and binding it to a property

Next, you create the exploded view animation of the ball bearing. You don't want this animation to run automatically but instead you want to control it with a slider in the UI.

Adding a timeline inside a component

To create this animation inside the ball bearing component:

  1. In the Navigator view, select ballBearing1.
  2. Select F2 to go into the component.
  3. In the Timeline view, select the Plus button to add a timeline and open the Timeline Settings dialog.
  4. Select the Minus button next to the Animation Settings tab to remove the animation in this timeline. You do not need an animation when you bind the timeline to a property.
  5. Select Close.

Adding keyframes

Now, you add keyframes for the different parts of the ball bearing:

  1. In the Navigator view, select inner_race.
  2. In the Properties view, select the Action button (Actions) next to Translation > Y.
  3. Select Insert Keyframe.
  4. In the Timeline view, select the Per Property Recording button to start recording property changes.
  5. In the Timeline view, move the playhead to the end of the animation (frame 1000).
  6. In the Properties view, set Translation > Y to 0,50.
  7. Select the Per Property Recording button to end the per property recording.
  8. Next, you set the keyframe values for the other parts of the ball bearing. For the following parts, set the Translation > Y value for frame 1000:
    • balls to 1,00.
    • retainer to 1,50.
    • shield_left to 1,80.
    • shield_right to -0,30.

You can preview the animation by dragging the playhead in the Timeline view.

Controlling the animation with a slider

Now, you use the slider on the main screen to control the exploded view animation that you created.

To do this, you first need to define a property for the slider:

  1. In the Navigator view, select Node.
  2. On the Properties tab in the Connections view, select the Plus button .
  3. In the Property Type field, enter Item. This field is a drop-down list, but you can also enter text.
  4. In the Property Value field, enter null.

Next, you set the property you just created to control the timeline animation:

  1. In the Timeline view, select the Animation button .
  2. In the Expression binding field, enter property0.value.
  3. Select Close.

Next, you go out from the component back to the main project and bind the property to the slider:

  1. In the toolbar, select the Screen01.ui.qml breadcrumb.

  2. In the Navigator view, select ballbearing1.
  3. In the Connections view, go to the Bindings tab.
  4. Select the Plus button .
  5. For the binding you just created:
    • Set Source Item to slider.
    • Remove the value from Source Property.

Previewing

Now, the animations are done. To preview and test your application, select Alt + P.

See also Creating timeline animations.

Available under certain Qt licenses.
Find out more.