Blame gst-libs/gst/audio/audio-converter.h

Packit 971217
/* GStreamer
Packit 971217
 * Copyright (C) 2004 Ronald Bultje <rbultje@ronald.bitfreak.net>
Packit 971217
 *           (C) 2015 Wim Taymans <wim.taymans@gmail.com>
Packit 971217
 *
Packit 971217
 * audioconverter.h: audio format conversion library
Packit 971217
 *
Packit 971217
 * This library is free software; you can redistribute it and/or
Packit 971217
 * modify it under the terms of the GNU Library General Public
Packit 971217
 * License as published by the Free Software Foundation; either
Packit 971217
 * version 2 of the License, or (at your option) any later version.
Packit 971217
 *
Packit 971217
 * This library is distributed in the hope that it will be useful,
Packit 971217
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 971217
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 971217
 * Library General Public License for more details.
Packit 971217
 *
Packit 971217
 * You should have received a copy of the GNU Library General Public
Packit 971217
 * License along with this library; if not, write to the
Packit 971217
 * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
Packit 971217
 * Boston, MA 02110-1301, USA.
Packit 971217
 */
Packit 971217
Packit 971217
#ifndef __GST_AUDIO_CONVERTER_H__
Packit 971217
#define __GST_AUDIO_CONVERTER_H__
Packit 971217
Packit 971217
#include <gst/gst.h>
Packit 971217
#include <gst/audio/audio.h>
Packit 971217
Packit 971217
G_BEGIN_DECLS
Packit 971217
Packit 971217
typedef struct _GstAudioConverter GstAudioConverter;
Packit 971217
Packit 971217
/**
Packit 971217
 * GST_AUDIO_CONVERTER_OPT_RESAMPLER_METHOD:
Packit 971217
 *
Packit 971217
 * #GST_TYPE_AUDIO_RESAMPLER_METHOD, The resampler method to use when
Packit 971217
 * changing sample rates.
Packit 971217
 * Default is #GST_AUDIO_RESAMPLER_METHOD_BLACKMAN_NUTTALL.
Packit 971217
 */
Packit 971217
#define GST_AUDIO_CONVERTER_OPT_RESAMPLER_METHOD   "GstAudioConverter.resampler-method"
Packit 971217
Packit 971217
/**
Packit 971217
 * GST_AUDIO_CONVERTER_OPT_DITHER_METHOD:
Packit 971217
 *
Packit 971217
 * #GST_TYPE_AUDIO_DITHER_METHOD, The dither method to use when
Packit 971217
 * changing bit depth.
Packit 971217
 * Default is #GST_AUDIO_DITHER_NONE.
Packit 971217
 */
Packit 971217
#define GST_AUDIO_CONVERTER_OPT_DITHER_METHOD   "GstAudioConverter.dither-method"
Packit 971217
Packit 971217
/**
Packit 971217
 * GST_AUDIO_CONVERTER_OPT_NOISE_SHAPING_METHOD:
Packit 971217
 *
Packit 971217
 * #GST_TYPE_AUDIO_NOISE_SHAPING_METHOD, The noise shaping method to use
Packit 971217
 * to mask noise from quantization errors.
Packit 971217
 * Default is #GST_AUDIO_NOISE_SHAPING_NONE.
Packit 971217
 */
Packit 971217
#define GST_AUDIO_CONVERTER_OPT_NOISE_SHAPING_METHOD   "GstAudioConverter.noise-shaping-method"
Packit 971217
Packit 971217
/**
Packit 971217
 * GST_AUDIO_CONVERTER_OPT_QUANTIZATION:
Packit 971217
 *
Packit 971217
 * #G_TYPE_UINT, The quantization amount. Components will be
Packit 971217
 * quantized to multiples of this value.
Packit 971217
 * Default is 1
Packit 971217
 */
Packit 971217
#define GST_AUDIO_CONVERTER_OPT_QUANTIZATION   "GstAudioConverter.quantization"
Packit 971217
Packit 971217
/**
Packit 971217
 * GST_AUDIO_CONVERTER_OPT_MIX_MATRIX:
Packit 971217
 *
Packit 971217
 * #GST_TYPE_VALUE_LIST, The channel mapping matrix.
Packit 971217
 *
Packit 971217
 * The matrix coefficients must be between -1 and 1: the number of rows is equal
Packit 971217
 * to the number of output channels and the number of columns is equal to the
Packit 971217
 * number of input channels.
Packit 971217
 *
Packit 971217
 * ## Example matrix generation code
Packit 971217
 * To generate the matrix using code:
Packit 971217
 *
Packit 971217
 * |[
Packit 971217
 * GValue v = G_VALUE_INIT;
Packit 971217
 * GValue v2 = G_VALUE_INIT;
Packit 971217
 * GValue v3 = G_VALUE_INIT;
Packit 971217
 *
Packit 971217
 * g_value_init (&v2, GST_TYPE_ARRAY);
Packit 971217
 * g_value_init (&v3, G_TYPE_DOUBLE);
Packit 971217
 * g_value_set_double (&v3, 1);
Packit 971217
 * gst_value_array_append_value (&v2, &v3;;
Packit 971217
 * g_value_unset (&v3;;
Packit 971217
 * [ Repeat for as many double as your input channels - unset and reinit v3 ]
Packit 971217
 * g_value_init (&v, GST_TYPE_ARRAY);
Packit 971217
 * gst_value_array_append_value (&v, &v2;;
Packit 971217
 * g_value_unset (&v2;;
Packit 971217
 * [ Repeat for as many v2's as your output channels - unset and reinit v2]
Packit 971217
 * g_object_set_property (G_OBJECT (audiomixmatrix), "matrix", &v);
Packit 971217
 * g_value_unset (&v);
Packit 971217
 * ]|
Packit 971217
 */
