91 lines
1.9 KiB
Rust
91 lines
1.9 KiB
Rust
![]() |
#[derive(Clone, Copy, Debug, Default, Deserialize, Serialize)]
|
||
|
pub struct Vec2 {
|
||
|
pub x: f32,
|
||
|
pub y: f32,
|
||
|
}
|
||
|
|
||
|
impl std::ops::Add for Vec2 {
|
||
|
type Output = Vec2;
|
||
|
fn add(self, rhs: Vec2) -> Vec2 {
|
||
|
Vec2 {
|
||
|
x: self.x + rhs.x,
|
||
|
y: self.y + rhs.y,
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
impl std::ops::Sub for Vec2 {
|
||
|
type Output = Vec2;
|
||
|
fn sub(self, rhs: Vec2) -> Vec2 {
|
||
|
Vec2 {
|
||
|
x: self.x - rhs.x,
|
||
|
y: self.y - rhs.y,
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
impl std::ops::Mul<f32> for Vec2 {
|
||
|
type Output = Vec2;
|
||
|
fn mul(self, factor: f32) -> Vec2 {
|
||
|
Vec2 {
|
||
|
x: self.x * factor,
|
||
|
y: self.y * factor,
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
pub fn vec2(x: f32, y: f32) -> Vec2 {
|
||
|
Vec2 { x, y }
|
||
|
}
|
||
|
|
||
|
#[derive(Clone, Copy, Debug, Default, Deserialize, Serialize)]
|
||
|
pub struct Rect {
|
||
|
pub pos: Vec2,
|
||
|
pub size: Vec2,
|
||
|
}
|
||
|
|
||
|
impl Rect {
|
||
|
pub fn from_center_size(center: Vec2, size: Vec2) -> Self {
|
||
|
Rect {
|
||
|
pos: center - size * 0.5,
|
||
|
size,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
pub fn contains(&self, p: Vec2) -> bool {
|
||
|
self.pos.x <= p.x
|
||
|
&& p.x <= self.pos.x + self.size.x
|
||
|
&& self.pos.y <= p.y
|
||
|
&& p.y <= self.pos.y + self.size.y
|
||
|
}
|
||
|
|
||
|
pub fn center(&self) -> Vec2 {
|
||
|
Vec2 {
|
||
|
x: self.pos.x + self.size.x / 2.0,
|
||
|
y: self.pos.y + self.size.y / 2.0,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
pub fn min(&self) -> Vec2 {
|
||
|
self.pos
|
||
|
}
|
||
|
pub fn max(&self) -> Vec2 {
|
||
|
self.pos + self.size
|
||
|
}
|
||
|
}
|
||
|
|
||
|
pub fn lerp(t: f32, min: f32, max: f32) -> f32 {
|
||
|
(1.0 - t) * min + t * max
|
||
|
}
|
||
|
|
||
|
pub fn remap_clamp(from: f32, from_min: f32, from_max: f32, to_min: f32, to_max: f32) -> f32 {
|
||
|
let t = if from <= from_min {
|
||
|
0.0
|
||
|
} else if from >= from_max {
|
||
|
1.0
|
||
|
} else {
|
||
|
(from - from_min) / (from_max - from_min)
|
||
|
};
|
||
|
lerp(t, to_min, to_max)
|
||
|
}
|