pub struct TouchSourceProxy { /* private fields */ }
Implementations§
Source§impl TouchSourceProxy
impl TouchSourceProxy
Sourcepub fn new(channel: AsyncChannel) -> Self
pub fn new(channel: AsyncChannel) -> Self
Create a new Proxy for fuchsia.ui.pointer/TouchSource.
Sourcepub fn take_event_stream(&self) -> TouchSourceEventStream
pub fn take_event_stream(&self) -> TouchSourceEventStream
Get a Stream of events from the remote end of the protocol.
§Panics
Panics if the event stream was already taken.
Sourcepub fn watch(
&self,
responses: &[TouchResponse],
) -> QueryResponseFut<Vec<TouchEvent>, DefaultFuchsiaResourceDialect>
pub fn watch( &self, responses: &[TouchResponse], ) -> QueryResponseFut<Vec<TouchEvent>, DefaultFuchsiaResourceDialect>
A method for a client to receive touch pointer events.
This call is formulated as a “hanging get” pattern: the client asks for a set of recent events, and receives them via the callback. This pull-based approach ensures that clients consume events at their own pace; events don’t clog up the channel in an unbounded manner.
Flow control. The caller is allowed at most one in-flight |Watch| call at a time; it is a logical error to have concurrent calls to |Watch|. Non-compliance results in channel closure.
Client pacing. The server will dispatch events to the caller on a FIFO, lossless, best-effort basis, but the caller must allocate enough time to keep up with new events. An unresponsive client may be categorized as “App Not Responding” and targeted for channel closure.
Responses. The gesture disambiguation scheme relies on the server
receiving a |TouchResponse| for each |TouchEvent|.|TouchPointerSample|;
non-sample events should return an empty |TouchResponse| table to the
server. Responses for previous events are fed to the server on the
next call of |Watch| [1]. Each element in the |responses| vector is
interpreted as the pairwise response to the event in the previous
|events| vector; the vector lengths must match. Note that the client’s
contract to respond to events starts as soon as it registers its
endpoint with scenic, NOT when it first calls Watch()
.
Initial response. The first call to |Watch| must be an empty vector.
Event times. The timestamps on each event in the event vector are not guaranteed monotonic; touch events from different devices may be injected into Scenic at different times. Generally, events from a single device are expected to have monotonically increasing timestamps.
View parameters. Occasionally, changes in view or viewport require notifying the client. If a |TouchEvent| carries |ViewParameters|, these parameters apply to successive |TouchPointerSample|s until the next |ViewParameters|.
[1] The hanging get pattern enables straightforward API evolution, but unfortunately does not admit an idiomatic matching of response to event.
Sourcepub fn update_response(
&self,
interaction: &TouchInteractionId,
response: &TouchResponse,
) -> QueryResponseFut<(), DefaultFuchsiaResourceDialect>
pub fn update_response( &self, interaction: &TouchInteractionId, response: &TouchResponse, ) -> QueryResponseFut<(), DefaultFuchsiaResourceDialect>
The gesture protocol allows a client to enact a “hold” on an open interaction of touch events; it prevents resolution of interaction ownership, even after the interaction closes. This method updates the client’s previous “hold” by replacing it with a response that allows ownership resolution to proceed.
See |TouchInteractionId| for how a stream is structured into interactions.
Flow control. The caller is allowed at most one |UpdateResponse| call per interaction, and it must be on a closed interaction. It is a logical error to call |UpdateResponse| when a normal response is possible with the |Watch| call.
Validity. This TouchResponse must not be another “hold” response, and the overwritten response is expected to be a “hold” response.
Trait Implementations§
Source§impl Clone for TouchSourceProxy
impl Clone for TouchSourceProxy
Source§fn clone(&self) -> TouchSourceProxy
fn clone(&self) -> TouchSourceProxy
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for TouchSourceProxy
impl Debug for TouchSourceProxy
Source§impl Proxy for TouchSourceProxy
impl Proxy for TouchSourceProxy
Source§type Protocol = TouchSourceMarker
type Protocol = TouchSourceMarker
Proxy
controls.Source§fn from_channel(inner: AsyncChannel) -> Self
fn from_channel(inner: AsyncChannel) -> Self
Source§fn into_channel(self) -> Result<AsyncChannel, Self>
fn into_channel(self) -> Result<AsyncChannel, Self>
Source§fn as_channel(&self) -> &AsyncChannel
fn as_channel(&self) -> &AsyncChannel
§fn into_client_end(self) -> Result<ClientEnd<Self::Protocol>, Self>
fn into_client_end(self) -> Result<ClientEnd<Self::Protocol>, Self>
Source§impl TouchSourceProxyInterface for TouchSourceProxy
impl TouchSourceProxyInterface for TouchSourceProxy
type WatchResponseFut = QueryResponseFut<Vec<TouchEvent>>
type UpdateResponseResponseFut = QueryResponseFut<()>
fn watch(&self, responses: &[TouchResponse]) -> Self::WatchResponseFut
fn update_response( &self, interaction: &TouchInteractionId, response: &TouchResponse, ) -> Self::UpdateResponseResponseFut
Auto Trait Implementations§
impl Freeze for TouchSourceProxy
impl !RefUnwindSafe for TouchSourceProxy
impl Send for TouchSourceProxy
impl Sync for TouchSourceProxy
impl Unpin for TouchSourceProxy
impl !UnwindSafe for TouchSourceProxy
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,
Source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)