Packit 971217
#define GST_AUDIO_CONVERTER_OPT_MIX_MATRIX   "GstAudioConverter.mix-matrix"
Packit 971217
Packit 971217
/**
Packit 971217
 * GstAudioConverterFlags:
Packit 971217
 * @GST_AUDIO_CONVERTER_FLAG_NONE: no flag
Packit 971217
 * @GST_AUDIO_CONVERTER_FLAG_IN_WRITABLE: the input sample arrays are writable and can be
Packit 971217
 *    used as temporary storage during conversion.
Packit 971217
 * @GST_AUDIO_CONVERTER_FLAG_VARIABLE_RATE: allow arbitrary rate updates with
Packit 971217
 *    gst_audio_converter_update_config().
Packit 971217
 *
Packit 971217
 * Extra flags passed to gst_audio_converter_new() and gst_audio_converter_samples().
Packit 971217
 */
Packit 971217
typedef enum {
Packit 971217
  GST_AUDIO_CONVERTER_FLAG_NONE            = 0,
Packit 971217
  GST_AUDIO_CONVERTER_FLAG_IN_WRITABLE     = (1 << 0),
Packit 971217
  GST_AUDIO_CONVERTER_FLAG_VARIABLE_RATE   = (1 << 1)
Packit 971217
} GstAudioConverterFlags;
Packit 971217
Packit 971217
GST_AUDIO_API
Packit 971217
GstAudioConverter *  gst_audio_converter_new             (GstAudioConverterFlags flags,
Packit 971217
                                                          GstAudioInfo *in_info,
Packit 971217
                                                          GstAudioInfo *out_info,
Packit 971217
                                                          GstStructure *config);
Packit 971217
Packit 971217
GST_AUDIO_API
Packit 971217
GType                gst_audio_converter_get_type        (void);
Packit 971217
Packit 971217
GST_AUDIO_API
Packit 971217
void                 gst_audio_converter_free            (GstAudioConverter * convert);
Packit 971217
Packit 971217
GST_AUDIO_API
Packit 971217
void                 gst_audio_converter_reset           (GstAudioConverter * convert);
Packit 971217
Packit 971217
GST_AUDIO_API
Packit 971217
gboolean             gst_audio_converter_update_config   (GstAudioConverter * convert,
Packit 971217
                                                          gint in_rate, gint out_rate,
Packit 971217
                                                          GstStructure *config);
Packit 971217
Packit 971217
GST_AUDIO_API
Packit 971217
const GstStructure * gst_audio_converter_get_config      (GstAudioConverter * convert,
Packit 971217
                                                          gint *in_rate, gint *out_rate);
Packit 971217
Packit 971217
GST_AUDIO_API
Packit 971217
gsize                gst_audio_converter_get_out_frames  (GstAudioConverter *convert,
Packit 971217
                                                          gsize in_frames);
Packit 971217
Packit 971217
GST_AUDIO_API
Packit 971217
gsize                gst_audio_converter_get_in_frames   (GstAudioConverter *convert,
Packit 971217
                                                          gsize out_frames);
Packit 971217
Packit 971217
GST_AUDIO_API
Packit 971217
gsize                gst_audio_converter_get_max_latency (GstAudioConverter *convert);
Packit 971217
Packit 971217
GST_AUDIO_API
Packit 971217
gboolean             gst_audio_converter_samples         (GstAudioConverter * convert,
Packit 971217
                                                          GstAudioConverterFlags flags,
Packit 971217
                                                          gpointer in[], gsize in_frames,
Packit 971217
                                                          gpointer out[], gsize out_frames);
Packit 971217
Packit 971217
GST_AUDIO_API
Packit 971217
gboolean             gst_audio_converter_supports_inplace (GstAudioConverter *convert);
Packit 971217
Packit 971217
GST_AUDIO_API
Packit 971217
gboolean             gst_audio_converter_convert          (GstAudioConverter * convert,
Packit 971217
                                                           GstAudioConverterFlags flags,
Packit 971217
                                                           gpointer in, gsize in_size,
Packit 971217
                                                           gpointer *out, gsize *out_size);
Packit 971217
Packit 971217
G_END_DECLS
Packit 971217
Packit 971217
#endif /* __GST_AUDIO_CONVERTER_H__ */