MTAudioProcessingTap

Struct MTAudioProcessingTap 

Source
pub struct MTAudioProcessingTap { /* private fields */ }
Available on crate feature MTAudioProcessingTap only.
Expand description

Implementations§

Source§

impl MTAudioProcessingTap

Source

pub unsafe fn create( allocator: Option<&CFAllocator>, callbacks: NonNull<MTAudioProcessingTapCallbacks>, flags: MTAudioProcessingTapCreationFlags, tap_out: NonNull<*const MTAudioProcessingTap>, ) -> i32

Available on crate features objc2-core-audio-types and objc2-core-media only.

Create a new processing tap.

This function creates a processing tap. The processing tap will then be used to process decoded data. The processing is performed on audio either before or after any effects or other processing (varispeed, etc) is applied by the audio queue.

Parameter allocator: The allocator to use to allocate memory for the new tap. Pass NULL or kCFAllocatorDefault to use the current default allocator.

Parameter callbacks: Callbacks struct. MTAudioProcessingTap will make a copy of this struct.

Parameter flags: Flags that are used to control aspects of the processing tap. Valid flags are:

  • kMTAudioProcessingTapCreationFlag_PreEffects: processing is done before any further effects are applied by the audio queue to the audio.
  • kMTAudioProcessingTapCreationFlag_PostEffects: processing is done after all processing is done, including that of other taps.

Parameter tapOut: The processing tap object.

Returns: An OSStatus result code.

§Safety
  • callbacks must be a valid pointer.
  • tap_out must be a valid pointer.
Source

pub unsafe fn storage(&self) -> NonNull<c_void>

Used by a processing tap to retrieve a custom storage pointer.

Parameter tap: The processing tap.

Returns: The tapStorage returned by the init callback.

Source

pub unsafe fn source_audio( &self, number_frames: CMItemCount, buffer_list_in_out: NonNull<AudioBufferList>, flags_out: *mut MTAudioProcessingTapFlags, time_range_out: *mut CMTimeRange, number_frames_out: *mut CMItemCount, ) -> i32

Available on crate features objc2-core-audio-types and objc2-core-media only.

Used by a processing tap to retrieve source audio.

This function may only be called from the processing tap’s callback.

Parameter tap: The processing tap.

Parameter numberFrames: The number of frames the processing tap requires for its processing.

Parameter bufferListInOut: The audio buffer list which will contain the source data. On input, all fields except for the buffer pointers must be filled in. If the buffer pointers are NULL (recommended), non-NULL pointers will be returned and system owns the source buffers; these buffers are only applicable for the duration of the processing tap callback. If the buffer pointers are non-NULL, then they must be big enough to hold numberFrames, and the source data will be copied into these buffers.

Parameter flagsOut: Flags to describe state about the input requested, e.g., discontinuity/complete. Can be NULL.

Parameter timeRangeOut: The asset time range corresponding to the provided source audio frames. Can be NULL.

Parameter numberFramesOut: The number of source frames that have been provided. Can be NULL. This can be less than the number of requested frames specified in numberFrames.

Returns: An OSStatus result code.

§Safety
  • buffer_list_in_out must be a valid pointer.
  • flags_out must be a valid pointer or null.
  • time_range_out must be a valid pointer or null.
  • number_frames_out must be a valid pointer or null.

Methods from Deref<Target = CFType>§

Source

pub fn downcast_ref<T>(&self) -> Option<&T>
where T: ConcreteType,

Attempt to downcast the type to that of type T.

This is the reference-variant. Use CFRetained::downcast if you want to convert a retained type. See also ConcreteType for more details on which types support being converted to.

Source

pub fn retain_count(&self) -> usize

Get the reference count of the object.

This function may be useful for debugging. You normally do not use this function otherwise.

Beware that some things (like CFNumbers, small CFStrings etc.) may not have a normal retain count for optimization purposes, and can return usize::MAX in that case.

Trait Implementations§

Source§

impl AsRef<AnyObject> for MTAudioProcessingTap

Source§

fn as_ref(&self) -> &AnyObject

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<CFType> for MTAudioProcessingTap

Source§

fn as_ref(&self) -> &CFType

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<MTAudioProcessingTap> for MTAudioProcessingTap

Source§

fn as_ref(&self) -> &Self

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl Borrow<AnyObject> for MTAudioProcessingTap

Source§

fn borrow(&self) -> &AnyObject

Immutably borrows from an owned value. Read more
Source§

impl Borrow<CFType> for MTAudioProcessingTap

Source§

fn borrow(&self) -> &CFType

Immutably borrows from an owned value. Read more
Source§

impl ConcreteType for MTAudioProcessingTap

Source§

fn type_id() -> CFTypeID

Get the unique CFTypeID identifier for the type. Read more
Source§

impl Debug for MTAudioProcessingTap

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Deref for MTAudioProcessingTap

Source§

type Target = CFType

The resulting type after dereferencing.
Source§

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

Dereferences the value.
Source§

impl Hash for MTAudioProcessingTap

Source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

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

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

impl Message for MTAudioProcessingTap

Source§

fn retain(&self) -> Retained<Self>
where Self: Sized,

Increment the reference count of the receiver. Read more
Source§

impl PartialEq for MTAudioProcessingTap

Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl RefEncode for MTAudioProcessingTap

Source§

const ENCODING_REF: Encoding

The Objective-C type-encoding for a reference of this type. Read more
Source§

impl Type for MTAudioProcessingTap

Source§

fn retain(&self) -> CFRetained<Self>
where Self: Sized,

Increment the reference count of the receiver. Read more
Source§

fn as_concrete_TypeRef(&self) -> &Self

👎Deprecated: this is redundant
Helper for easier transition from the core-foundation crate.
Source§

unsafe fn wrap_under_get_rule(ptr: *const Self) -> CFRetained<Self>
where Self: Sized,

👎Deprecated: use CFRetained::retain
Helper for easier transition from the core-foundation crate. Read more
Source§

fn as_CFTypeRef(&self) -> &CFType
where Self: AsRef<CFType>,

👎Deprecated: this is redundant (CF types deref to CFType)
Helper for easier transition from the core-foundation crate.
Source§

unsafe fn wrap_under_create_rule(ptr: *const Self) -> CFRetained<Self>
where Self: Sized,

👎Deprecated: use CFRetained::from_raw
Helper for easier transition from the core-foundation crate. Read more
Source§

impl Eq for MTAudioProcessingTap

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

Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
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.
Source§

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