Tweening animation plugin for the Bevy game engine.
Add the tweening plugin to your app:
rust
App::default()
.add_plugins(DefaultPlugins)
.add_plugin(TweeningPlugin)
.run();
Animate the transform position of an entity:
rust
commands
// Spawn a Sprite entity to animate the position of
.spawn_bundle(SpriteBundle {
sprite: Sprite {
color: Color::RED,
custom_size: Some(Vec2::new(size, size)),
..Default::default()
},
..Default::default()
})
// Add an Animator component to perform the animation. This is a shortcut to
// create both an Animator and a Tween, and assign the Tween to the Animator.
.insert(Animator::new(
// Use a quadratic easing on both endpoints
EaseFunction::QuadraticInOut,
// Loop animation back and forth over 1 second, with a 0.5 second
// pause after each cycle (start -> end -> start -> pause -> ...).
TweeningType::PingPong {
duration: Duration::from_secs(1),
pause: Some(Duration::from_millis(500)),
},
// The lens gives access to the Transform component of the Sprite,
// for the Animator to animate it. It also contains the start and
// end values associated with the animation ratios 0. and 1.
TransformPositionLens {
start: Vec3::new(0., 0., 0.),
end: Vec3::new(1., 2., -4.),
},
));
A small number of predefined lenses are available for the most common use cases, which also serve as examples. Users are encouraged to write their own lens to tailor the animation to their use case.
The naming scheme for predefined lenses is "<TargetName><FieldName>Lens"
, where <TargetName>
is the name of the target Bevy component or asset type which is queried by the internal animation system to be modified, and <FieldName>
is the field which is mutated in place by the lens. All predefined lenses modify a single field. Custom lenses can be written which modify multiple fields at once.
| Target Component | Animated Field | Lens |
|---|---|---|
| Sprite
| color
| SpriteColorLens
|
| Transform
| translation
| TransformPositionLens
|
| | rotation
| TransformRotationLens
|
| | scale
| TransformScaleLens
|
| Style
| position
| UiPositionLens
|
| Text
| TextStyle::color
| TextColorLens
|
| Target Asset | Animated Field | Lens |
|---|---|---|
| ColorMaterial
| color
| ColorMaterialColorLens
|
A custom lens allows animating any field or group of fields of a Bevy component or asset. A custom lens is a type implementing the Lens
trait, which is generic over the type of component or asset.
```rust struct MyXAxisLens { start: f32, end: f32, }
impl Lens
Note that the lens always linearly interpolates the field(s) of the component or asset. The type of easing applied modifies the rate at which the ratio
parameter evolves, and is applied before the lerp()
function is invoked.
The basic formula for lerp (linear interpolation) is either of:
start + (end - start) * scalar
start * (1.0 - scalar) + end * scalar
The two formulations are mathematically equivalent, but one may be more suited than the other depending on the type interpolated and the operations available, and the potential floating-point precision errors.
Custom components are animated like built-in Bevy ones, via a lens.
```rust
struct MyCustomComponent(f32);
struct MyCustomLens { start: f32, end: f32, }
impl Lens
Then, in addition, the system component_animator_system::<CustomComponent>
needs to be added to the application. This system will extract each frame all CustomComponent
instances with an Animator<CustomComponent>
on the same entity, and animate the component via its animator.
The process is similar to custom components, creating a custom lens for the custom asset. The system to add is asset_animator_system::<CustomAsset>
.
See the examples/
folder.
sprite_color
rust
cargo run --example sprite_color --features="bevy/bevy_winit"
transform_rotation
rust
cargo run --example transform_rotation --features="bevy/bevy_winit"
transform_translation
rust
cargo run --example transform_translation --features="bevy/bevy_winit"
colormaterial_color
rust
cargo run --example colormaterial_color --features="bevy/bevy_winit"
ui_position
rust
cargo run --example ui_position --features="bevy/bevy_winit"
sequence
rust
cargo run --example sequence --features="bevy/bevy_winit"
Many ease functions are available:
The main
branch is compatible with the latest Bevy release.
Compatibility of bevy_tweening
versions:
| bevy_tweening
| bevy
|
| :-- | :-- |
| 0.2
| 0.6
|
| 0.1
| 0.5
|
bevy_easings
The bevy_tweening
library started as a fork of the bevy_easings
library by François Mocker, with the goals to:
bevy_easings
does, and instead mutate the assets (and, by similarity, the components too) in-place without making a copy. The in-place mutation also allows a more optimal interpolation limited to modifying the fields of interest only, instead of creating a new copy of the entire component each tick.