ProjectionEncoderRef

Struct ProjectionEncoderRef 

Source
pub struct ProjectionEncoderRef<'a> { /* private fields */ }
Expand description

Borrowed wrapper around a projection encoder state.

Implementations§

Source§

impl<'a> ProjectionEncoderRef<'a>

Source

pub unsafe fn from_raw( ptr: *mut OpusProjectionEncoder, sample_rate: SampleRate, channels: u8, streams: u8, coupled_streams: u8, ) -> Self

Wrap an externally-initialized projection encoder without taking ownership.

§Safety
  • ptr must point to valid, initialized memory of at least ProjectionEncoder::size() bytes
  • ptr must be aligned to at least align_of::<usize>() (malloc-style alignment)
  • The memory must remain valid for the lifetime 'a
  • Caller is responsible for freeing the memory after this wrapper is dropped

Use ProjectionEncoder::init_in_place to initialize the memory before calling this.

Source

pub fn init_in( buf: &'a mut AlignedBuffer, sample_rate: SampleRate, channels: u8, mapping_family: i32, application: Application, ) -> Result<Self>

Initialize and wrap an externally allocated buffer.

§Errors

Returns Error::BadArg if the buffer is too small, or a mapped libopus error.

Methods from Deref<Target = ProjectionEncoder>§

Source

pub fn encode( &mut self, pcm: &[i16], frame_size_per_ch: usize, out: &mut [u8], ) -> Result<usize>

Encode interleaved i16 PCM.

§Errors

Returns Error::InvalidState if the encoder handle was freed, Error::BadArg for buffer/layout issues, the libopus error mapped via Error::from_code, or Error::InternalError if libopus reports an impossible packet length.

Source

pub fn encode_float( &mut self, pcm: &[f32], frame_size_per_ch: usize, out: &mut [u8], ) -> Result<usize>

Encode interleaved f32 PCM.

§Errors

Returns Error::InvalidState if the encoder handle was freed, Error::BadArg for buffer/layout issues, the libopus error mapped via Error::from_code, or Error::InternalError if libopus reports an impossible packet length.

Source

pub fn set_bitrate(&mut self, bitrate: Bitrate) -> Result<()>

Set target bitrate for the encoder.

§Errors

Returns Error::InvalidState if the encoder handle is invalid or a mapped libopus error.

Source

pub fn bitrate(&mut self) -> Result<Bitrate>

Query current bitrate configuration.

§Errors

Returns Error::InvalidState if the encoder handle is invalid or a mapped libopus error.

Source

pub fn demixing_matrix_size(&mut self) -> Result<i32>

Size in bytes of the current demixing matrix.

§Errors

Returns Error::InvalidState if the encoder handle is invalid or a mapped libopus error.

Source

pub fn demixing_matrix_gain(&mut self) -> Result<i32>

Gain (in Q8 dB) of the demixing matrix.

§Errors

Returns Error::InvalidState if the encoder handle is invalid or a mapped libopus error.

Source

pub fn write_demixing_matrix(&mut self, out: &mut [u8]) -> Result<usize>

Copy the demixing matrix into out and return the number of bytes written.

§Errors

Returns Error::InvalidState if the encoder handle is invalid, Error::BufferTooSmall when out cannot fit the matrix, a mapped libopus error, or Error::InternalError when libopus reports an invalid matrix size.

Source

pub fn demixing_matrix_bytes(&mut self) -> Result<Vec<u8>>

Convenience helper returning the demixing matrix as a newly allocated buffer.

§Errors

Propagates errors from Self::demixing_matrix_size and Self::write_demixing_matrix, including Error::InternalError if libopus reports impossible sizes.

Source

pub fn streams(&self) -> u8

Number of coded streams.

Source

pub fn coupled_streams(&self) -> u8

Number of coupled (stereo) coded streams.

Source

pub fn channels(&self) -> u8

Input channels passed to the encoder.

Source

pub fn sample_rate(&self) -> SampleRate

Encoder sample rate.

Trait Implementations§

Source§

impl Deref for ProjectionEncoderRef<'_>

Source§

type Target = ProjectionEncoder

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl DerefMut for ProjectionEncoderRef<'_>

Source§

fn deref_mut(&mut self) -> &mut Self::Target

Mutably dereferences the value.
Source§

impl Send for ProjectionEncoderRef<'_>

Source§

impl Sync for ProjectionEncoderRef<'_>

Auto Trait Implementations§

Blanket Implementations§

§

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

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

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

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

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

§

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

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

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

§

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<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
§

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

§

type Error = Infallible

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

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

Performs the conversion.
§

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

§

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

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

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

Performs the conversion.