6 releases (breaking)
0.6.0 | Jul 8, 2024 |
---|---|
0.5.0 | Jun 8, 2024 |
0.4.0 | Apr 8, 2024 |
0.3.1 | Apr 4, 2024 |
0.1.3 |
|
#176 in Game dev
65 downloads per month
220KB
2.5K
SLoC
bevy_tween
Bevy procedural and keyframe animation library.
This is a young plugin and APIs are to be fleshed out. Breaking changes are to be expected!
See changelog here.
Features
-
Ergonomic and user-friendly API: You can always spawn the animator manually but this crate provide APIs that abstracted over most boilerplate code. Animation can be built using the builder with function combinators.
Example
let sprite_id = commands.spawn(SpriteBundle { ... }).id(); let sprite = sprite_id.into_target(); commands.animation() .insert(tween( Duration::from_secs(1), EaseFunction::Linear, sprite.with(translation(pos0, pos1)) ));
You can also abstract animation!
fn my_animation( target: TargetComponent, duration: Duration ) -> impl FnOnce(&mut AnimationCommands, &mut Duration) { parallel(( tween(duration, EaseFunction::QuadraticOut, target.with(translation(...))), tween(duration, EaseFunction::QuadraticOut, target.with(rotation(...))), )) } let sprite_id = commands.spawn(Sprite { ... }).id(); let sprite = sprite_id.into_target(); commands.animation().insert(my_animation(sprite, Duration::from_secs(1)))
-
Flexible and Extensible: This crate is built on top of
bevy_time_runner
which mean we can extend this crate by adding any components and systems.- Tween anything from anywhere, built-in or custom system.
- Interpolate with any curve, built-in or custom system.
- Anything else.
-
Parallelism: Tweens are typed and can be query over by their typed system which increase chances for system parallelism.
-
Rich timer control:
- Looping
- Time scaling
- Skip backward or forward
- Jumping to anywhen
See demos
Goals:
- Flexible 🎉
- integration with other crates (?)
-
bevy_animation
-
bevy_lookup_curve
-
- Editor. While the original goal for this crate is tweening from code,
this crate absolutely has the capability to work on any complex animations.
The editor will aid in such jobs.
- Real-time display at any point in time in the animation.
- Editing path from point A to point B with arbitary curve.
Differences
The main motivation for this tweening crate is that the previous existing tweening crates is not flexible enough and so the main goal is to solve it.
Differences to bevy_tweening
or bevy_easings
:
- Tweening is not tied to a certain entity. You can create an entity specifically for tweening any where in the world.
- Complex animations, such as sequential or parallel tweening, are solved using
child-parent hierarchy:
- Solved the issue of modifying animation at runtime presents in the previous crates.
- Everything exists in the ECS world with no hidden structure, everything can be freely accessed.
- Makes a very extendable system, thanks Bevy's ECS!
- It's possible to have multiple
Interpolator
(orLens
if you came frombevy_tweening
) tweening the same component/asset/resource because of the design of this crate and so it is not limited by '1 component type per entitiy'.
- Advanced timer. This crate has custom timer implementation.
- Dependency injection. Systems communicate through various specific components, allowing you to extends the behavior to your needs by supplying those components and reduce duplication.
- Users of this crate are free to decide if they want to only use generic, only trait object, or even both for tweening, or even something else entirely.
Feature gates
- Defaults
bevy_asset
Add tweening systems for asset.bevy_render
Currently add nothing but required by thebevy_sprite
feature.bevy_sprite
Add some built-in interpolators related to sprite.bevy_ui
Add some built-in interpolators related to ui.bevy_eventlistener
Add entity-targeted events with bevy_eventlistener.
- Optional
bevy_lookup_curve
.
Adds interpolation implementation usingbevy_lookup_curve
.
Bevy Version Support
bevy |
bevy_tween |
---|---|
0.14 | 0.6 |
0.13 | 0.2–0.5 |
Credits
-
The first crate I discovered and tried to do tweening with in Bevy. Their method of
Lens
is great and so it's present in this crate. Now calledInterpolator
. Usages may be similar but is implemented differently. -
Godot's tween make it simple to animate something which is the inspiration for this crate. The multi-entity architecture is mainly inspired by Godot's node child-parent hierarchy system and that most of the engine APIs utilizes this to define behavior.
Contributions
Contributions are welcome!
License
Licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Your contributions
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
Demos
cargo run --example follow -F bevy/bevy_winit
A square will follow your circle with configurable animation.
https://github.com/Multirious/bevy_tween/assets/77918086/d582c2de-0f54-4b22-be03-e3bff3348deb
cargo run --example click -F bevy/bevy_winit
Click left to spawn a circle. Hold right click to repetitively spawn a circle every frame.
https://github.com/Multirious/bevy_tween/assets/77918086/fd0fe9d3-13a2-4261-880c-cc2609b875ba
cargo run --example hold -F bevy/bevy_winit
Hold left click to increase the effect intensitiy.
https://github.com/Multirious/bevy_tween/assets/77918086/33a297a6-19f2-4146-a906-1a88ff037ab3
cargo run --example event -F bevy/bevy_winit
Showcasing the tween event feature.
https://github.com/Multirious/bevy_tween/assets/77918086/9507c467-6428-4aed-bd00-511f05e6e951
cargo run --example sprite_sheet -F bevy/bevy_winit
Sprite Sheet animation.
https://github.com/Multirious/bevy_tween/assets/77918086/e3997b06-38e6-4add-85f5-a885b69c6687
Dependencies
~20–63MB
~1M SLoC