Skip to content

AnimationAsset Guide

MelvMay-GG edited this page Feb 21, 2013 · 6 revisions

Introduction

All assets are known engine types that allow instances to be created at runtime. The "AnimationAsset", like all assets, is derived from a base type of "AssetBase". That means it includes all the fields from that type as well as adding its own fields specific to itself.

The AnimationAsset provides a way to refer to any ImageAsset that contains frames and select those frames for playing in a specified order to produce an animation of images.

For an AnimationAsset to be valid, it must contain at least a single frame selected from a valid ImageAsset.

TorqueScript Bindings

Exposed Fields

The AnimationAsset type exposes the following fields in addition to those it inherits. Shown are the equivalent methods available that perform the same action in setting and getting the respective field:

  • Image
    • setImage(imageAssetId)
    • getImage()
  • AnimationFrames
    • setAnimationFrames(string)
    • getAnimationFrames()
  • AnimationTime
    • setAnimationTime(float)
    • getAnimationTime();
  • AnimationCycle
    • setAnimationCycle(bool)
    • getAnimationCycle()
  • RandomStart
    • setRandomStart(bool)
    • getRandomStart()

The following is a complete description of each of these fields.

Image (string)

This is a mandatory field and refers to the image asset that should be used as the source for frames. This field should be an asset-Id that refers to an ImageAsset. If it does not refer to a valid asset (or the module the asset is defined in has not been loaded) or it is not an ImageAsset or the asset is not valid then the animation is not be valid.

An example is:

<AnimationAsset
    AnimationName="FireAnimation"
    Image="EffectsModule:FireImage"
...
/>

This example defines an animation named "FireAnimation" and refers to an ImageAsset named "FireImage" in the "EffectsModule" i.e. its asset-Id is "EffectsModule:FireImage".

AnimationFrames

This is another mandatory field that specifies the actual frames to use from the selected ImageAsset. You can select any number of frames and use each as many times as you like:

<AnimationAsset
    AnimationName="FireAnimation"
    Image="EffectsModule:FireImage"
    AnimationFrames="0 1 2 3 4 5 4 3 2 1"
/>

This example defines an animation that plays, in sequence, frames 0 to 5 to 1 i.e. it is a 10 frame animation.

Animation Time

Whilst this field is not mandatory as it defaults to one (second), it's obviously important in determining how fast the animation runs.

The animation time is how long it takes, in seconds, for the animation to play *all the specified animation frames.

<AnimationAsset
    AnimationName="FireAnimation"
    Image="EffectsModule:FireImage"
    AnimationFrames="0 1 2 3 4 5 4 3 2 1"
    AnimationTime="5"    
/>

This example plays all 10 frames in 5 seconds i.e. 0.5 seconds per frame. You are free to use any value greater than zero including floating-point values.

Animation Cycle

This is an optional field that controls whether the animation, when reaching the end of the selected frames should start again at the beginning or not. By default, animation cycle is true therefore all animations are "cyclic" animations by default therefore unless you want an animation that plays only once then you do not need to specify it.

<AnimationAsset
    AnimationName="FireAnimation"
    Image="EffectsModule:FireImage"
    AnimationFrames="0 1 2 3 4 5 4 3 2 1"
    AnimationTime="5"    
    AnimationCycle="false"
/>

The example plays all 10 frame 0 to 5 to 1 then stops because the animation cycle is false.

Random Start

This is an optional field that controls whether the animation, when starting, should start at a random selection of one of the specified frames. By default, random start is off therefore the animation will start at the first frame specified.

<AnimationAsset
    AnimationName="FireAnimation"
    Image="EffectsModule:FireImage"
    AnimationFrames="0 1 2 3 4 5 4 3 2 1"
    AnimationTime="5"    
    RandomStart="true"
/>

The example animation could start at any of the frames specified i.e. 0, 1, 2, 3, 4, 5, 4, 3, 2 or 1.

When starting lots of animations at the same time, having them all synchronized can look very odd, especially if the animation represents something typically random in nature such as fire, a flicker light, a swarm of insects etc. By using random start, you ensure that all these animations appear more random.

Clone this wiki locally