2 stable releases

1.0.1 Jan 12, 2023
1.0.0 Aug 20, 2021

#648 in Algorithms

Download history 545/week @ 2024-07-21 746/week @ 2024-07-28 719/week @ 2024-08-04 888/week @ 2024-08-11 1248/week @ 2024-08-18 1371/week @ 2024-08-25 1194/week @ 2024-09-01 939/week @ 2024-09-08 1181/week @ 2024-09-15 1507/week @ 2024-09-22 2675/week @ 2024-09-29 3105/week @ 2024-10-06 3916/week @ 2024-10-13 1050/week @ 2024-10-20 851/week @ 2024-10-27 1104/week @ 2024-11-03

6,964 downloads per month
Used in 13 crates (5 directly)

MIT/Apache

8KB
204 lines

simple-easing

This package contains a set of simple easing functions.


lib.rs:

This package contains a set of simple easing functions. That consume a standardised time attribute in the range between 0.0 and 1.0, that represent the progress of a transition. 0.0 being the beginning, 1.0 the end.

They return a value between 0.0 and 1.0 (it might exceed the 0..=1 range temporarily for a bounce effect). The returned value can be used to interpolate between the initial (0.0) and the final (1.0) transition state, allowing for a "more natural" feel of a transition by accelerating and decelerating at certain points, depending on the easing function used.

Visit easings.net to see visualisations of the different easing functions.

All easing functions have the same signature ((f32) -> f32) and can be easily stored as fn pointers.

use ::simple_easing::linear;
let easing: fn(f32) -> f32 = linear;
assert_eq!(easing(1.0), 1.0);

No runtime deps