From 5fca4fa0139121adef3cbf8187b31c63fd6273c7 Mon Sep 17 00:00:00 2001 From: Jerome Humbert Date: Sat, 7 Dec 2024 18:50:51 +0000 Subject: [PATCH] Force `bevy_math/curve` feature through `bevy_color` (#139) The `EaseFunction` definition depends on the `bevy_math/curve` feature, which is unfortunately not re-exposed by Bevy. As a workaround, to make sure that feature is always active (since `EaseFunction` is a core type of `bevy_tweening`), we force a dependency on `bevy_color`, which itself already forces that feature. This is not ideal and brittle, but good enough until Bevy provides a better way. --- Cargo.toml | 4 ++- README.md | 77 +++++++++++++++++++++++++++--------------------------- 2 files changed, 41 insertions(+), 40 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index b6acc95..58985e0 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -27,7 +27,9 @@ bevy_ui = ["bevy/bevy_ui", "bevy/bevy_render"] bevy_text = ["bevy/bevy_text", "bevy/bevy_render", "bevy/bevy_sprite"] [dependencies] -bevy = { version = "0.15", default-features = false, features = ["x11"] } +# Note: need 'x11' or 'wayland' on Linux for winit to build +# Note: abuse 'bevy_color' to force 'bevy_math/curve' feature, which defines EaseFunction +bevy = { version = "0.15", default-features = false, features = ["x11", "bevy_color"] } [dev-dependencies] bevy-inspector-egui = "0.28" diff --git a/README.md b/README.md index 66c2140..26cef6d 100644 --- a/README.md +++ b/README.md @@ -151,13 +151,12 @@ The naming scheme for predefined lenses is `"Lens"`, wher | [`Sprite`](https://docs.rs/bevy/0.15.0/bevy/sprite/struct.Sprite.html) | [`color`](https://docs.rs/bevy/0.15.0/bevy/sprite/struct.Sprite.html#structfield.color) | [`SpriteColorLens`](https://docs.rs/bevy_tweening/latest/bevy_tweening/lens/struct.SpriteColorLens.html) | `bevy_sprite` | | [`Node`](https://docs.rs/bevy/0.15.0/bevy/ui/struct.Node.html) | [`position`](https://docs.rs/bevy/0.15.0/bevy/ui/struct.Node.html) | [`UiPositionLens`](https://docs.rs/bevy_tweening/latest/bevy_tweening/lens/struct.UiPositionLens.html) | `bevy_ui` | | [`BackgroundColor`](https://docs.rs/bevy/0.15.0/bevy/ui/struct.BackgroundColor.html)| | [`UiBackgroundColorLens`](https://docs.rs/bevy_tweening/latest/bevy_tweening/lens/struct.UiBackgroundColorLens.html) | `bevy_ui` | -| [`Text`](https://docs.rs/bevy/latest/bevy/text/index.html) | [`TextColor`](https://docs.rs/bevy/0.15.0/bevy/text/struct.TextColor.html) | [`TextColorLens`](https://docs.rs/bevy_tweening/latest/bevy_tweening/lens/struct.TextColorLens.html) | `bevy_text` | +| [`TextColor`](https://docs.rs/bevy/0.15.0/bevy/text/struct.TextColor.html) | | [`TextColorLens`](https://docs.rs/bevy_tweening/latest/bevy_tweening/lens/struct.TextColorLens.html) | `bevy_text` | -¹ Shortest-path interpolation between two rotations, using `Quat::slerp()`. +There are two ways to interpolate rotations. See the [comparison of rotation lenses](https://docs.rs/bevy_tweening/0.7.0/bevy_tweening/lens/index.html#rotations) for details: -² Angle-based interpolation, valid for rotations over ½ turn. - -See the [comparison of rotation lenses](https://docs.rs/bevy_tweening/0.7.0/bevy_tweening/lens/index.html#rotations) for details. +- ¹ Shortest-path interpolation between two rotations, using `Quat::slerp()`. +- ² Angle-based interpolation, valid for rotations over ½ turn. ### Bevy Assets @@ -283,74 +282,74 @@ cargo run --example sequence --features="bevy/bevy_winit" ## Ease Functions -Many [ease functions](https://docs.rs/bevy/latest/bevy/math/curve/enum.EaseFunction.html) are available: +Many [ease functions](https://docs.rs/bevy/0.15.0/bevy/math/curve/enum.EaseFunction.html) are available from `bevy_math`: - Linear -> `f(t) = t` + > `f(t) = t` - QuadraticIn -> `f(t) = t²` + > `f(t) = t²` - QuadraticOut -> `f(t) = -(t * (t - 2.0))` + > `f(t) = -(t * (t - 2.0))` - QuadraticInOut -> Behaves as `EaseFunction::QuadraticIn` for t < 0.5 and as `EaseFunction::QuadraticOut` for t >= 0.5 + > Behaves as `EaseFunction::QuadraticIn` for t < 0.5 and as `EaseFunction::QuadraticOut` for t >= 0.5 - CubicIn -> `f(t) = t³` + > `f(t) = t³` - CubicOut -> `f(t) = (t - 1.0)³ + 1.0` + > `f(t) = (t - 1.0)³ + 1.0` - CubicInOut -> Behaves as `EaseFunction::CubicIn` for t < 0.5 and as `EaseFunction::CubicOut` for t >= 0.5 + > Behaves as `EaseFunction::CubicIn` for t < 0.5 and as `EaseFunction::CubicOut` for t >= 0.5 - QuarticIn -> `f(t) = t⁴` + > `f(t) = t⁴` - QuarticOut -> `f(t) = (t - 1.0)³ * (1.0 - t) + 1.0` + > `f(t) = (t - 1.0)³ * (1.0 - t) + 1.0` - QuarticInOut -> Behaves as `EaseFunction::QuarticIn` for t < 0.5 and as `EaseFunction::QuarticOut` for t >= 0.5 + > Behaves as `EaseFunction::QuarticIn` for t < 0.5 and as `EaseFunction::QuarticOut` for t >= 0.5 - QuinticIn -> `f(t) = t⁵` + > `f(t) = t⁵` - QuinticOut -> `f(t) = (t - 1.0)⁵ + 1.0` + > `f(t) = (t - 1.0)⁵ + 1.0` - QuinticInOut -> Behaves as `EaseFunction::QuinticIn` for t < 0.5 and as `EaseFunction::QuinticOut` for t >= 0.5 + > Behaves as `EaseFunction::QuinticIn` for t < 0.5 and as `EaseFunction::QuinticOut` for t >= 0.5 - SineIn -> `f(t) = 1.0 - cos(t * π / 2.0)` + > `f(t) = 1.0 - cos(t * π / 2.0)` - SineOut -> `f(t) = sin(t * π / 2.0)` + > `f(t) = sin(t * π / 2.0)` - SineInOut -> Behaves as `EaseFunction::SineIn` for t < 0.5 and as `EaseFunction::SineOut` for t >= 0.5 + > Behaves as `EaseFunction::SineIn` for t < 0.5 and as `EaseFunction::SineOut` for t >= 0.5 - CircularIn -> `f(t) = 1.0 - sqrt(1.0 - t²)` + > `f(t) = 1.0 - sqrt(1.0 - t²)` - CircularOut -> `f(t) = sqrt((2.0 - t) * t)` + > `f(t) = sqrt((2.0 - t) * t)` - CircularInOut -> Behaves as `EaseFunction::CircularIn` for t < 0.5 and as `EaseFunction::CircularOut` for t >= 0.5 + > Behaves as `EaseFunction::CircularIn` for t < 0.5 and as `EaseFunction::CircularOut` for t >= 0.5 - ExponentialIn -> `f(t) = 2.0^(10.0 * (t - 1.0))` + > `f(t) = 2.0^(10.0 * (t - 1.0))` - ExponentialOut -> `f(t) = 1.0 - 2.0^(-10.0 * t)` + > `f(t) = 1.0 - 2.0^(-10.0 * t)` - ExponentialInOut -> Behaves as `EaseFunction::ExponentialIn` for t < 0.5 and as `EaseFunction::ExponentialOut` for t >= 0.5 + > Behaves as `EaseFunction::ExponentialIn` for t < 0.5 and as `EaseFunction::ExponentialOut` for t >= 0.5 - ElasticIn -> `f(t) = -2.0^(10.0 * t - 10.0) * sin((t * 10.0 - 10.75) * 2.0 * π / 3.0)` + > `f(t) = -2.0^(10.0 * t - 10.0) * sin((t * 10.0 - 10.75) * 2.0 * π / 3.0)` - ElasticOut -> `f(t) = 2.0^(-10.0 * t) * sin((t * 10.0 - 0.75) * 2.0 * π / 3.0) + 1.0` + > `f(t) = 2.0^(-10.0 * t) * sin((t * 10.0 - 0.75) * 2.0 * π / 3.0) + 1.0` - ElasticInOut -> Behaves as `EaseFunction::ElasticIn` for t < 0.5 and as `EaseFunction::ElasticOut` for t >= 0.5 + > Behaves as `EaseFunction::ElasticIn` for t < 0.5 and as `EaseFunction::ElasticOut` for t >= 0.5 - BackIn -> `f(t) = 2.70158 * t³ - 1.70158 * t²` + > `f(t) = 2.70158 * t³ - 1.70158 * t²` - BackOut -> `f(t) = 1.0 + 2.70158 * (t - 1.0)³ - 1.70158 * (t - 1.0)²` + > `f(t) = 1.0 + 2.70158 * (t - 1.0)³ - 1.70158 * (t - 1.0)²` - BackInOut -> Behaves as `EaseFunction::BackIn` for t < 0.5 and as `EaseFunction::BackOut` for t >= 0.5 + > Behaves as `EaseFunction::BackIn` for t < 0.5 and as `EaseFunction::BackOut` for t >= 0.5 - BounceIn -> bouncy at the start! + > bouncy at the start! - BounceOut -> bouncy at the end! + > bouncy at the end! - BounceInOut -> Behaves as `EaseFunction::BounceIn` for t < 0.5 and as `EaseFunction::BounceOut` for t >= 0.5 + > Behaves as `EaseFunction::BounceIn` for t < 0.5 and as `EaseFunction::BounceOut` for t >= 0.5 - Steps(usize) -> `n` steps connecting the start and the end + > `n` steps connecting the start and the end - Elastic(f32) -> `f(omega,t) = 1 - (1 - t)²(2sin(omega * t) / omega + cos(omega * t))`, parametrized by omega + > `f(omega,t) = 1 - (1 - t)²(2sin(omega * t) / omega + cos(omega * t))`, parametrized by omega ## Compatible Bevy versions