Animation
Animation.new(path?)
Returns a new Animation instance.
animation:copy_from(animation)
Copies states and settings from the passed animation. Progress is reset.
Internally calls animation:apply()
unless the animation was created through Animation.new()
This function will call and clear interrupt callbacks.
animation:apply(sprite)
Applies the current animation state to the sprite, updating the origin and bounds of the sprite.
animation:load(path)
Loads new states, clears the old states.
Will attempt to retain settings and progress if the new animation has the same state as the active state.
If the animation has not completed and retaining state fails, this function will call and clear interrupt callbacks.
animation:update()
Advances animation progress by 1f or ~0.1666s. Ignored if the animation is paused.
Internally calls animation:apply()
unless the animation was created through Animation.new()
Automatically called unless the animation was created through Animation.new()
animation:sync_time(time)
time
: number, represents game frames
Updates the animation as if it has only played for time
. Using the same time will freeze the animation, decreasing time will reverse the animation.
animation:pause()
Causes animation:update()
calls (including automatic calls) to be ignored.
animation:resume()
Unpauses the animation.
animation:completed()
Returns true if the animation is complete.
animation:has_state(state)
Returns true if the state exists.
animation:state()
Returns the name of the active state.
animation:states()
Returns a list of available state names.
animation:set_state(state, frame_data?)
frame_data
a list of frame index and duration pairs.- When provided, the animation will remap frames and durations to match until the next
set_state
call. - Frame index starts at 1
- Duration is in game frames (60 per second).
- When provided, the animation will remap frames and durations to match until the next
Changes the active state, resets animation progress and settings.
This function will call and clear interrupt callbacks.
Internally calls animation:apply()
unless the animation was created through Animation.new()
-- modified example from the built-in buster.lua file
local frame_data = { { 1, 1 }, { 2, 2 }, { 3, 2 }, { 1, 1 } }
action:override_animation_frames(frame_data)
-- setup buster attachment
local buster_attachment = action:add_attachment("BUSTER")
local buster_sprite = buster_attachment:sprite()
buster_sprite:set_texture(user:texture())
buster_sprite:set_layer(-2)
buster_sprite:use_root_shader()
local buster_animation = buster_attachment:animation()
buster_animation:copy_from(user:animation())
-- relevant
buster_animation:set_state("BUSTER", frame_data)
animation:has_point(name)
Returns true if the current animation frame has a point with this name.
animation:get_point(name)
Returns { x: number, y: number }
.
animation:relative_point(name, origin_name?)
Calculates where a point is relative to the origin.
Returns { x: number, y: number }
.
animation:set_playback(playback)
playback
:Playback.Once
stops when the animation is completed.Playback.Loop
restarts the animation when completed.Playback.Bounce
when the animation completes playing forward it will play again reversed and cycle.Playback.Reverse
same asPlayback.Once
but reversed.- Currently does not start the animation on the last frame.
animation:set_state("example")
animation:set_playback(Playback.Loop)
animation:on_complete(function())
Adds a function to be called when the animation "completes".
Completion condition differs depending on playback:
Playback.Once
when the last frame completes.Playback.Loop
when the last frame completes.Playback.Bounce
when the first frame completes when reversed.Playback.Reverse
when the first frame completes.
animation:on_interrupt(function())
Adds a function to be called when the state changes.
animation:on_frame(frame_index, function(), do_once?)
frame_index
starts at 1do_once
when true, the callback is deleted.
Calls the callback when the frame changes during an update. If the frame_index
is 1 and the state was just set, it will be called next update.