Step 1 - Create the animation

Kanzi creates keyframe animations by gradually changing the value of the animated properties between keyframes. When creating a keyframe animation that changes the values of the Render Transformation property the attributes of which define the position and size of a node, you create movement keyframe animation. However, you can also create a keyframe animation that changes the values of any other Kanzi property, such as color.

In Kanzi you create keyframe animations in Animation Clip and Animation Data items. To create more complex animations, you can organize animations into Timeline Entry and Timeline Sequence items. See Animations.

In this step of the tutorial you create the keyframe animation and use the Animation Player to play the animation.

Assets for the tutorial

The starting point of this tutorial is the <KanziWorkspace>/Tutorials/Keyframe animations/Start/Keyframe animations.kzproj Kanzi Studio project.

You can find the completed tutorial in the <KanziWorkspace>/Tutorials/Keyframe animations/Completed directory.

Create the animation

In this section you create the keyframe animation that bounces the BeachBall node on top of the Ground node.

To create the animation:

  1. In Kanzi Studio open the project stored in <KanziWorkspace>/Tutorials/Keyframe animations/Start.

    The project contains a BeachBall Model node and a Ground Plane node.

    ../../_images/beginning.png
  2. In the Library double-click Animations > Animation Clips > Animation Clip to open the Animation Clip in the Animation Clip Editor.

    ../../_images/animation-clip-editor.png
  3. In the Animation Clip Editor set the Current Time to 0.

    By setting the Current Time you tell Kanzi Studio at what time in the application you want to create a keyframe.

    ../../_images/current-time-0.png
  4. In the Node Tree select the BeachBall node and create a keyframe by dragging and dropping the Render Transformation property from the Properties to the Animation Clip Editor.

    This keyframe sets the position of the BeachBall node at the beginning of the animation (the keyframe contains the values of the BeachBall node Render Transformation property attributes).

    ../../_images/create-first-keyframe-properties.png ../../_images/create-first-keyframe.png
  5. In the Animation Clip Editor set the Current Time to 0,45, in the Properties set the Render Transformation Translation Y property field to 1 to move the BeachBall node right on top of the Ground node, and create a keyframe by dragging and dropping the Render Transformation property from the Properties to the Animation Clip Editor.

    This keyframe sets the position of the BeachBall node as it hits the Ground node.

    ../../_images/create-second-keyframe-properties.png ../../_images/create-second-keyframe.png
  6. Set the Current Time to 0,5, scale the BeachBall node on the y axis and move it right on top of the Ground node, and create a keyframe. Make sure you disable the Uniform option for the Scale attribute and apply the scaling only on the y axis of the BeachBall node.

    This keyframe scales the BeachBall node on y axis (the ball squezees as it hits the ground), and positions it right on top of the Ground node.

    ../../_images/create-third-keyframe-properties.png ../../_images/create-third-keyframe.png
  7. Set the Current Time to 0,55, return the scale of the BeachBall node to the state before it hit the Ground node, move it right on top of the Ground node, and create a keyframe.

    This keyframe returns the BeachBall node to its original size (the ball regains the shape as it bounces), and positions it right on top of the Ground node.

    ../../_images/create-second-keyframe-properties.png ../../_images/create-fourth-keyframe.png
  8. Set the Current Time to 1, move the BeachBall node to its starting position, and create a keyframe.

    This keyframe returns the BeachBall node to the position in which it was in the beginning of the animation.

    ../../_images/create-first-keyframe-properties.png ../../_images/create-fifth-keyframe.png

Play the animation

In Kanzi Studio use the Animation Player to control a keyframe animation.

To start the animation:

  1. In the Node Tree select the BeachBall node, in the Node Components press Alt and right-click Animation and select Animation Player.

    ../../_images/triggers-add-animation-player1.png
  2. In the Animation Player set:

    • Target Animation Timeline to the Animation Clip.

    • Autoplay Enabled to enabled.

      Autoplay Enabled sets whether the animation starts immediately after Kanzi attaches the node with the Animation Player to the node tree.

    • Repeat Count Infinite to enabled.

      In the Repeat Count property when you enable the Infinite property, the Animation Player plays the animation infinite amount of times.

    ../../_images/animation-player-trigger-settings-infinite.png

In the Preview you can see the BeachBall bouncing off the Ground. In the next step you fine-tune the animation and make the shadow react to the position of the BeachBall.

< Introduction | Next step >

See also

To find out more about the keyframe animations in Kanzi, see Animations.

To find out more about playing keyframe animations, see Using keyframe animations.

To find out more about the tools for editing keyframe animations in Kanzi Studio, see Editing animation clips.

To find out more about working with the timeline squences, see Editing timeline sequences.