Wiki Page Content

Differences between revisions 27 and 28
Revision 27 as of 2011-11-12 05:41:19
Size: 5658
Editor: SheenaSmith
Comment: camelcase pragma change
Revision 28 as of 2011-12-12 19:15:47
Size: 5165
Editor: SheenaSmith
Comment: some sans-Sam editing (shift green to comment)
Deletions are marked like this. Additions are marked like this.
Line 7: Line 7:
A structure that contains the audio output format. It ^also^ contains a callback that is called when the audio device needs more data. A structure that contains the audio output format. It also contains a callback that is called when the audio device needs more data.
Line 12: Line 12:
<<Color2(green,Can '''channels''' only be 1 or 2 or can it handle more? Old wiki lists 4 for surround and 6 for surround w/ center and lfe (sub?).  Should it be 1=mono instead of just 1 mono etc.?)>> /* Can '''channels''' only be 1 or 2 or can it handle more? Old wiki lists 4 for surround and 6 for surround w/ center and lfe (sub?). */
Line 15: Line 16:
||Uint8||'''channels'''||number of channels: 1 mono, 2 stereo; see [[#Remarks|Remarks]] for details|| ||Uint8||'''channels'''||number of separate sound channels: 1 = mono, 2 = stereo||
Line 28: Line 29:
<<Color2(green,Should the functions [[SDL_LoadWAV_RW]] and [[SDL_OpenAudioDevice]] be added into this remark? Do they behave like their similarly named counterparts with respect to this struct?)>> /* Should the functions [[SDL_LoadWAV_RW]] and [[SDL_OpenAudioDevice]] be added into this remark? Do they behave like their similarly named counterparts with respect to this struct? */
Line 30: Line 31:
*<<BR>>The [[SDL_AudioSpec]] structure is used to describe the format of some audio data. This structure is used by [[SDL_OpenAudio]]() and [[SDL_LoadWAV]](). While all fields are used by [[SDL_OpenAudio]](), only '''freq''', '''format''', '''channels''', and '''samples''' are used by [[SDL_LoadWAV]](). ,,We will detail these common members here:,, *<<BR>>The [[SDL_AudioSpec]] structure is used to describe the format of some audio data. This structure is used by [[SDL_OpenAudio]]() and [[SDL_LoadWAV]](). While all fields are used by [[SDL_OpenAudio]](), only '''freq''', '''format''', '''channels''', and '''samples''' are used by [[SDL_LoadWAV]]().
Line 32: Line 33:
'''freq''' ^specifies^ the number of samples sent to the sound device ,,every,, ^per^ second. Common values are 11025, 22050 and 44100. The higher the better. <<Color2(green,I think this info could be moved to Params above and this paragraph removed.)>><<Color2(green,I think "The higher the better." implies that the programmer has a choice and should choose the higher number. I suspect that the value is actually dictated by the audio data. Perhaps rewording to say "Higher values produce higher quality sounds/audio output" might be preferable?)>> '''freq''' specifies the number of samples sent to the sound device per second. Common values are 11025, 22050 and 44100. The higher the better.
/*
I think this info could be moved to Params above and this paragraph removed. */
/*
I think "The higher the better." implies that the programmer has a choice and should choose the higher number. I suspect that the value is actually dictated by the audio data. Perhaps rewording to say "Higher values produce higher quality sounds/audio output" might be preferable? */
Line 34: Line 37:
<<Color2(green,Should this be an include from [[SDL_AudioFormat]] instead?)>>
'''format''' specifies the size and type of each sample element. ,,Values it can take are:,, ^Audio format flags may be one of the following values:^
/* Should this be an include from [[SDL_AudioFormat]] instead? */
'''format''' specifies the size and type of each sample element and may be one of the following:
Line 56: Line 59:
<<Color2(green,This list was taken from the header. A portion was listed in the old wiki as well. Is it correct that audio change flags and audio flags (as opposed to the above audio format flags) should not be included here?)>> /* This list was taken from the header. A portion was listed in the old wiki as well. Is it correct that audio change flags and audio flags (as opposed to the above audio format flags) should not be included here? */
Line 58: Line 61:
'''channels''' ^specifies^ the number of separate sound channels. 1 is mono (single channel), 2 is stereo (dual channel). <<Color2(green,I think this paragraph is redundant with Params above and can be removed.)>>

'''samples''' ^specifies a unit of audio data.^
When used with [[SDL_OpenAudio]]() this refers to the size of the audio buffer in samples. A sample is a chunk of audio data of the size specified in '''format''' multiplied by the number of channels. When the [[SDL_AudioSpec]] is used with [[SDL_LoadWAV]]() '''samples''' is set to 4096. <<Color2(green,Params above specifies that this is a "power of 2". Would it be appropriate to show how to determine/calculate this value here?)>>
'''samples''' specifies a unit of audio data. When used with [[SDL_OpenAudio]]() this refers to the size of the audio buffer in samples. A sample is a chunk of audio data of the size specified in '''format''' multiplied by the number of channels. When the [[SDL_AudioSpec]] is used with [[SDL_LoadWAV]]() '''samples''' is set to 4096.
/*
Params above specifies that this is a "power of 2". Would it be appropriate to show how to determine/calculate this value here? */
Line 63: Line 65:
The ,,calculated,, values '''silence''' and '''size''' are calculated by [[SDL_OpenAudio]](). The values '''silence''' and '''size''' are calculated by [[SDL_OpenAudio]]().

DRAFT

SDL_AudioSpec

A structure that contains the audio output format. It also contains a callback that is called when the audio device needs more data.

Data Fields

int

freq

DSP frequency (samples per second); see Remarks for details

SDL_AudioFormat

format

audio data format; see Remarks for details

Uint8

channels

number of separate sound channels: 1 = mono, 2 = stereo

Uint8

silence

audio buffer silence value (calculated)

Uint16

samples

audio buffer size in samples (power of 2); see Remarks for details

Uint32

size

audio buffer size in bytes (calculated)

SDL_AudioCallback

callback

the function to call when the audio device needs more data; see Remarks for details

void*

userdata

a pointer that is passed to callback

Code Examples

You can add your code example here

Remarks

*
The SDL_AudioSpec structure is used to describe the format of some audio data. This structure is used by SDL_OpenAudio() and SDL_LoadWAV(). While all fields are used by SDL_OpenAudio(), only freq, format, channels, and samples are used by SDL_LoadWAV().

freq specifies the number of samples sent to the sound device per second. Common values are 11025, 22050 and 44100. The higher the better.

format specifies the size and type of each sample element and may be one of the following:

  • Defaults to LSB byte order -or- Basic ???

    AUDIO_U8

    unsigned 8-bit samples.

    AUDIO_S8

    signed 8-bit samples.

    AUDIO_U16 or AUDIO_U16LSB

    not supported by all hardware (unsigned 16-bit little-endian)

    AUDIO_S16 or AUDIO_S16LSB

    not supported by all hardware (signed 16-bit little-endian)

    AUDIO_U16MSB

    not supported by all hardware (unsigned 16-bit big-endian)

    AUDIO_S16MSB

    not supported by all hardware (signed 16-bit big-endian)

    int32 support

    AUDIO_S32 or AUDIO_S32LSB

    32-bit integer samples

    AUDIO_S32MSB

    as above, but big-endian byte order

    float32 support

    AUDIO_F32 or AUDIO_F32LSB

    32-bit floating point samples

    AUDIO_F32MSB

    as above, but big-endian byte order

    Native audio byte ordering

    AUDIO_U16SYS

    either AUDIO_U16LSB or AUDIO_U16MSB depending on hardware CPU endianness

    AUDIO_S16SYS

    either AUDIO_S16LSB or AUDIO_S16MSB depending on hardware CPU endianness

    AUDIO_S32SYS

    either AUDIO_S32LSB or AUDIO_S32MSB depending on hardware CPU endianness

    AUDIO_F32SYS

    either AUDIO_F32LSB or AUDIO_F32MSB depending on hardware CPU endianness

samples specifies a unit of audio data. When used with SDL_OpenAudio() this refers to the size of the audio buffer in samples. A sample is a chunk of audio data of the size specified in format multiplied by the number of channels. When the SDL_AudioSpec is used with SDL_LoadWAV() samples is set to 4096.
*

The values silence and size are calculated by SDL_OpenAudio().

Stereo samples are stored in a LRLRLR ordering.

The function prototype for callback is:

  • void SDL_AudioCallback(void*  userdata,
                           Uint8* stream,
                           int    len)
  • where its parameters are:

    userdata

    an application-specific parameter saved in the SDL_AudioSpec structure

    stream

    a pointer to the audio data buffer filled in by SDL_AudioCallback()

    len

    the length of that buffer in bytes

Once the callback returns, the buffer will no longer be valid.


CategoryStruct, CategoryAudio

None: SDL_AudioSpec (last edited 2019-05-15 14:14:25 by ColaEuphoria)

(Page Info.)
Feedback
Please include your contact information if you'd like to receive a reply.
Submit