diff options
Diffstat (limited to 'gst/audioresample')
-rw-r--r-- | gst/audioresample/gstaudioresample.c | 154 | ||||
-rw-r--r-- | gst/audioresample/gstaudioresample.h | 10 |
2 files changed, 95 insertions, 69 deletions
diff --git a/gst/audioresample/gstaudioresample.c b/gst/audioresample/gstaudioresample.c index e907dbfa..1a49484a 100644 --- a/gst/audioresample/gstaudioresample.c +++ b/gst/audioresample/gstaudioresample.c @@ -19,6 +19,25 @@ */ /* Element-Checklist-Version: 5 */ +/** + * SECTION:element-audioresample + * + * <refsect2> + * Audioresample resamples raw audio buffers to different sample rates using + * a configurable windowing function to enhance quality. + * <title>Example launch line</title> + * <para> + * <programlisting> + * gst-launch -v filesrc location=sine.ogg ! oggdemux ! vorbisdec ! audioconvert ! audioresample ! audio/x-raw-int, rate=8000 ! alsasink + * </programlisting> + * Decode an Ogg/Vorbis downsample to 8Khz and play sound through alsa. + * To create the Ogg/Vorbis file refer to the documentation of vorbisenc. + * </para> + * </refsect2> + * + * Last reviewed on 2006-03-02 (0.10.4) + */ + #ifdef HAVE_CONFIG_H #include "config.h" #endif @@ -52,8 +71,8 @@ enum enum { - ARG_0, - ARG_FILTERLEN + PROP_0, + PROP_FILTERLEN }; #define SUPPORTED_CAPS \ @@ -72,39 +91,38 @@ GST_STATIC_CAPS ( \ "audio/x-raw-float, " "rate = (int) [ 1, MAX ], " "channels = (int) [ 1, MAX ], " - "endianness = (int) BYTE_ORDER, " "width = (int) 32") + "endianness = (int) BYTE_ORDER, " "width = (int) 32" #endif - static GstStaticPadTemplate gst_audioresample_sink_template = - GST_STATIC_PAD_TEMPLATE ("sink", - GST_PAD_SINK, GST_PAD_ALWAYS, SUPPORTED_CAPS); +static GstStaticPadTemplate gst_audioresample_sink_template = +GST_STATIC_PAD_TEMPLATE ("sink", + GST_PAD_SINK, GST_PAD_ALWAYS, SUPPORTED_CAPS); - static GstStaticPadTemplate gst_audioresample_src_template = - GST_STATIC_PAD_TEMPLATE ("src", - GST_PAD_SRC, GST_PAD_ALWAYS, SUPPORTED_CAPS); +static GstStaticPadTemplate gst_audioresample_src_template = +GST_STATIC_PAD_TEMPLATE ("src", + GST_PAD_SRC, GST_PAD_ALWAYS, SUPPORTED_CAPS); - static void gst_audioresample_dispose (GObject * object); +static void gst_audioresample_dispose (GObject * object); - static void gst_audioresample_set_property (GObject * object, - guint prop_id, const GValue * value, GParamSpec * pspec); - static void gst_audioresample_get_property (GObject * object, - guint prop_id, GValue * value, GParamSpec * pspec); +static void gst_audioresample_set_property (GObject * object, + guint prop_id, const GValue * value, GParamSpec * pspec); +static void gst_audioresample_get_property (GObject * object, + guint prop_id, GValue * value, GParamSpec * pspec); /* vmethods */ - gboolean audioresample_get_unit_size (GstBaseTransform * base, - GstCaps * caps, guint * size); - GstCaps *audioresample_transform_caps (GstBaseTransform * base, - GstPadDirection direction, GstCaps * caps); - gboolean audioresample_transform_size (GstBaseTransform * trans, - GstPadDirection direction, GstCaps * incaps, guint insize, - GstCaps * outcaps, guint * outsize); - gboolean audioresample_set_caps (GstBaseTransform * base, GstCaps * incaps, - GstCaps * outcaps); - static GstFlowReturn audioresample_pushthrough (GstAudioresample * - audioresample); - static GstFlowReturn audioresample_transform (GstBaseTransform * base, - GstBuffer * inbuf, GstBuffer * outbuf); - static gboolean audioresample_event (GstBaseTransform * base, - GstEvent * event); +gboolean audioresample_get_unit_size (GstBaseTransform * base, + GstCaps * caps, guint * size); +GstCaps *audioresample_transform_caps (GstBaseTransform * base, + GstPadDirection direction, GstCaps * caps); +gboolean audioresample_transform_size (GstBaseTransform * trans, + GstPadDirection direction, GstCaps * incaps, guint insize, + GstCaps * outcaps, guint * outsize); +gboolean audioresample_set_caps (GstBaseTransform * base, GstCaps * incaps, + GstCaps * outcaps); +static GstFlowReturn audioresample_pushthrough (GstAudioresample * + audioresample); +static GstFlowReturn audioresample_transform (GstBaseTransform * base, + GstBuffer * inbuf, GstBuffer * outbuf); +static gboolean audioresample_event (GstBaseTransform * base, GstEvent * event); /*static guint gst_audioresample_signals[LAST_SIGNAL] = { 0 }; */ @@ -114,20 +132,21 @@ GST_STATIC_CAPS ( \ GST_BOILERPLATE_FULL (GstAudioresample, gst_audioresample, GstBaseTransform, GST_TYPE_BASE_TRANSFORM, DEBUG_INIT); - static void gst_audioresample_base_init (gpointer g_class) - { - GstElementClass *gstelement_class = GST_ELEMENT_CLASS (g_class); +static void +gst_audioresample_base_init (gpointer g_class) +{ + GstElementClass *gstelement_class = GST_ELEMENT_CLASS (g_class); - gst_element_class_add_pad_template (gstelement_class, - gst_static_pad_template_get (&gst_audioresample_src_template)); - gst_element_class_add_pad_template (gstelement_class, - gst_static_pad_template_get (&gst_audioresample_sink_template)); + gst_element_class_add_pad_template (gstelement_class, + gst_static_pad_template_get (&gst_audioresample_src_template)); + gst_element_class_add_pad_template (gstelement_class, + gst_static_pad_template_get (&gst_audioresample_sink_template)); - gst_element_class_set_details (gstelement_class, - &gst_audioresample_details); - } + gst_element_class_set_details (gstelement_class, &gst_audioresample_details); +} -static void gst_audioresample_class_init (GstAudioresampleClass * klass) +static void +gst_audioresample_class_init (GstAudioresampleClass * klass) { GObjectClass *gobject_class; @@ -137,7 +156,7 @@ static void gst_audioresample_class_init (GstAudioresampleClass * klass) gobject_class->get_property = gst_audioresample_get_property; gobject_class->dispose = gst_audioresample_dispose; - g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_FILTERLEN, + g_object_class_install_property (G_OBJECT_CLASS (klass), PROP_FILTERLEN, g_param_spec_int ("filter_length", "filter_length", "filter_length", 0, G_MAXINT, DEFAULT_FILTERLEN, G_PARAM_READWRITE | G_PARAM_CONSTRUCT)); @@ -159,7 +178,7 @@ static void gst_audioresample_class_init (GstAudioresampleClass * klass) } static void - gst_audioresample_init (GstAudioresample * audioresample, +gst_audioresample_init (GstAudioresample * audioresample, GstAudioresampleClass * klass) { ResampleState *r; @@ -181,7 +200,8 @@ static void resample_set_format (r, RESAMPLE_FORMAT_S16); } -static void gst_audioresample_dispose (GObject * object) +static void +gst_audioresample_dispose (GObject * object) { GstAudioresample *audioresample = GST_AUDIORESAMPLE (object); @@ -195,8 +215,9 @@ static void gst_audioresample_dispose (GObject * object) /* vmethods */ gboolean - audioresample_get_unit_size (GstBaseTransform * base, GstCaps * caps, - guint * size) { +audioresample_get_unit_size (GstBaseTransform * base, GstCaps * caps, + guint * size) +{ gint width, channels; GstStructure *structure; gboolean ret; @@ -214,7 +235,8 @@ gboolean return TRUE; } -GstCaps *audioresample_transform_caps (GstBaseTransform * base, +GstCaps * +audioresample_transform_caps (GstBaseTransform * base, GstPadDirection direction, GstCaps * caps) { GstCaps *res; @@ -230,7 +252,7 @@ GstCaps *audioresample_transform_caps (GstBaseTransform * base, } static gboolean - resample_set_state_from_caps (ResampleState * state, GstCaps * incaps, +resample_set_state_from_caps (ResampleState * state, GstCaps * incaps, GstCaps * outcaps, gint * channels, gint * inrate, gint * outrate) { GstStructure *structure; @@ -275,9 +297,10 @@ static gboolean } gboolean - audioresample_transform_size (GstBaseTransform * base, +audioresample_transform_size (GstBaseTransform * base, GstPadDirection direction, GstCaps * caps, guint size, GstCaps * othercaps, - guint * othersize) { + guint * othersize) +{ GstAudioresample *audioresample = GST_AUDIORESAMPLE (base); ResampleState *state; GstCaps *srccaps, *sinkcaps; @@ -329,8 +352,9 @@ gboolean } gboolean - audioresample_set_caps (GstBaseTransform * base, GstCaps * incaps, - GstCaps * outcaps) { +audioresample_set_caps (GstBaseTransform * base, GstCaps * incaps, + GstCaps * outcaps) +{ gboolean ret; gint inrate, outrate; int channels; @@ -362,7 +386,8 @@ gboolean return TRUE; } -static gboolean audioresample_event (GstBaseTransform * base, GstEvent * event) +static gboolean +audioresample_event (GstBaseTransform * base, GstEvent * event) { GstAudioresample *audioresample; @@ -397,8 +422,7 @@ static gboolean audioresample_event (GstBaseTransform * base, GstEvent * event) } static GstFlowReturn - audioresample_do_output (GstAudioresample * audioresample, - GstBuffer * outbuf) +audioresample_do_output (GstAudioresample * audioresample, GstBuffer * outbuf) { int outsize; int outsamples; @@ -475,7 +499,7 @@ static GstFlowReturn } static GstFlowReturn - audioresample_transform (GstBaseTransform * base, GstBuffer * inbuf, +audioresample_transform (GstBaseTransform * base, GstBuffer * inbuf, GstBuffer * outbuf) { GstAudioresample *audioresample; @@ -522,7 +546,7 @@ static GstFlowReturn /* push remaining data in the buffers out */ static GstFlowReturn - audioresample_pushthrough (GstAudioresample * audioresample) +audioresample_pushthrough (GstAudioresample * audioresample) { int outsize; ResampleState *r; @@ -552,29 +576,30 @@ done: static void - gst_audioresample_set_property (GObject * object, guint prop_id, +gst_audioresample_set_property (GObject * object, guint prop_id, const GValue * value, GParamSpec * pspec) { GstAudioresample *audioresample; - g_return_if_fail (GST_IS_AUDIORESAMPLE (object)); - audioresample = GST_AUDIORESAMPLE (object); + g_return_if_fail (GST_IS_AUDIORESAMPLE (object)); + audioresample = GST_AUDIORESAMPLE (object); switch (prop_id) { - case ARG_FILTERLEN: + case PROP_FILTERLEN: audioresample->filter_length = g_value_get_int (value); GST_DEBUG_OBJECT (GST_ELEMENT (audioresample), "new filter length %d", audioresample->filter_length); resample_set_filter_length (audioresample->resample, audioresample->filter_length); break; - default:G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); + default: + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); break; } } static void - gst_audioresample_get_property (GObject * object, guint prop_id, +gst_audioresample_get_property (GObject * object, guint prop_id, GValue * value, GParamSpec * pspec) { GstAudioresample *audioresample; @@ -583,7 +608,7 @@ static void audioresample = GST_AUDIORESAMPLE (object); switch (prop_id) { - case ARG_FILTERLEN: + case PROP_FILTERLEN: g_value_set_int (value, audioresample->filter_length); break; default: @@ -593,7 +618,8 @@ static void } -static gboolean plugin_init (GstPlugin * plugin) +static gboolean +plugin_init (GstPlugin * plugin) { resample_init (); diff --git a/gst/audioresample/gstaudioresample.h b/gst/audioresample/gstaudioresample.h index 9bf18c9f..f135411d 100644 --- a/gst/audioresample/gstaudioresample.h +++ b/gst/audioresample/gstaudioresample.h @@ -21,16 +21,13 @@ #ifndef __AUDIORESAMPLE_H__ #define __AUDIORESAMPLE_H__ - #include <gst/gst.h> #include <gst/base/gstbasetransform.h> #include "resample.h" - G_BEGIN_DECLS - #define GST_TYPE_AUDIORESAMPLE \ (gst_audioresample_get_type()) #define GST_AUDIORESAMPLE(obj) \ @@ -45,6 +42,11 @@ G_BEGIN_DECLS typedef struct _GstAudioresample GstAudioresample; typedef struct _GstAudioresampleClass GstAudioresampleClass; +/** + * GstAudioresample: + * + * Opaque data structure. + */ struct _GstAudioresample { GstBaseTransform element; @@ -70,8 +72,6 @@ struct _GstAudioresampleClass { GType gst_audioresample_get_type(void); - G_END_DECLS - #endif /* __AUDIORESAMPLE_H__ */ |