pub struct TouchInputArgs {Show 13 fields
pub timestamp: DInstant,
pub window_id: WindowId,
pub device_id: InputDeviceId,
pub touch: TouchId,
pub touch_propagation: EventPropagationHandle,
pub position: Point2D<Dip, Dip>,
pub force: Option<TouchForce>,
pub velocity: Vector2D<Dip, Dip>,
pub phase: TouchPhase,
pub hits: HitTestInfo,
pub target: InteractionPath,
pub capture: Option<CaptureInfo>,
pub modifiers: ModifiersState,
/* private fields */
}Expand description
Arguments for TOUCH_INPUT_EVENT.
Fields§
§timestamp: DInstantInstant the event happened.
window_id: WindowIdId of window that received the event.
device_id: InputDeviceIdId of device that generated the event.
touch: TouchIdIdentify the touch contact or finger.
Multiple points of contact can happen in the same device at the same time, this ID identifies each uninterrupted contact. IDs are unique only among other concurrent touches on the same device, after a touch is ended an ID may be reused.
touch_propagation: EventPropagationHandlePropagation handle for the touch lifetime.
The TOUCH_INPUT_EVENT and TOUCH_MOVE_EVENT have their own separate propagation handles, but
touch gesture events aggregate all these events to produce a single gesture event, usually only a single
gesture should be generated, multiple gestures can disambiguate using this touch_propagation handle.
As an example, TOUCH_TAP_EVENT only tries to match the gesture if it has subscribers, and only notifies
if by the time the gesture completes the touch_propagation was not stopped. Touch gesture events or event properties
must stop touch propagation as soon as they commit to a gesture, a pan gesture for example, must stop as soon as
it starts scrolling, otherwise the user may accidentally scroll and tap a button at the same time.
The propagation handle always signals stopped after the touch ends. Handles are unique while at least one
clone of it remains, this makes this a better unique identifier of a touch contact than TouchId that may be reused
by the system as soon as a new touch contact is made.
position: Point2D<Dip, Dip>Center of the touch in the window’s content area.
force: Option<TouchForce>Touch pressure force and angle.
velocity: Vector2D<Dip, Dip>Velocity in device independent pixels per second.
This is always zero on Start and Cancel and is the last move velocity for End. Note that
the velocity value can be less than min_fling_velocity.
phase: TouchPhaseTouch phase.
Does not include Moved.
hits: HitTestInfoHit-test result for the touch point in the window.
target: InteractionPathFull path to the top-most hit in hits.
capture: Option<CaptureInfo>Current pointer capture.
modifiers: ModifiersStateWhat modifier keys where pressed when this event happened.
Implementations§
Source§impl TouchInputArgs
impl TouchInputArgs
Sourcepub fn new(
timestamp: impl Into<DInstant>,
propagation_handle: EventPropagationHandle,
window_id: impl Into<WindowId>,
device_id: impl Into<InputDeviceId>,
touch: impl Into<TouchId>,
touch_propagation: impl Into<EventPropagationHandle>,
position: impl Into<Point2D<Dip, Dip>>,
force: impl Into<Option<TouchForce>>,
velocity: impl Into<Vector2D<Dip, Dip>>,
phase: impl Into<TouchPhase>,
hits: impl Into<HitTestInfo>,
target: impl Into<InteractionPath>,
capture: impl Into<Option<CaptureInfo>>,
modifiers: impl Into<ModifiersState>,
) -> TouchInputArgs
pub fn new( timestamp: impl Into<DInstant>, propagation_handle: EventPropagationHandle, window_id: impl Into<WindowId>, device_id: impl Into<InputDeviceId>, touch: impl Into<TouchId>, touch_propagation: impl Into<EventPropagationHandle>, position: impl Into<Point2D<Dip, Dip>>, force: impl Into<Option<TouchForce>>, velocity: impl Into<Vector2D<Dip, Dip>>, phase: impl Into<TouchPhase>, hits: impl Into<HitTestInfo>, target: impl Into<InteractionPath>, capture: impl Into<Option<CaptureInfo>>, modifiers: impl Into<ModifiersState>, ) -> TouchInputArgs
New args from values that convert into the argument types.
Sourcepub fn now(
window_id: impl Into<WindowId>,
device_id: impl Into<InputDeviceId>,
touch: impl Into<TouchId>,
touch_propagation: impl Into<EventPropagationHandle>,
position: impl Into<Point2D<Dip, Dip>>,
force: impl Into<Option<TouchForce>>,
velocity: impl Into<Vector2D<Dip, Dip>>,
phase: impl Into<TouchPhase>,
hits: impl Into<HitTestInfo>,
target: impl Into<InteractionPath>,
capture: impl Into<Option<CaptureInfo>>,
modifiers: impl Into<ModifiersState>,
) -> TouchInputArgs
pub fn now( window_id: impl Into<WindowId>, device_id: impl Into<InputDeviceId>, touch: impl Into<TouchId>, touch_propagation: impl Into<EventPropagationHandle>, position: impl Into<Point2D<Dip, Dip>>, force: impl Into<Option<TouchForce>>, velocity: impl Into<Vector2D<Dip, Dip>>, phase: impl Into<TouchPhase>, hits: impl Into<HitTestInfo>, target: impl Into<InteractionPath>, capture: impl Into<Option<CaptureInfo>>, modifiers: impl Into<ModifiersState>, ) -> TouchInputArgs
Arguments for event that happened now (INSTANT.now).
Source§impl TouchInputArgs
impl TouchInputArgs
Sourcepub fn capture_allows(&self) -> bool
pub fn capture_allows(&self) -> bool
Sourcepub fn is_touch_start(&self) -> bool
pub fn is_touch_start(&self) -> bool
If the phase is start.
Sourcepub fn is_touch_end(&self) -> bool
pub fn is_touch_end(&self) -> bool
If the phase is end.
Sourcepub fn is_touch_cancel(&self) -> bool
pub fn is_touch_cancel(&self) -> bool
If the phase is cancel.
Sourcepub fn inertia_x(&self, friction: Dip) -> (Dip, Duration)
pub fn inertia_x(&self, friction: Dip) -> (Dip, Duration)
Compute the final offset and duration for a fling animation that simulates inertia movement from the
velocity.x and friction. Returns 0 if velocity less than min_fling_velocity.
Friction is in dips decelerated per second.
To animate a point using these values:
- Compute the final point by adding the vector offset to the current point.
- Animate using the duration linear interpolation.
Sourcepub fn inertia_y(&self, friction: Dip) -> (Dip, Duration)
pub fn inertia_y(&self, friction: Dip) -> (Dip, Duration)
Compute the final offset and duration for a fling animation that simulates inertia movement from the
velocity.y and friction. Returns 0 if velocity less than min_fling_velocity.
Friction is in dips decelerated per second.
Sourcepub fn position_wgt(&self) -> Option<Point2D<Px, Px>>
pub fn position_wgt(&self) -> Option<Point2D<Px, Px>>
Gets position in the widget inner bounds.
Trait Implementations§
Source§impl AnyEventArgs for TouchInputArgs
impl AnyEventArgs for TouchInputArgs
Source§fn delivery_list(&self, list: &mut UpdateDeliveryList)
fn delivery_list(&self, list: &mut UpdateDeliveryList)
Source§fn clone_any(&self) -> Box<dyn AnyEventArgs>
fn clone_any(&self) -> Box<dyn AnyEventArgs>
Source§fn propagation(&self) -> &EventPropagationHandle
fn propagation(&self) -> &EventPropagationHandle
Source§impl Clone for TouchInputArgs
impl Clone for TouchInputArgs
Source§fn clone(&self) -> TouchInputArgs
fn clone(&self) -> TouchInputArgs
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for TouchInputArgs
impl Debug for TouchInputArgs
Auto Trait Implementations§
impl Freeze for TouchInputArgs
impl RefUnwindSafe for TouchInputArgs
impl Send for TouchInputArgs
impl Sync for TouchInputArgs
impl Unpin for TouchInputArgs
impl UnwindSafe for TouchInputArgs
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> FsChangeNote for T
impl<T> FsChangeNote for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more