pub struct AudioConsumerProxy { /* private fields */ }
Implementations§
Source§impl AudioConsumerProxy
impl AudioConsumerProxy
Sourcepub fn take_event_stream(&self) -> AudioConsumerEventStream
pub fn take_event_stream(&self) -> AudioConsumerEventStream
Get a Stream of events from the remote end of the protocol.
§Panics
Panics if the event stream was already taken.
Sourcepub fn create_stream_sink(
&self,
buffers: Vec<Vmo>,
stream_type: &AudioStreamType,
compression: Option<&Compression>,
stream_sink_request: ServerEnd<StreamSinkMarker>,
) -> Result<(), Error>
pub fn create_stream_sink( &self, buffers: Vec<Vmo>, stream_type: &AudioStreamType, compression: Option<&Compression>, stream_sink_request: ServerEnd<StreamSinkMarker>, ) -> Result<(), Error>
Creates a StreamSink
for the consumer with the indicated properties.
Multiple stream sinks may be acquired using this method, but they are intended to be used
sequentially rather than concurrently. The first stream sink that’s created using this
method is used as the sole source of packets incoming to the logical consumer until that
stream sink is closed or the EndOfStream
method is called on that sink. At that point,
the second stream sink is used, and so on.
If an unsupported compression type is supplied, the
stream_sink_request
request will be closed with an epitaph value of
ZX_ERR_INVALID_ARGS
.
Sourcepub fn start(
&self,
flags: AudioConsumerStartFlags,
reference_time: i64,
media_time: i64,
) -> Result<(), Error>
pub fn start( &self, flags: AudioConsumerStartFlags, reference_time: i64, media_time: i64, ) -> Result<(), Error>
Starts rendering as indicated by flags
.
media_time
indicates the packet timestamp that corresponds to reference_time
.
Typically, this is the timestamp of the first packet that will be
rendered. If packets will be supplied with no timestamps, this value
should be NO_TIMESTAMP
. Passing a media_time
value of
NO_TIMESTAMP
chooses the default media time, established as follows:
1. When starting for the first time, the default media time is the
timestamp on the first packet sent to the stream sink.
2. When resuming after stop, the default media time is the media
time at which the stream stopped.
reference_time
is the monotonic system time at which rendering should
be started. For supply-driven sources, this must be the time at which
the first packet was (or will be) sent plus a lead time, which must be
in the range indicated in the AudioConsumerStatus
. For demand-driven
sources, the client must ensure that the lead time requirement is met at
the start time. Passing the default value of 0 for reference_time
causes the consumer to choose a start time based on the availability of
packets, the lead time requirements, and whether LOW_LATENCY
has been
specified.
The actual start time will be reflected in the updated status.
Sourcepub fn stop(&self) -> Result<(), Error>
pub fn stop(&self) -> Result<(), Error>
Stops rendering as soon as possible after this method is called. The actual stop time will be reflected in the updated status.
Sourcepub fn set_rate(&self, rate: f32) -> Result<(), Error>
pub fn set_rate(&self, rate: f32) -> Result<(), Error>
Requests to change the playback rate of the renderer. 1.0 means normal
playback. Negative rates are not supported. The new rate will be
reflected in the updated status. The default rate of any newly created StreamSink
is 1.0.
Sourcepub fn bind_volume_control(
&self,
volume_control_request: ServerEnd<VolumeControlMarker>,
) -> Result<(), Error>
pub fn bind_volume_control( &self, volume_control_request: ServerEnd<VolumeControlMarker>, ) -> Result<(), Error>
Binds to this AudioConsumer
volume control for control and notifications.
Sourcepub fn watch_status(
&self,
) -> QueryResponseFut<AudioConsumerStatus, DefaultFuchsiaResourceDialect>
pub fn watch_status( &self, ) -> QueryResponseFut<AudioConsumerStatus, DefaultFuchsiaResourceDialect>
Gets the current status of the consumer using the long get pattern. The consumer responds to this method when the status changes - initially with respect to the initial status value and thereafter with respect to the previously-reported status value.
Trait Implementations§
Source§impl AudioConsumerProxyInterface for AudioConsumerProxy
impl AudioConsumerProxyInterface for AudioConsumerProxy
type WatchStatusResponseFut = QueryResponseFut<AudioConsumerStatus>
fn create_stream_sink( &self, buffers: Vec<Vmo>, stream_type: &AudioStreamType, compression: Option<&Compression>, stream_sink_request: ServerEnd<StreamSinkMarker>, ) -> Result<(), Error>
fn start( &self, flags: AudioConsumerStartFlags, reference_time: i64, media_time: i64, ) -> Result<(), Error>
fn stop(&self) -> Result<(), Error>
fn set_rate(&self, rate: f32) -> Result<(), Error>
fn bind_volume_control( &self, volume_control_request: ServerEnd<VolumeControlMarker>, ) -> Result<(), Error>
fn watch_status(&self) -> Self::WatchStatusResponseFut
Source§impl Clone for AudioConsumerProxy
impl Clone for AudioConsumerProxy
Source§fn clone(&self) -> AudioConsumerProxy
fn clone(&self) -> AudioConsumerProxy
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for AudioConsumerProxy
impl Debug for AudioConsumerProxy
Source§impl Proxy for AudioConsumerProxy
impl Proxy for AudioConsumerProxy
Source§type Protocol = AudioConsumerMarker
type Protocol = AudioConsumerMarker
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>
Auto Trait Implementations§
impl Freeze for AudioConsumerProxy
impl !RefUnwindSafe for AudioConsumerProxy
impl Send for AudioConsumerProxy
impl Sync for AudioConsumerProxy
impl Unpin for AudioConsumerProxy
impl !UnwindSafe for AudioConsumerProxy
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
)