mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-22 21:30:56 +00:00
refactor(core/rust): replace TouchAbort event with explicit abort via a detected swipe
worth considering: pub enum Phase { Start, Move, End, } pub enum TouchEvent { Touch(Phase, Point), Swipe(Phase, Point), } (Swipe needs its own Phase because it needs a progress on the Move, but otherwise...)
This commit is contained in:
parent
943d6d9b30
commit
9f083c1865
@ -14,8 +14,6 @@ pub enum TouchEvent {
|
||||
TouchMove(Point),
|
||||
/// Touch has ended at a point on the screen.
|
||||
TouchEnd(Point),
|
||||
/// Touch event has been suppressed by more important event - i.e. Swipe.
|
||||
TouchAbort,
|
||||
}
|
||||
|
||||
impl TouchEvent {
|
||||
@ -34,6 +32,7 @@ impl TouchEvent {
|
||||
#[derive(Copy, Clone, PartialEq, Eq)]
|
||||
#[cfg_attr(feature = "debug", derive(ufmt::derive::uDebug))]
|
||||
pub enum SwipeEvent {
|
||||
Start(Direction),
|
||||
Move(Direction, i16),
|
||||
End(Direction),
|
||||
}
|
||||
|
@ -223,7 +223,7 @@ impl SwipeFlow {
|
||||
Some(SwipeDetectMsg::Move(dir, progress)) => {
|
||||
Event::Swipe(SwipeEvent::Move(dir, progress as i16))
|
||||
}
|
||||
Some(SwipeDetectMsg::Start(_)) => Event::Touch(TouchEvent::TouchAbort),
|
||||
Some(SwipeDetectMsg::Start(dir)) => Event::Swipe(SwipeEvent::Start(dir)),
|
||||
None => event,
|
||||
}
|
||||
} else {
|
||||
|
@ -353,7 +353,8 @@ impl Component for Button {
|
||||
}
|
||||
}
|
||||
}
|
||||
Event::Touch(TouchEvent::TouchAbort) => {
|
||||
Event::Swipe(_) => {
|
||||
// When a swipe is detected, abort any ongoing touch.
|
||||
match self.state {
|
||||
State::Initial | State::Disabled => {
|
||||
// Do nothing.
|
||||
|
@ -185,7 +185,6 @@ impl Component for NumberInputSlider {
|
||||
ctx.request_paint();
|
||||
self.touch_eval(pos, ctx, true)
|
||||
}
|
||||
TouchEvent::TouchAbort => None,
|
||||
};
|
||||
}
|
||||
None
|
||||
|
@ -56,7 +56,7 @@ impl<T: Swipable + Component> Component for SwipeUpScreen<T> {
|
||||
Some(SwipeDetectMsg::Move(dir, progress)) => {
|
||||
Event::Swipe(SwipeEvent::Move(dir, progress as i16))
|
||||
}
|
||||
Some(SwipeDetectMsg::Start(_)) => Event::Touch(TouchEvent::TouchAbort),
|
||||
Some(SwipeDetectMsg::Start(dir)) => Event::Swipe(SwipeEvent::Start(dir)),
|
||||
_ => event,
|
||||
};
|
||||
|
||||
|
@ -147,7 +147,6 @@ impl Component for NumberInputSlider {
|
||||
TouchEvent::TouchStart(pos) => self.slider_eval(pos, ctx),
|
||||
TouchEvent::TouchMove(pos) => self.slider_eval(pos, ctx),
|
||||
TouchEvent::TouchEnd(pos) => self.slider_eval(pos, ctx),
|
||||
TouchEvent::TouchAbort => None,
|
||||
};
|
||||
}
|
||||
None
|
||||
|
Loading…
Reference in New Issue
Block a user