Easings on Bevy components using interpolation.
Add the plugin to your app:
rust
App::build()
.add_default_plugins()
.add_plugin(EasingsPlugin)
...
And then just ease your components to their new state!
rust
commands
.spawn(SpriteComponents {
material: materials.add(Color::RED.into()),
..Default::default()
})
.with(
Sprite {
size: Vec2::new(10., 10.),
..Default::default()
}
.ease_to(
Sprite {
size: Vec2::new(100., 100.),
..Default::default()
},
EaseFunction::QuadraticIn,
EasingType::PingPong {
duration: std::time::Duration::from_secs(1),
pause: std::time::Duration::from_millis(500),
},
),
);
If the component being eased is not already a component of the entity, the component should first be inserted for the target entity.
You can chain easings, if they are not set to repeat they will happen in sequence.
rust
commands
.spawn(SpriteComponents {
material: materials.add(Color::RED.into()),
..Default::default()
})
.with(
Sprite {
size: Vec2::new(10., 10.),
..Default::default()
}
.ease_to(
Sprite {
size: Vec2::new(300., 300.),
..Default::default()
},
EaseFunction::QuadraticIn,
EasingType::Once {
duration: std::time::Duration::from_secs(1),
},
)
.ease_to(
Sprite {
size: Vec2::new(350., 350.),
..Default::default()
},
EaseFunction::QuadraticIn,
EasingType::PingPong {
duration: std::time::Duration::from_millis(500),
pause: std::time::Duration::from_millis(200),
},
),
);
:warning: While doing easings on
Handle<ColorMaterial>
is possible (as shown in this example), it is probably not a good idea as manyColorMaterial
s will need to be added to the assets and it will slow down your game.
To be able to ease a component, it needs to implement the traits Default
and Lerp
. This trait is re-exported by beavy_easings
.
```rust
struct CustomComponent(f32); impl Lerp for CustomComponent { type Scalar = f32;
fn lerp(&self, other: &Self, scalar: &Self::Scalar) -> Self {
CustomComponent(self.0.lerp(&other.0, scalar))
}
} ```
The basic formula for lerp (linear interpolation) is self + (other - self) * scalar
.
Then, the system custom_ease_system::<CustomComponent>.system()
needs to be added to the application.
See examples
Many ease functions are available:
Feature ease_handle
is enabled by default, and control wether easing on Handle<ColorMaterial>
is possible or not. Disabling this feature removes a system and a resource that are not used otherwise, the rand
dependency and remove a i128
from the EasingComponent
.