mirror of https://github.com/emilk/egui.git
Emil Ernerfeldt
6 years ago
6 changed files with 216 additions and 56 deletions
@ -0,0 +1,90 @@ |
|||
#[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) |
|||
} |
Loading…
Reference in new issue