CUGL 2.5
Cornell University Game Library
|
#include <CUAction.h>
Public Member Functions | |
Action () | |
~Action () | |
float | getDuration () const |
void | setDuration (float time) |
virtual std::shared_ptr< Action > | clone () |
virtual void | start (const std::shared_ptr< SceneNode > &target, void **state) |
virtual void | stop (const std::shared_ptr< SceneNode > &target, void **state) |
virtual void | update (const std::shared_ptr< SceneNode > &target, void *state, float dt) |
virtual std::string | toString (bool verbose=false) const |
operator std::string () const | |
Protected Attributes | |
float | _duration |
This class provides an template for an animation action template.
An action contains only the definition of the animation. This can include information about the transform to use or the duration of the animation. However, it does not contain any attribute of the target. Hence, an action can be reapplied to different targets.
By itself, an action does nothing. It only specifies an action that may take place. To use an action, it must be passed to the ActionManager. The manager will create an action instance and animate that instance. While an action may be reused many times, an action instance corresponds to a single animation.
To define a custom action, simply create a subclass and override the uppdate method. This is the method that an action uses to update its target Node.
|
inline |
Creates an uninitialized action.
NEVER USE A CONSTRUCTOR WITH NEW. If you want to allocate an object on the heap, use one of the static constructors instead.
|
inline |
Deletes this action, disposing all resources
|
virtual |
Returns a newly allocated copy of this Action.
Reimplemented in cugl::scene2::Animate, cugl::scene2::FadeOut, cugl::scene2::FadeIn, cugl::scene2::MoveBy, cugl::scene2::MoveTo, cugl::scene2::RotateBy, cugl::scene2::RotateTo, cugl::scene2::ScaleBy, and cugl::scene2::ScaleTo.
|
inline |
Returns the duration (in seconds) of this animation
Changing this value in mid-animation has undefined side-effects.
|
inline |
Cast from an Action to a string.
|
inline |
Sets the duration (in seconds) of this animation
Changing this value in mid-animation has undefined side-effects.
time | the duration (in seconds) of this animation |
|
inlinevirtual |
Prepares a target for action
The important state of the target should be allocated and stored in the given state reference. The semantics of this state is action-dependent.
target | The node to act on |
state | The address to store the node state |
Reimplemented in cugl::scene2::Animate, cugl::scene2::FadeOut, cugl::scene2::FadeIn, cugl::scene2::MoveBy, cugl::scene2::MoveTo, cugl::scene2::RotateBy, cugl::scene2::RotateTo, cugl::scene2::ScaleBy, and cugl::scene2::ScaleTo.
|
inlinevirtual |
Cleans up a target after an action
The target state in the given address should be deallocated, just as it was allocated in start
. The semantics of this state is action-dependent.
target | The node to act on |
state | The address to deallocate the node state |
Reimplemented in cugl::scene2::Animate, cugl::scene2::FadeOut, cugl::scene2::FadeIn, cugl::scene2::MoveBy, cugl::scene2::MoveTo, cugl::scene2::RotateBy, cugl::scene2::RotateTo, cugl::scene2::ScaleBy, and cugl::scene2::ScaleTo.
|
virtual |
Returns a string representation of the action for debugging purposes.
If verbose is true, the string will include class information. This allows us to unambiguously identify the class.
verbose | Whether to include class information |
Reimplemented in cugl::scene2::Animate, cugl::scene2::FadeOut, cugl::scene2::FadeIn, cugl::scene2::MoveBy, cugl::scene2::MoveTo, cugl::scene2::RotateBy, cugl::scene2::RotateTo, cugl::scene2::ScaleBy, and cugl::scene2::ScaleTo.
|
inlinevirtual |
Executes an (incremental) action on the given target node.
The important state of the target is stored in the given state parameter. The semantics of this state is action-dependent.
target | The node to act on |
state | The relevant node state |
dt | The elapsed time to animate. |
Reimplemented in cugl::scene2::Animate, cugl::scene2::FadeOut, cugl::scene2::FadeIn, cugl::scene2::MoveBy, cugl::scene2::MoveTo, cugl::scene2::RotateBy, cugl::scene2::RotateTo, cugl::scene2::ScaleBy, and cugl::scene2::ScaleTo.
|
protected |
The duration (in seconds) of the animation