Struct zng_ext_input::touch::TouchInputArgs

source ·
pub struct TouchInputArgs {
Show 13 fields pub timestamp: DInstant, pub window_id: WindowId, pub device_id: DeviceId, pub touch: TouchId, pub touch_propagation: EventPropagationHandle, pub position: DipPoint, pub force: Option<TouchForce>, pub velocity: DipVector, 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: DInstant

Instant the event happened.

§window_id: WindowId

Id of window that received the event.

§device_id: DeviceId

Id of device that generated the event.

§touch: TouchId

Identify 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: EventPropagationHandle

Propagation 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: DipPoint

Center of the touch in the window’s content area.

§force: Option<TouchForce>

Touch pressure force and angle.

§velocity: DipVector

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: TouchPhase

Touch phase.

Does not include Moved.

§hits: HitTestInfo

Hit-test result for the touch point in the window.

§target: InteractionPath

Full path to the top-most hit in hits.

§capture: Option<CaptureInfo>

Current pointer capture.

§modifiers: ModifiersState

What modifier keys where pressed when this event happened.

Implementations§

source§

impl TouchInputArgs

source

pub fn new( timestamp: impl Into<DInstant>, propagation_handle: EventPropagationHandle, window_id: impl Into<WindowId>, device_id: impl Into<DeviceId>, touch: impl Into<TouchId>, touch_propagation: impl Into<EventPropagationHandle>, position: impl Into<DipPoint>, force: impl Into<Option<TouchForce>>, velocity: impl Into<DipVector>, phase: impl Into<TouchPhase>, hits: impl Into<HitTestInfo>, target: impl Into<InteractionPath>, capture: impl Into<Option<CaptureInfo>>, modifiers: impl Into<ModifiersState>, ) -> Self

New args from values that convert into the argument types.

source

pub fn now( window_id: impl Into<WindowId>, device_id: impl Into<DeviceId>, touch: impl Into<TouchId>, touch_propagation: impl Into<EventPropagationHandle>, position: impl Into<DipPoint>, force: impl Into<Option<TouchForce>>, velocity: impl Into<DipVector>, phase: impl Into<TouchPhase>, hits: impl Into<HitTestInfo>, target: impl Into<InteractionPath>, capture: impl Into<Option<CaptureInfo>>, modifiers: impl Into<ModifiersState>, ) -> Self

Arguments for event that happened now (INSTANT.now).

source§

impl TouchInputArgs

source

pub fn capture_allows(&self) -> bool

If capture is None or allows the WIDGET to receive this event.

source

pub fn is_enabled(&self, widget_id: WidgetId) -> bool

If the widget_id is in the target is enabled.

source

pub fn is_disabled(&self, widget_id: WidgetId) -> bool

If the widget_id is in the target is disabled.

source

pub fn is_touch_start(&self) -> bool

If the phase is start.

source

pub fn is_touch_end(&self) -> bool

If the phase is end.

source

pub fn is_touch_cancel(&self) -> bool

If the phase is cancel.

source

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.
source

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.

Trait Implementations§

source§

impl AnyEventArgs for TouchInputArgs

source§

fn delivery_list(&self, list: &mut UpdateDeliveryList)

The target and capture.

source§

fn clone_any(&self) -> Box<dyn AnyEventArgs>

Clone the event into a type erased box.
source§

fn as_any(&self) -> &dyn Any

Access to dyn Any methods.
source§

fn timestamp(&self) -> DInstant

Gets the instant this event happened.
source§

fn propagation(&self) -> &EventPropagationHandle

Propagation handle associated with this event instance. Read more
source§

impl Clone for TouchInputArgs

source§

fn clone(&self) -> TouchInputArgs

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for TouchInputArgs

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl EventArgs for TouchInputArgs

source§

fn handle<F, R>(&self, handler: F) -> Option<R>
where F: FnOnce(&Self) -> R,

Calls handler and stops propagation if propagation is still allowed. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

source§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
source§

impl<T> StateValue for T
where T: Any + Send + Sync,