Files
ffmpeg-dev-go/avutil_samplefmt.go
2023-11-05 08:43:33 +08:00

136 lines
5.8 KiB
Go

// Copyright (c) 2023 QRTC. All rights reserved.
// Use of this source code is governed by a MIT
// license that can be found in the LICENSE file.
package ffmpeg
/*
#include <libavutil/samplefmt.h>
*/
import "C"
import "unsafe"
// AVSampleFormat
type AVSampleFormat = C.enum_AVSampleFormat
const (
AV_SAMPLE_FMT_NONE = AVSampleFormat(C.AV_SAMPLE_FMT_NONE)
AV_SAMPLE_FMT_U8 = AVSampleFormat(C.AV_SAMPLE_FMT_U8)
AV_SAMPLE_FMT_S16 = AVSampleFormat(C.AV_SAMPLE_FMT_S16)
AV_SAMPLE_FMT_S32 = AVSampleFormat(C.AV_SAMPLE_FMT_S32)
AV_SAMPLE_FMT_FLT = AVSampleFormat(C.AV_SAMPLE_FMT_FLT)
AV_SAMPLE_FMT_DBL = AVSampleFormat(C.AV_SAMPLE_FMT_DBL)
AV_SAMPLE_FMT_U8P = AVSampleFormat(C.AV_SAMPLE_FMT_U8P)
AV_SAMPLE_FMT_S16P = AVSampleFormat(C.AV_SAMPLE_FMT_S16P)
AV_SAMPLE_FMT_S32P = AVSampleFormat(C.AV_SAMPLE_FMT_S32P)
AV_SAMPLE_FMT_FLTP = AVSampleFormat(C.AV_SAMPLE_FMT_FLTP)
AV_SAMPLE_FMT_DBLP = AVSampleFormat(C.AV_SAMPLE_FMT_DBLP)
AV_SAMPLE_FMT_S64 = AVSampleFormat(C.AV_SAMPLE_FMT_S64)
AV_SAMPLE_FMT_S64P = AVSampleFormat(C.AV_SAMPLE_FMT_S64P)
AV_SAMPLE_FMT_NB = AVSampleFormat(C.AV_SAMPLE_FMT_NB)
)
// AvGetSampleFmtName returns the name of sample_fmt, or NULL if sample_fmt is not
// recognized.
func AvGetSampleFmtName(sampleFmt AVSampleFormat) string {
return C.GoString(C.av_get_sample_fmt_name((C.enum_AVSampleFormat)(sampleFmt)))
}
// AvGetSampleFmt returns a sample format corresponding to name, or AV_SAMPLE_FMT_NONE
// on error.
func AvGetSampleFmt(name string) AVSampleFormat {
namePtr, nameFunc := StringCasting(name)
defer nameFunc()
return (AVSampleFormat)(C.av_get_sample_fmt((*C.char)(namePtr)))
}
// AvGetAltSampleFmt returns the planar<->packed alternative form of the given sample format, or
// Av_SAMPLE_FMT_NONE on error. If the passed sample_fmt is already in the
// requested planar/packed format, the format returned is the same as the
// input.
func AvGetAltSampleFmt(sampleFmt AVSampleFormat, planar int32) AVSampleFormat {
return (AVSampleFormat)(C.av_get_alt_sample_fmt((C.enum_AVSampleFormat)(sampleFmt), (C.int)(planar)))
}
// AvGetPackedSampleFmt gets the packed alternative form of the given sample format.
func AvGetPackedSampleFmt(sampleFmt AVSampleFormat) AVSampleFormat {
return (AVSampleFormat)(C.av_get_packed_sample_fmt((C.enum_AVSampleFormat)(sampleFmt)))
}
// AvGetPlanarSampleFmt gets the planar alternative form of the given sample format.
func AvGetPlanarSampleFmt(sampleFmt AVSampleFormat) AVSampleFormat {
return (AVSampleFormat)(C.av_get_planar_sample_fmt((C.enum_AVSampleFormat)(sampleFmt)))
}
// AvGetSampleFmtString generates a string corresponding to the sample format with
// sample_fmt, or a header if sample_fmt is negative.
func AvGetSampleFmtString(buf *int8, bufSize int32, sampleFmt AVSampleFormat) string {
return C.GoString(C.av_get_sample_fmt_string((*C.char)(buf), (C.int)(bufSize),
(C.enum_AVSampleFormat)(sampleFmt)))
}
// AvGetBytesPerSample returns number of bytes per sample.
func AvGetBytesPerSample(sampleFmt AVSampleFormat) int32 {
return (int32)(C.av_get_bytes_per_sample((C.enum_AVSampleFormat)(sampleFmt)))
}
// AvSampleFmtIsPlanar checks if the sample format is planar.
func AvSampleFmtIsPlanar(sampleFmt AVSampleFormat) int32 {
return (int32)(C.av_sample_fmt_is_planar((C.enum_AVSampleFormat)(sampleFmt)))
}
// AvSamplesGetBufferSize gets the required buffer size for the given audio parameters.
func AvSamplesGetBufferSize(linesize *int32, nbChannels, nbSamples int32,
sampleFmt AVSampleFormat, align int32) int32 {
return (int32)(C.av_samples_get_buffer_size((*C.int)(linesize), (C.int)(nbChannels),
(C.int)(nbSamples), (C.enum_AVSampleFormat)(sampleFmt), (C.int)(align)))
}
// AvSamplesFillArrays fills plane data pointers and linesize for samples with sample
// format sample_fmt.
func AvSamplesFillArrays(audioData **uint8, linesize *int32,
buf *uint8, nbChannels, nbSamples int32,
sampleFmt AVSampleFormat, align int32) int32 {
return (int32)(C.av_samples_fill_arrays((**C.uint8_t)(unsafe.Pointer(audioData)),
(*C.int)(linesize), (*C.uint8_t)(buf),
(C.int)(nbChannels), (C.int)(nbSamples),
(C.enum_AVSampleFormat)(sampleFmt), (C.int)(align)))
}
// AvSamplesAlloc allocates a samples buffer for nb_samples samples, and fill data pointers and
// linesize accordingly.
func AvSamplesAlloc(audioData **uint8, linesize *int32,
nbChannels, nbSamples int32,
sampleFmt AVSampleFormat, align int32) int32 {
return (int32)(C.av_samples_alloc((**C.uint8_t)(unsafe.Pointer(audioData)),
(*C.int)(linesize),
(C.int)(nbChannels), (C.int)(nbSamples),
(C.enum_AVSampleFormat)(sampleFmt), (C.int)(align)))
}
// AvSamplesAllocArrayAndSamples allocates a data pointers array, samples buffer for nb_samples
// samples, and fill data pointers and linesize accordingly.
func AvSamplesAllocArrayAndSamples(audioData ***uint8, linesize *int32, nbChannels, nbSamples int32,
sampleFmt AVSampleFormat, align int32) int32 {
return (int32)(C.av_samples_alloc_array_and_samples((***C.uint8_t)(unsafe.Pointer(audioData)),
(*C.int)(linesize), (C.int)(nbChannels), (C.int)(nbSamples),
(C.enum_AVSampleFormat)(sampleFmt), (C.int)(align)))
}
// AvSamplesCopy copies samples from src to dst.
func AvSamplesCopy(dst, src **uint8, dstOffset, srcOffset int32,
nbSamples, nbChannels int32, sampleFmt AVSampleFormat) int32 {
return (int32)(C.av_samples_copy((**C.uint8_t)(unsafe.Pointer(dst)),
(**C.uint8_t)(unsafe.Pointer(src)),
(C.int)(dstOffset), (C.int)(srcOffset),
(C.int)(nbSamples), (C.int)(nbChannels),
(C.enum_AVSampleFormat)(sampleFmt)))
}
// AvSamplesSetSilence fills an audio buffer with silence.
func AvSamplesSetSilence(audioData **uint8, offset int32,
nbSamples, nbChannels int32, sampleFmt AVSampleFormat) int32 {
return (int32)(C.av_samples_set_silence((**C.uint8_t)(unsafe.Pointer(audioData)), (C.int)(offset),
(C.int)(nbSamples), (C.int)(nbChannels), (C.enum_AVSampleFormat)(sampleFmt)))
}