fidl_fuchsia_camera3

Enum Stream_Request

Source
pub enum Stream_Request {
Show 14 variants GetProperties { responder: Stream_GetPropertiesResponder, }, GetProperties2 { responder: Stream_GetProperties2Responder, }, SetCropRegion { region: Option<Box<RectF>>, control_handle: Stream_ControlHandle, }, WatchCropRegion { responder: Stream_WatchCropRegionResponder, }, SetResolution { coded_size: Size, control_handle: Stream_ControlHandle, }, WatchResolution { responder: Stream_WatchResolutionResponder, }, SetBufferCollection2 { token: Option<ClientEnd<BufferCollectionTokenMarker>>, control_handle: Stream_ControlHandle, }, SetBufferCollection { token: Option<ClientEnd<BufferCollectionTokenMarker>>, control_handle: Stream_ControlHandle, }, WatchBufferCollection2 { responder: Stream_WatchBufferCollection2Responder, }, WatchBufferCollection { responder: Stream_WatchBufferCollectionResponder, }, WatchOrientation { responder: Stream_WatchOrientationResponder, }, GetNextFrame { responder: Stream_GetNextFrameResponder, }, GetNextFrame2 { responder: Stream_GetNextFrame2Responder, }, Rebind { request: ServerEnd<Stream_Marker>, control_handle: Stream_ControlHandle, },
}
Expand description

A Stream represents timing, sequencing, and other camera-specific properties applied to a buffer collection.

Variants§

§

GetProperties

Gets the properties associated with this stream. The value returned is identical to the one corresponding to this stream as returned by |Device.GetConfigurations|.

§

GetProperties2

Gets the properties associated with this stream. The value returned is identical to the one corresponding to this stream as returned by |Device.GetConfigurations|.

§

SetCropRegion

Sets the Stream’s crop region to the provided region, with the top-left of the image represented by (0,0) and the bottom-right of the image represented by (1,1). The resulting content is subsequently scaled to fill the output buffer. If the implementation does not precisely support the provided value, it will be expanded to the minimum region that covers the provided region. If region is set to null, the crop region is unset, which is equivalent to specifying a region covering the entire image. Upon initial connection, the region is unset. If the stream does not support crop region, the connection is closed with the ZX_ERR_NOT_SUPPORTED epitaph.

Fields

§region: Option<Box<RectF>>
§control_handle: Stream_ControlHandle
§

WatchCropRegion

Returns the crop region if it has changed from a previously returned value, or is called by a client for the first time. Frame callbacks received after receiving this callback reflect the use of the new region. See SetCropRegion for a description of the region parameter.

§

SetResolution

Sets the resolution of the stream to the provided value. If the implementation does not precisely support the provided value, it will be expanded to the minimum resolution that exceeds the provided resolution.

Fields

§coded_size: Size
§control_handle: Stream_ControlHandle
§

WatchResolution

Returns the resolution if it has changed from a previously returned value, or is called by a client for the first time. Frame callbacks received after receiving this callback reflect the new resolution.

§

SetBufferCollection2

If non-null, requests renegotiation of the buffer collection backing this stream, and identifies this client as a participant in buffer negotiation. If null, identifies this client as a non-participant in buffer negotiation. Upon initial connection, the client is a non-participant. After registering as a participant, clients must always have an outstanding call to WatchBufferCollection to receive tokens from the server so that they are able to respond to current and future renegotiation requests.

Fields

§token: Option<ClientEnd<BufferCollectionTokenMarker>>
§control_handle: Stream_ControlHandle
§

SetBufferCollection

Fields

§token: Option<ClientEnd<BufferCollectionTokenMarker>>
§control_handle: Stream_ControlHandle
§

WatchBufferCollection2

Returns when the server or any buffer negotiation participant (including the current client) requires buffer renegotiation, and the current client is registered as a participant. Frame callbacks received after receiving this callback apply to the newly negotiated collection.

Because the camera can output directly to these collections, each client should support reading from a |fuchsia.sysmem.CoherencyDomain| of RAM, and set |ram_domain_supported| in their |fuchsia.sysmem.BufferMemoryConstraints|.

§

WatchBufferCollection

§

WatchOrientation

Returns the orientation if it has changed from a previously returned value, or is called by a client for the first time. Frame callbacks received after receiving this callback reflect the new orientation.

§

GetNextFrame

See GetNextFrame2.

§

GetNextFrame2

Request the next available frame for this stream that has not yet been acquired by the current client. Multiple participating clients may concurrently hold the same frame. Returns when the stream has completed populating the buffer and may be read by the client, provided the number of unreleased buffers is less than the count provided via the most recently negotiated buffer collection token. If a buffer renegotiation is in progress, this call will return only after the negotiation is complete and a new collection is available.

§

Rebind

Request another connection to this Stream. This allows a client to delegate different operations to different coordinated clients, or have multiple clients concurrently observe frames produced by the stream.

Fields

§request: ServerEnd<Stream_Marker>
§control_handle: Stream_ControlHandle

Implementations§

Trait Implementations§

Source§

impl Debug for Stream_Request

Source§

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

Formats the value using the given formatter. 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
§

impl<T, D> Encode<Ambiguous1, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
§

impl<T, D> Encode<Ambiguous2, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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.

§

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