[window] better mouse velocity tracking for throwing windows
This commit is contained in:
parent
598564cecc
commit
506dd11f73
2 changed files with 24 additions and 9 deletions
|
@ -224,6 +224,12 @@ impl MouseInput {
|
|||
could_be_click = false;
|
||||
}
|
||||
|
||||
if self.pressed {
|
||||
// Start of a drag: we want to track the velocity for during the drag
|
||||
// and ignore any incoming movement
|
||||
self.pos_tracker.clear();
|
||||
}
|
||||
|
||||
if let Some(mouse_pos) = new.mouse_pos {
|
||||
self.pos_tracker.add(new.time, mouse_pos);
|
||||
} else {
|
||||
|
@ -232,7 +238,12 @@ impl MouseInput {
|
|||
// the user tried to throw
|
||||
}
|
||||
|
||||
let velocity = self.pos_tracker.velocity_noew(new.time).unwrap_or_default();
|
||||
self.pos_tracker.flush(new.time);
|
||||
let velocity = if self.pos_tracker.len() >= 3 && self.pos_tracker.dt() > 0.01 {
|
||||
self.pos_tracker.velocity().unwrap_or_default()
|
||||
} else {
|
||||
Vec2::default()
|
||||
};
|
||||
|
||||
MouseInput {
|
||||
down: new.mouse_down && new.mouse_pos.is_some(),
|
||||
|
|
|
@ -33,6 +33,15 @@ where
|
|||
self.values.len()
|
||||
}
|
||||
|
||||
/// Amount of time contained from start to end in this `MovementTracker`
|
||||
pub fn dt(&self) -> f32 {
|
||||
if let (Some(front), Some(back)) = (self.values.front(), self.values.back()) {
|
||||
(back.0 - front.0) as f32
|
||||
} else {
|
||||
0.0
|
||||
}
|
||||
}
|
||||
|
||||
pub fn values<'a>(&'a self) -> impl Iterator<Item = T> + 'a {
|
||||
self.values.iter().map(|(_time, value)| *value)
|
||||
}
|
||||
|
@ -64,7 +73,8 @@ where
|
|||
}
|
||||
}
|
||||
|
||||
fn flush(&mut self, now: f64) {
|
||||
/// Remove samples that are too old
|
||||
pub fn flush(&mut self, now: f64) {
|
||||
while self.values.len() > self.max_len {
|
||||
self.values.pop_front();
|
||||
}
|
||||
|
@ -104,14 +114,8 @@ where
|
|||
T: std::ops::Sub<Output = Vel>,
|
||||
Vel: std::ops::Div<f32, Output = Vel>,
|
||||
{
|
||||
/// Calculate a smooth velocity (per second) from start until now
|
||||
pub fn velocity_noew(&mut self, now: f64) -> Option<Vel> {
|
||||
self.flush(now);
|
||||
self.velocity_all()
|
||||
}
|
||||
|
||||
/// Calculate a smooth velocity (per second) over the entire time span
|
||||
pub fn velocity_all(&self) -> Option<Vel> {
|
||||
pub fn velocity(&self) -> Option<Vel> {
|
||||
if let (Some(first), Some(last)) = (self.values.front(), self.values.back()) {
|
||||
let dt = (last.0 - first.0) as f32;
|
||||
if dt > 0.0 {
|
||||
|
|
Loading…
Reference in a new issue