diff --git a/crates/egui/src/containers/scroll_area.rs b/crates/egui/src/containers/scroll_area.rs index b7da4bf8528..3b3925c9dcd 100644 --- a/crates/egui/src/containers/scroll_area.rs +++ b/crates/egui/src/containers/scroll_area.rs @@ -640,15 +640,8 @@ impl ScrollArea { .as_ref() .is_some_and(|response| response.drag_stopped()) { - for d in 0..2 { - if scroll_enabled[d] { - ui.input(|input| { - state.vel[d] = input.pointer.velocity()[d]; - }); - } else { - state.vel[d] = 0.0; - } - } + state.vel = + scroll_enabled.to_vec2() * ui.input(|input| input.pointer.velocity()); } for d in 0..2 { // Kinetic scrolling diff --git a/crates/emath/src/vec2b.rs b/crates/emath/src/vec2b.rs index f241de64ed5..673f2959e0f 100644 --- a/crates/emath/src/vec2b.rs +++ b/crates/emath/src/vec2b.rs @@ -1,3 +1,5 @@ +use crate::Vec2; + /// Two bools, one for each axis (X and Y). #[derive(Copy, Clone, Debug, Default, PartialEq, Eq)] #[cfg_attr(feature = "serde", derive(serde::Deserialize, serde::Serialize))] @@ -43,6 +45,12 @@ impl Vec2b { y: self.y || other.y, } } + + /// Convert to a float `Vec2` where the components are 1.0 for `true` and 0.0 for `false`. + #[inline] + pub fn to_vec2(self) -> Vec2 { + Vec2::new(self.x.into(), self.y.into()) + } } impl From for Vec2b {