Enum gstreamer_audio::AudioChannelPosition[][src]

#[non_exhaustive]
pub enum AudioChannelPosition {
Show variants None, Mono, Invalid, FrontLeft, FrontRight, FrontCenter, Lfe1, RearLeft, RearRight, FrontLeftOfCenter, FrontRightOfCenter, RearCenter, Lfe2, SideLeft, SideRight, TopFrontLeft, TopFrontRight, TopFrontCenter, TopCenter, TopRearLeft, TopRearRight, TopSideLeft, TopSideRight, TopRearCenter, BottomFrontCenter, BottomFrontLeft, BottomFrontRight, WideLeft, WideRight, SurroundLeft, SurroundRight, // some variants omitted
}
[]

Audio channel positions.

These are the channels defined in SMPTE 2036-2-2008 Table 1 for 22.2 audio systems with the Surround and Wide channels from DTS Coherent Acoustics (v.1.3.1) and 10.2 and 7.1 layouts. In the caps the actual channel layout is expressed with a channel count and a channel mask, which describes the existing channels. The positions in the bit mask correspond to the enum values. For negotiation it is allowed to have more bits set in the channel mask than the number of channels to specify the allowed channel positions but this is not allowed in negotiated caps. It is not allowed in any situation other than the one mentioned below to have less bits set in the channel mask than the number of channels.

Self::Mono can only be used with a single mono channel that has no direction information and would be mixed into all directional channels. This is expressed in caps by having a single channel and no channel mask.

Self::None can only be used if all channels have this position. This is expressed in caps by having a channel mask with no bits set.

As another special case it is allowed to have two channels without a channel mask. This implicitly means that this is a stereo stream with a front left and front right channel.

Variants (Non-exhaustive)

Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
None
[]

used for position-less channels, e.g. from a sound card that records 1024 channels; mutually exclusive with any other channel position

Mono
[]

Mono without direction; can only be used with 1 channel

Invalid
[]

invalid position

FrontLeft
[]

Front left

FrontRight
[]

Front right

FrontCenter
[]

Front center

Lfe1
[]

Low-frequency effects 1 (subwoofer)

RearLeft
[]

Rear left

RearRight
[]

Rear right

FrontLeftOfCenter
[]

Front left of center

FrontRightOfCenter
[]

Front right of center

RearCenter
[]

Rear center

Lfe2
[]

Low-frequency effects 2 (subwoofer)

SideLeft
[]

Side left

SideRight
[]

Side right

TopFrontLeft
[]

Top front left

TopFrontRight
[]

Top front right

TopFrontCenter
[]

Top front center

TopCenter
[]

Top center

TopRearLeft
[]

Top rear left

TopRearRight
[]

Top rear right

TopSideLeft
[]

Top side right

TopSideRight
[]

Top rear right

TopRearCenter
[]

Top rear center

BottomFrontCenter
[]

Bottom front center

BottomFrontLeft
[]

Bottom front left

BottomFrontRight
[]

Bottom front right

WideLeft
[]

Wide left (between front left and side left)

WideRight
[]

Wide right (between front right and side right)

SurroundLeft
[]

Surround left (between rear left and side left)

SurroundRight
[]

Surround right (between rear right and side right)

Implementations

impl AudioChannelPosition[src]

pub fn to_mask(self) -> u64[src]

pub fn positions_to_mask(
    positions: &[Self],
    force_order: bool
) -> Result<u64, BoolError>
[src]

pub fn positions_from_mask(
    mask: u64,
    positions: &mut [Self]
) -> Result<(), BoolError>
[src]

pub fn positions_to_valid_order(positions: &mut [Self]) -> Result<(), BoolError>[src]

pub fn fallback_mask(channels: u32) -> u64[src]

pub fn check_valid_channel_positions(
    positions: &[Self],
    force_order: bool
) -> bool
[src]

Trait Implementations

impl Clone for AudioChannelPosition[src]

fn clone(&self) -> AudioChannelPosition[src]

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

impl Debug for AudioChannelPosition[src]

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

Formats the value using the given formatter. Read more

impl<'a> FromValue<'a> for AudioChannelPosition[src]

type Checker = GenericValueTypeChecker<Self>

Value type checker.

unsafe fn from_value(value: &'a Value) -> Self[src]

Get the contained value from a Value. Read more

impl Hash for AudioChannelPosition[src]

fn hash<__H: Hasher>(&self, state: &mut __H)[src]

Feeds this value into the given Hasher. Read more

fn hash_slice<H>(data: &[Self], state: &mut H) where
    H: Hasher
1.3.0[src]

Feeds a slice of this type into the given Hasher. Read more

impl Ord for AudioChannelPosition[src]

fn cmp(&self, other: &AudioChannelPosition) -> Ordering[src]

This method returns an Ordering between self and other. Read more

#[must_use]
fn max(self, other: Self) -> Self
1.21.0[src]

Compares and returns the maximum of two values. Read more

#[must_use]
fn min(self, other: Self) -> Self
1.21.0[src]

Compares and returns the minimum of two values. Read more

#[must_use]
fn clamp(self, min: Self, max: Self) -> Self
1.50.0[src]

Restrict a value to a certain interval. Read more

impl PartialEq<AudioChannelPosition> for AudioChannelPosition[src]

fn eq(&self, other: &AudioChannelPosition) -> bool[src]

This method tests for self and other values to be equal, and is used by ==. Read more

fn ne(&self, other: &AudioChannelPosition) -> bool[src]

This method tests for !=.

impl PartialOrd<AudioChannelPosition> for AudioChannelPosition[src]

fn partial_cmp(&self, other: &AudioChannelPosition) -> Option<Ordering>[src]

This method returns an ordering between self and other values if one exists. Read more

#[must_use]
fn lt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than (for self and other) and is used by the < operator. Read more

#[must_use]
fn le(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more

#[must_use]
fn gt(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than (for self and other) and is used by the > operator. Read more

#[must_use]
fn ge(&self, other: &Rhs) -> bool
1.0.0[src]

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more

impl StaticType for AudioChannelPosition[src]

fn static_type() -> Type[src]

Returns the type identifier of Self.

impl ToValue for AudioChannelPosition[src]

fn to_value(&self) -> Value[src]

Convert a value to a Value.

fn value_type(&self) -> Type[src]

Returns the type identifer of self. Read more

impl ValueType for AudioChannelPosition[src]

type Type = Self

Type to get the Type from. Read more

impl Copy for AudioChannelPosition[src]

impl Eq for AudioChannelPosition[src]

impl StructuralEq for AudioChannelPosition[src]

impl StructuralPartialEq for AudioChannelPosition[src]

Auto Trait Implementations

impl RefUnwindSafe for AudioChannelPosition

impl Send for AudioChannelPosition

impl Sync for AudioChannelPosition

impl Unpin for AudioChannelPosition

impl UnwindSafe for AudioChannelPosition

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

pub fn to_owned(&self) -> T[src]

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

pub fn clone_into(&self, target: &mut T)[src]

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

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

impl<T> ToSendValue for T where
    T: Send + ToValue + ?Sized
[src]

pub fn to_send_value(&self) -> SendValue[src]

Returns a SendValue clone of self.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

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

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

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

Performs the conversion.