[][src]Enum gstreamer_audio::AudioChannelPosition

#[non_exhaustive]pub enum AudioChannelPosition {
    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.

AudioChannelPosition::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.

AudioChannelPosition::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: &[AudioChannelPosition],
    force_order: bool
) -> Result<u64, BoolError>
[src]

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

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

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

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

Trait Implementations

impl Clone for AudioChannelPosition[src]

impl Copy for AudioChannelPosition[src]

impl Debug for AudioChannelPosition[src]

impl Eq for AudioChannelPosition[src]

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

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

impl Hash for AudioChannelPosition[src]

impl Ord for AudioChannelPosition[src]

impl PartialEq<AudioChannelPosition> for AudioChannelPosition[src]

impl PartialOrd<AudioChannelPosition> for AudioChannelPosition[src]

impl SetValue for AudioChannelPosition[src]

impl StaticType 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]

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

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

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

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

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

type Owned = T

The resulting type after obtaining ownership.

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

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

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.

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.