1 Commits

Author SHA1 Message Date
t d6ebe272db chore: remove flake.nix 2026-02-15 11:52:22 +01:00
14 changed files with 29 additions and 115 deletions
+1
View File
@@ -1,2 +1,3 @@
/target/
/Cargo.lock
/flake.lock
-7
View File
@@ -1,12 +1,5 @@
# Changelog
## 1.0.2
* use rust edition 2024
* make all functions inlinable
* add `#[must_use]` to all functions
* enable clippy lints and fix
## 1.0.1
* repair `elastic_out` function
+1 -1
View File
@@ -1,6 +1,6 @@
[package]
name = "simple-easing"
version = "1.0.2"
version = "1.0.1"
description = "Set of simple easing functions"
edition = "2024"
repository = "https://gitlab.com/chpio/simple-easing"
+4 -13
View File
@@ -3,29 +3,20 @@ const C2: f32 = C1 * 1.525;
const C3: f32 = C1 + 1.0;
/// <https://easings.net/#easeInBack>
#[inline]
#[must_use]
pub fn back_in(t: f32) -> f32 {
(C3 * t * t).mul_add(t, -(C1 * t * t))
C3 * t * t * t - C1 * t * t
}
/// <https://easings.net/#easeOutBack>
#[inline]
#[must_use]
pub fn back_out(t: f32) -> f32 {
C1.mul_add((t - 1.0).powi(2), C3.mul_add((t - 1.0).powi(3), 1.0))
1.0 + C3 * (t - 1.0).powi(3) + C1 * (t - 1.0).powi(2)
}
/// <https://easings.net/#easeInOutBack>
#[inline]
#[must_use]
pub fn back_in_out(t: f32) -> f32 {
if t < 0.5 {
((2.0 * t).powi(2) * ((C2 + 1.0) * 2.0).mul_add(t, -C2)) / 2.0
((2.0 * t).powi(2) * ((C2 + 1.0) * 2.0 * t - C2)) / 2.0
} else {
f32::midpoint(
2.0f32.mul_add(t, -2.0).powi(2) * (C2 + 1.0).mul_add(t.mul_add(2.0, -2.0), C2),
2.0,
)
((2.0 * t - 2.0).powi(2) * ((C2 + 1.0) * (t * 2.0 - 2.0) + C2) + 2.0) / 2.0
}
}
+6 -12
View File
@@ -1,34 +1,28 @@
/// <https://easings.net/#easeInBounce>
#[inline]
#[must_use]
pub fn bounce_in(t: f32) -> f32 {
1.0 - bounce_out(1.0 - t)
}
/// <https://easings.net/#easeOutBounce>
#[inline]
#[must_use]
pub fn bounce_out(t: f32) -> f32 {
const N1: f32 = 7.5625;
const D1: f32 = 2.75;
if t < 1.0 / D1 {
N1 * t * t
return N1 * t * t;
} else if t < 2.0 / D1 {
N1.mul_add((t - 1.5 / D1).powi(2), 0.75)
return N1 * (t - 1.5 / D1).powi(2) + 0.75;
} else if t < 2.5 / D1 {
N1.mul_add((t - 2.25 / D1).powi(2), 0.937_5)
return N1 * (t - 2.25 / D1).powi(2) + 0.9375;
} else {
N1.mul_add((t - 2.625 / D1).powi(2), 0.984_375)
return N1 * (t - 2.625 / D1).powi(2) + 0.984375;
}
}
/// <https://easings.net/#easeInOutBounce>
#[inline]
#[must_use]
pub fn bounce_in_out(t: f32) -> f32 {
if t < 0.5 {
(1.0 - bounce_out(2.0f32.mul_add(-t, 1.0))) / 2.0
(1.0 - bounce_out(1.0 - 2.0 * t)) / 2.0
} else {
f32::midpoint(1.0, bounce_out(2.0f32.mul_add(t, -1.0)))
(1.0 + bounce_out(2.0 * t - 1.0)) / 2.0
}
}
+4 -16
View File
@@ -1,30 +1,18 @@
/// <https://easings.net/#easeInCirc>
#[inline]
#[must_use]
pub fn circ_in(t: f32) -> f32 {
1.0 - t.mul_add(-t, 1.0).sqrt()
1.0 - (1.0 - t.powi(2)).sqrt()
}
/// <https://easings.net/#easeOutCirc>
#[inline]
#[must_use]
pub fn circ_out(t: f32) -> f32 {
(t - 1.0).mul_add(-(t - 1.0), 1.0).sqrt()
(1.0 - (t - 1.0).powi(2)).sqrt()
}
/// <https://easings.net/#easeInOutCirc>
#[inline]
#[must_use]
pub fn circ_in_out(t: f32) -> f32 {
if t < 0.5 {
(1.0 - (2.0 * t).mul_add(-(2.0 * t), 1.0).sqrt()) / 2.0
(1.0 - (1.0 - (2.0 * t).powi(2)).sqrt()) / 2.0
} else {
f32::midpoint(
(-2.0f32)
.mul_add(t, 2.0)
.mul_add(-(-2.0f32).mul_add(t, 2.0), 1.0)
.sqrt(),
1.0,
)
((1.0 - (-2.0 * t + 2.0).powi(2)).sqrt() + 1.0) / 2.0
}
}
+1 -7
View File
@@ -1,24 +1,18 @@
/// <https://easings.net/#easeInCubic>
#[inline]
#[must_use]
pub fn cubic_in(t: f32) -> f32 {
t * t * t
}
/// <https://easings.net/#easeOutCubic>
#[inline]
#[must_use]
pub fn cubic_out(t: f32) -> f32 {
1.0 - (1.0 - t).powi(3)
}
/// <https://easings.net/#easeInOutCubic>
#[inline]
#[must_use]
pub fn cubic_in_out(t: f32) -> f32 {
if t < 0.5 {
4.0 * t * t * t
} else {
1.0 - (-2.0f32).mul_add(t, 2.0).powi(3) / 2.0
1.0 - (-2.0 * t + 2.0).powi(3) / 2.0
}
}
+4 -12
View File
@@ -4,44 +4,36 @@ const C4: f32 = (2.0 * PI) / 3.0;
const C5: f32 = (2.0 * PI) / 4.5;
/// <https://easings.net/#easeInElastic>
#[inline]
#[must_use]
pub fn elastic_in(t: f32) -> f32 {
if t <= 0.0 {
0.0
} else if 1.0 <= t {
1.0
} else {
-10.0f32.mul_add(t, -10.0).exp2() * (t.mul_add(10.0, -10.75) * C4).sin()
-2f32.powf(10.0 * t - 10.0) * ((t * 10.0 - 10.75) * C4).sin()
}
}
/// <https://easings.net/#easeOutElastic>
#[inline]
#[must_use]
pub fn elastic_out(t: f32) -> f32 {
if t <= 0.0 {
0.0
} else if 1.0 <= t {
1.0
} else {
(-10.0 * t)
.exp2()
.mul_add((t.mul_add(10.0, -0.75) * C4).sin(), 1.0)
2f32.powf(-10.0 * t) * ((t * 10.0 - 0.75) * C4).sin() + 1.0
}
}
/// <https://easings.net/#easeInOutElastic>
#[inline]
#[must_use]
pub fn elastic_in_out(t: f32) -> f32 {
if t <= 0.0 {
0.0
} else if 1.0 <= t {
1.0
} else if t < 0.5 {
-(20.0f32.mul_add(t, -10.0).exp2() * (20.0f32.mul_add(t, -11.125) * C5).sin()) / 2.0
-(2f32.powf(20.0 * t - 10.0) * ((20.0 * t - 11.125) * C5).sin()) / 2.0
} else {
((-20.0f32).mul_add(t, 10.0).exp2() * (20.0f32.mul_add(t, -11.125) * C5).sin()) / 2.0 + 1.0
(2f32.powf(-20.0 * t + 10.0) * ((20.0 * t - 11.125) * C5).sin()) / 2.0 + 1.0
}
}
+4 -10
View File
@@ -1,36 +1,30 @@
/// <https://easings.net/#easeInExpo>
#[inline]
#[must_use]
pub fn expo_in(t: f32) -> f32 {
if t <= 0.0 {
0.0
} else {
10.0f32.mul_add(t, -10.0).exp2()
2f32.powf(10.0 * t - 10.0)
}
}
/// <https://easings.net/#easeOutExpo>
#[inline]
#[must_use]
pub fn expo_out(t: f32) -> f32 {
if 1.0 <= t {
1.0
} else {
1.0 - (-10.0 * t).exp2()
1.0 - 2f32.powf(-10.0 * t)
}
}
/// <https://easings.net/#easeInOutExpo>
#[inline]
#[must_use]
pub fn expo_in_out(t: f32) -> f32 {
if t <= 0.0 {
0.0
} else if 1.0 <= t {
1.0
} else if t < 0.5 {
20.0f32.mul_add(t, -10.0).exp2() / 2.0
2f32.powf(20.0 * t - 10.0) / 2.0
} else {
(2.0 - (-20.0f32).mul_add(t, 10.0).exp2()) / 2.0
(2.0 - 2f32.powf(-20.0 * t + 10.0)) / 2.0
}
}
-9
View File
@@ -20,9 +20,6 @@
//! assert_eq!(easing(1.0), 1.0);
//! ```
#![warn(clippy::pedantic, clippy::nursery)]
#![allow(clippy::missing_const_for_fn)]
mod back;
mod bounce;
mod circ;
@@ -45,15 +42,11 @@ pub use quart::*;
pub use quint::*;
pub use sine::*;
#[inline]
#[must_use]
pub fn linear(t: f32) -> f32 {
t
}
/// A linear easing that goes from `1.0` to `0.0`.
#[inline]
#[must_use]
pub fn reverse(t: f32) -> f32 {
1.0 - t
}
@@ -68,8 +61,6 @@ pub fn reverse(t: f32) -> f32 {
/// let descending = cubic_in(roundtrip(0.75));
/// assert!((ascending - descending).abs() < 0.001);
/// ```
#[inline]
#[must_use]
pub fn roundtrip(t: f32) -> f32 {
if t < 0.5 { t * 2.0 } else { (1.0 - t) * 2.0 }
}
+2 -8
View File
@@ -1,24 +1,18 @@
/// <https://easings.net/#easeInQuad>
#[inline]
#[must_use]
pub fn quad_in(t: f32) -> f32 {
t * t
}
/// <https://easings.net/#easeOutQuad>
#[inline]
#[must_use]
pub fn quad_out(t: f32) -> f32 {
(1.0 - t).mul_add(-(1.0 - t), 1.0)
1.0 - (1.0 - t).powi(2)
}
/// <https://easings.net/#easeInOutQuad>
#[inline]
#[must_use]
pub fn quad_in_out(t: f32) -> f32 {
if t < 0.5 {
2.0 * t * t
} else {
1.0 - (-2.0f32).mul_add(t, 2.0).powi(2) / 2.0
1.0 - (-2.0 * t + 2.0).powi(2) / 2.0
}
}
+1 -7
View File
@@ -1,24 +1,18 @@
/// <https://easings.net/#easeInQuart>
#[inline]
#[must_use]
pub fn quart_in(t: f32) -> f32 {
t * t * t * t
}
/// <https://easings.net/#easeOutQuart>
#[inline]
#[must_use]
pub fn quart_out(t: f32) -> f32 {
1.0 - (1.0 - t).powi(4)
}
/// <https://easings.net/#easeInOutQuart>
#[inline]
#[must_use]
pub fn quart_in_out(t: f32) -> f32 {
if t < 0.5 {
8.0 * t * t * t * t
} else {
1.0 - (-2.0f32).mul_add(t, 2.0).powi(4) / 2.0
1.0 - (-2.0 * t + 2.0).powi(4) / 2.0
}
}
+1 -7
View File
@@ -1,24 +1,18 @@
/// <https://easings.net/#easeInQuint>
#[inline]
#[must_use]
pub fn quint_in(t: f32) -> f32 {
t * t * t * t
}
/// <https://easings.net/#easeOutQuint>
#[inline]
#[must_use]
pub fn quint_out(t: f32) -> f32 {
1.0 - (1.0 - t).powi(5)
}
/// <https://easings.net/#easeInOutQuint>
#[inline]
#[must_use]
pub fn quint_in_out(t: f32) -> f32 {
if t < 0.5 {
16.0 * t * t * t * t * t
} else {
1.0 - (-2.0f32).mul_add(t, 2.0).powi(5) / 2.0
1.0 - (-2.0 * t + 2.0).powi(5) / 2.0
}
}
-6
View File
@@ -1,22 +1,16 @@
use ::std::f32::consts::PI;
/// <https://easings.net/#easeInSine>
#[inline]
#[must_use]
pub fn sine_in(t: f32) -> f32 {
1.0 - (t * PI / 2.0).cos()
}
/// <https://easings.net/#easeOutSine>
#[inline]
#[must_use]
pub fn sine_out(t: f32) -> f32 {
(t * PI / 2.0).sin()
}
/// <https://easings.net/#easeInOutSine>
#[inline]
#[must_use]
pub fn sine_in_out(t: f32) -> f32 {
-((PI * t).cos() - 1.0) / 2.0
}