1
0
Fork 0
mirror of https://github.com/Ellpeck/MLEM.git synced 2024-11-22 20:58:34 +01:00
MLEM/Docs/articles/sprite_animations.md
2020-05-21 01:08:36 +02:00

1.9 KiB

The MLEM package contains a very simple sprite animation system that features different-length frames as well as animation grouping.

Using animations

You can create an animation like so:

var texture = this.Content.Load<Texture2D>("Textures/TestSprite");

// Two-frame animation using a frame time of 0.5 seconds
var anim1 = new SpriteAnimation(timePerFrame: 0.5F,
    new TextureRegion(texture, 0, 0, 16, 16), new TextureRegion(texture, 16, 0, 16, 16));

// Three-frame animation with varying frame times
var anim2 = new SpriteAnimation(
    new AnimationFrame(new TextureRegion(texture, 0, 0, 16, 16), 0.25F),
    new AnimationFrame(new TextureRegion(texture, 16, 0, 16, 16), 0.5F),
    new AnimationFrame(new TextureRegion(texture, 32, 0, 16, 16), 0.3F)
);

Additionally, you have to update the animation every update frame in your game's Update method:

anim1.Update(gameTime);

You can draw the animation's current frame as follows:

this.SpriteBatch.Draw(anim1.CurrentRegion, new Vector2(10, 10), Color.White);

Using animation groups

Animation groups consist of multiple animations. Each animation in a group has a condition that determines if it should currently be playing.

You can create an animation group and add animations to it like so:

var group = new SpriteAnimationGroup();
// Animation 1 should always play
group.Add(anim1, () => true, priority: 0);
// Animation 2 should play if the game has been running for 10 seconds or more
// Since its priority is higher than anim1's, it will be the one that plays when its condition is true
group.Add(anim2, () => gameTime.TotalGameTime.TotalSeconds >= 10, priority: 1);

As with regular animations, an animation group also has to be updated each update frame:

group.Update(gameTime);

You can draw the group's current frame as follows:

this.SpriteBatch.Draw(group.CurrentRegion, new Vector2(10, 10), Color.White);