Struct playdate_sys::ffi::playdate_sound_sample

source ·
#[repr(C)]
pub struct playdate_sound_sample { pub newSampleBuffer: Option<unsafe extern "C" fn(byteCount: c_int) -> *mut AudioSample>, pub loadIntoSample: Option<unsafe extern "C" fn(sample: *mut AudioSample, path: *const c_char) -> c_int>, pub load: Option<unsafe extern "C" fn(path: *const c_char) -> *mut AudioSample>, pub newSampleFromData: Option<unsafe extern "C" fn(data: *mut u8, format: SoundFormat, sampleRate: u32, byteCount: c_int) -> *mut AudioSample>, pub getData: Option<unsafe extern "C" fn(sample: *mut AudioSample, data: *mut *mut u8, format: *mut SoundFormat, sampleRate: *mut u32, bytelength: *mut u32)>, pub freeSample: Option<unsafe extern "C" fn(sample: *mut AudioSample)>, pub getLength: Option<unsafe extern "C" fn(sample: *mut AudioSample) -> c_float>, pub decompress: Option<unsafe extern "C" fn(sample: *mut AudioSample) -> c_int>, }

Fields§

§newSampleBuffer: Option<unsafe extern "C" fn(byteCount: c_int) -> *mut AudioSample>

AudioSample* playdate->sound->sample->newSampleBuffer(int length)

Allocates and returns a new AudioSample with a buffer large enough to load a file of length bytes.

§loadIntoSample: Option<unsafe extern "C" fn(sample: *mut AudioSample, path: *const c_char) -> c_int>

void playdate->sound->sample->loadIntoSample(AudioSample* sample, const char* path)

Loads the sound data from the file at path into an existing AudioSample, sample.

§load: Option<unsafe extern "C" fn(path: *const c_char) -> *mut AudioSample>

AudioSample* playdate->sound->sample->load(const char* path)

Allocates and returns a new AudioSample, with the sound data loaded in memory. If there is no file at path, the function returns null.

§newSampleFromData: Option<unsafe extern "C" fn(data: *mut u8, format: SoundFormat, sampleRate: u32, byteCount: c_int) -> *mut AudioSample>

AudioSample* playdate->sound->sample->newSampleFromData(uint8_t* data, SoundFormat format, uint32_t sampleRate, int byteCount)

Returns a new AudioSample referencing the given audio data. The sample keeps a pointer to the data instead of copying it, so the data must remain valid while the sample is active. format is one of the following values:

SoundFormat

typedef enum
{
	kSound8bitMono = 0,
	kSound8bitStereo = 1,
	kSound16bitMono = 2,
	kSound16bitStereo = 3,
	kSoundADPCMMono = 4,
	kSoundADPCMStereo = 5
} SoundFormat;

pd_api_sound.h also provides some helper macros and functions:

#define SoundFormatIsStereo(f) ((f)&1)
#define SoundFormatIs16bit(f) ((f)>=kSound16bitMono)
static inline uint32_t SoundFormat_bytesPerFrame(SoundFormat fmt);
§getData: Option<unsafe extern "C" fn(sample: *mut AudioSample, data: *mut *mut u8, format: *mut SoundFormat, sampleRate: *mut u32, bytelength: *mut u32)>§freeSample: Option<unsafe extern "C" fn(sample: *mut AudioSample)>

void playdate->sound->sample->freeSample(AudioSample* sample)

Frees the given sample.

§getLength: Option<unsafe extern "C" fn(sample: *mut AudioSample) -> c_float>

float playdate->sound->sample->getLength(AudioSample* sample)

Returns the length, in seconds, of sample.

§decompress: Option<unsafe extern "C" fn(sample: *mut AudioSample) -> c_int>

int playdate->sound->sample->decompress(void)

If the sample is ADPCM compressed, decompresses the sample data to 16-bit PCM data. This increases the sample’s memory footprint by 4x and does not affect the quality in any way, but it is necessary if you want to use the sample in a synth or play the file backwards. Returns 1 if successful, 0 if there’s not enough memory for the uncompressed data.

Trait Implementations§

source§

impl Clone for playdate_sound_sample

source§

fn clone(&self) -> playdate_sound_sample

Returns a copy of the value. Read more
1.0.0§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for playdate_sound_sample

source§

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

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

impl Default for playdate_sound_sample

source§

fn default() -> playdate_sound_sample

Returns the “default value” for a type. Read more
source§

impl Hash for playdate_sound_sample

source§

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

Feeds this value into the given [Hasher]. Read more
1.3.0§

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 Ord for playdate_sound_sample

source§

fn cmp(&self, other: &playdate_sound_sample) -> Ordering

This method returns an [Ordering] between self and other. Read more
1.21.0§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized + PartialOrd,

Restrict a value to a certain interval. Read more
source§

impl PartialEq for playdate_sound_sample

source§

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

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

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl PartialOrd for playdate_sound_sample

source§

fn partial_cmp(&self, other: &playdate_sound_sample) -> Option<Ordering>

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

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

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

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

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

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

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

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

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

impl Copy for playdate_sound_sample

source§

impl Eq for playdate_sound_sample

source§

impl StructuralPartialEq for playdate_sound_sample

Auto Trait Implementations§

§

impl Freeze for playdate_sound_sample

§

impl RefUnwindSafe for playdate_sound_sample

§

impl Send for playdate_sound_sample

§

impl Sync for playdate_sound_sample

§

impl Unpin for playdate_sound_sample

§

impl UnwindSafe for playdate_sound_sample

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<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

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

fn clone_into(&self, target: &mut T)

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

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.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 32 bytes