mirror of
https://github.com/joel16/SDL2.git
synced 2024-12-13 22:38:34 +00:00
8dd601989f
--HG-- extra : convert_revision : svn%3Ac70aab31-4412-0410-b14c-859654838e24/trunk%40182
69 lines
2.8 KiB
Groff
69 lines
2.8 KiB
Groff
.TH "SDL_AudioCVT" "3" "Tue 11 Sep 2001, 22:58" "SDL" "SDL API Reference"
|
|
.SH "NAME"
|
|
SDL_AudioCVT\- Audio Conversion Structure
|
|
.SH "STRUCTURE DEFINITION"
|
|
.PP
|
|
.nf
|
|
\f(CWtypedef struct{
|
|
int needed;
|
|
Uint16 src_format;
|
|
Uint16 dest_format;
|
|
double rate_incr;
|
|
Uint8 *buf;
|
|
int len;
|
|
int len_cvt;
|
|
int len_mult;
|
|
double len_ratio;
|
|
void (*filters[10])(struct SDL_AudioCVT *cvt, Uint16 format);
|
|
int filter_index;
|
|
} SDL_AudioCVT;\fR
|
|
.fi
|
|
.PP
|
|
.SH "STRUCTURE DATA"
|
|
.TP 20
|
|
\fBneeded\fR
|
|
Set to one if the conversion is possible
|
|
.TP 20
|
|
\fBsrc_format\fR
|
|
Audio format of the source
|
|
.TP 20
|
|
\fBdest_format\fR
|
|
Audio format of the destination
|
|
.TP 20
|
|
\fBrate_incr\fR
|
|
Rate conversion increment
|
|
.TP 20
|
|
\fBbuf\fR
|
|
Audio buffer
|
|
.TP 20
|
|
\fBlen\fR
|
|
Length of the original audio buffer in bytes
|
|
.TP 20
|
|
\fBlen_cvt\fR
|
|
Length of converted audio buffer in bytes (calculated)
|
|
.TP 20
|
|
\fBlen_mult\fR
|
|
\fBbuf\fR must be \fBlen\fR*\fBlen_mult\fR bytes in size(calculated)
|
|
.TP 20
|
|
\fBlen_ratio\fR
|
|
Final audio size is \fBlen\fR*\fBlen_ratio\fR
|
|
.TP 20
|
|
\fBfilters[10](\&.\&.)\fR
|
|
Pointers to functions needed for this conversion
|
|
.TP 20
|
|
\fBfilter_index\fR
|
|
Current conversion function
|
|
.SH "DESCRIPTION"
|
|
.PP
|
|
The \fBSDL_AudioCVT\fR is used to convert audio data between different formats\&. A \fBSDL_AudioCVT\fR structure is created with the \fI\fBSDL_BuildAudioCVT\fP\fR function, while the actual conversion is done by the \fI\fBSDL_ConvertAudio\fP\fR function\&.
|
|
.PP
|
|
Many of the fields in the \fBSDL_AudioCVT\fR structure should be considered private and their function will not be discussed here\&.
|
|
.IP "\fBUint8 *\fP\fBbuf\fR" 10This points to the audio data that will be used in the conversion\&. It is both the source and the destination, which means the converted audio data overwrites the original data\&. It also means that the converted data may be larger than the original data (if you were converting from 8-bit to 16-bit, for instance), so you must ensure \fBbuf\fR is large enough\&. See below\&.
|
|
.IP "\fBint\fP \fBlen\fR" 10This is the length of the original audio data in bytes\&.
|
|
.IP "\fBint\fP \fBlen_mult\fR" 10As explained above, the audio buffer needs to be big enough to store the converted data, which may be bigger than the original audio data\&. The length of \fBbuf\fR should be \fBlen\fR*\fBlen_mult\fR\&.
|
|
.IP "\fBdouble\fP \fBlen_ratio\fR" 10When you have finished converting your audio data, you need to know how much of your audio buffer is valid\&. \fBlen\fR*\fBlen_ratio\fR is the size of the converted audio data in bytes\&. This is very similar to \fBlen_mult\fR, however when the convert audio data is shorter than the original \fBlen_mult\fR would be 1\&. \fBlen_ratio\fR, on the other hand, would be a fractional number between 0 and 1\&.
|
|
.SH "SEE ALSO"
|
|
.PP
|
|
\fI\fBSDL_BuildAudioCVT\fP\fR, \fI\fBSDL_ConvertAudio\fP\fR, \fI\fBSDL_AudioSpec\fR\fR
|
|
...\" created by instant / docbook-to-man, Tue 11 Sep 2001, 22:58
|