mirror of https://git.ffmpeg.org/ffmpeg.git
avutil: add better documentation for AVSampleFormat
This commit is contained in:
parent
8b84e082ed
commit
5e8280d177
|
@ -22,7 +22,26 @@
|
||||||
#include "avutil.h"
|
#include "avutil.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* all in native-endian format
|
* Audio Sample Formats
|
||||||
|
*
|
||||||
|
* @par
|
||||||
|
* The data described by the sample format is always in native-endian order.
|
||||||
|
* Sample values can be expressed by native C types, hence the lack of a signed
|
||||||
|
* 24-bit sample format even though it is a common raw audio data format.
|
||||||
|
*
|
||||||
|
* @par
|
||||||
|
* The floating-point formats are based on full volume being in the range
|
||||||
|
* [-1.0, 1.0]. Any values outside this range are beyond full volume level.
|
||||||
|
*
|
||||||
|
* @par
|
||||||
|
* The data layout as used in av_samples_fill_arrays() and elsewhere in Libav
|
||||||
|
* (such as AVFrame in libavcodec) is as follows:
|
||||||
|
*
|
||||||
|
* For planar sample formats, each audio channel is in a separate data plane,
|
||||||
|
* and linesize is the buffer size, in bytes, for a single plane. All data
|
||||||
|
* planes must be the same size. For packed sample formats, only the first data
|
||||||
|
* plane is used, and samples for each channel are interleaved. In this case,
|
||||||
|
* linesize is the buffer size, in bytes, for the 1 plane.
|
||||||
*/
|
*/
|
||||||
enum AVSampleFormat {
|
enum AVSampleFormat {
|
||||||
AV_SAMPLE_FMT_NONE = -1,
|
AV_SAMPLE_FMT_NONE = -1,
|
||||||
|
@ -139,6 +158,9 @@ int av_samples_get_buffer_size(int *linesize, int nb_channels, int nb_samples,
|
||||||
* buffer for planar layout, or the aligned size of the buffer for all channels
|
* buffer for planar layout, or the aligned size of the buffer for all channels
|
||||||
* for packed layout.
|
* for packed layout.
|
||||||
*
|
*
|
||||||
|
* @see enum AVSampleFormat
|
||||||
|
* The documentation for AVSampleFormat describes the data layout.
|
||||||
|
*
|
||||||
* @param[out] audio_data array to be filled with the pointer for each channel
|
* @param[out] audio_data array to be filled with the pointer for each channel
|
||||||
* @param[out] linesize calculated linesize, may be NULL
|
* @param[out] linesize calculated linesize, may be NULL
|
||||||
* @param buf the pointer to a buffer containing the samples
|
* @param buf the pointer to a buffer containing the samples
|
||||||
|
@ -157,6 +179,9 @@ int av_samples_fill_arrays(uint8_t **audio_data, int *linesize, uint8_t *buf,
|
||||||
* linesize accordingly.
|
* linesize accordingly.
|
||||||
* The allocated samples buffer can be freed by using av_freep(&audio_data[0])
|
* The allocated samples buffer can be freed by using av_freep(&audio_data[0])
|
||||||
*
|
*
|
||||||
|
* @see enum AVSampleFormat
|
||||||
|
* The documentation for AVSampleFormat describes the data layout.
|
||||||
|
*
|
||||||
* @param[out] audio_data array to be filled with the pointer for each channel
|
* @param[out] audio_data array to be filled with the pointer for each channel
|
||||||
* @param[out] linesize aligned size for audio buffer(s), may be NULL
|
* @param[out] linesize aligned size for audio buffer(s), may be NULL
|
||||||
* @param nb_channels number of audio channels
|
* @param nb_channels number of audio channels
|
||||||
|
|
Loading…
Reference in New Issue