mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 00:58:12 +00:00
Converted some send_event to properties
Original commit message from CVS: Converted some send_event to properties
This commit is contained in:
parent
6fb62bbc9a
commit
16da17addc
2 changed files with 111 additions and 44 deletions
|
@ -47,11 +47,23 @@ enum
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
ARG_0,
|
ARG_0,
|
||||||
|
ARG_COMMENT,
|
||||||
|
ARG_VENDOR,
|
||||||
|
ARG_VERSION,
|
||||||
|
ARG_CHANNELS,
|
||||||
|
ARG_RATE,
|
||||||
|
ARG_BITRATE_UPPER,
|
||||||
|
ARG_BITRATE_NOMINAL,
|
||||||
|
ARG_BITRATE_LOWER,
|
||||||
|
ARG_BITRATE_WINDOW,
|
||||||
};
|
};
|
||||||
|
|
||||||
static void gst_vorbisdec_class_init (VorbisDecClass *klass);
|
static void gst_vorbisdec_class_init (VorbisDecClass *klass);
|
||||||
static void gst_vorbisdec_init (VorbisDec *vorbisdec);
|
static void gst_vorbisdec_init (VorbisDec *vorbisdec);
|
||||||
|
|
||||||
|
static void gst_vorbisdec_get_property (GObject *object, guint prop_id,
|
||||||
|
GValue *value, GParamSpec *pspec);
|
||||||
|
|
||||||
static void gst_vorbisdec_loop (GstElement *element);
|
static void gst_vorbisdec_loop (GstElement *element);
|
||||||
|
|
||||||
static GstElementClass *parent_class = NULL;
|
static GstElementClass *parent_class = NULL;
|
||||||
|
@ -83,11 +95,43 @@ vorbisdec_get_type (void)
|
||||||
static void
|
static void
|
||||||
gst_vorbisdec_class_init (VorbisDecClass * klass)
|
gst_vorbisdec_class_init (VorbisDecClass * klass)
|
||||||
{
|
{
|
||||||
|
GObjectClass *gobject_class;
|
||||||
GstElementClass *gstelement_class;
|
GstElementClass *gstelement_class;
|
||||||
|
|
||||||
|
gobject_class = (GObjectClass*) klass;
|
||||||
gstelement_class = (GstElementClass *) klass;
|
gstelement_class = (GstElementClass *) klass;
|
||||||
|
|
||||||
parent_class = g_type_class_ref (GST_TYPE_ELEMENT);
|
parent_class = g_type_class_ref (GST_TYPE_ELEMENT);
|
||||||
|
|
||||||
|
g_object_class_install_property (gobject_class, ARG_COMMENT,
|
||||||
|
g_param_spec_string ("comment", "Comment", "The comment tags for this vorbis stream",
|
||||||
|
"", G_PARAM_READABLE));
|
||||||
|
g_object_class_install_property (gobject_class, ARG_VENDOR,
|
||||||
|
g_param_spec_string ("vendor", "Vendor", "The vendor for this vorbis stream",
|
||||||
|
"", G_PARAM_READABLE));
|
||||||
|
g_object_class_install_property (gobject_class, ARG_VERSION,
|
||||||
|
g_param_spec_int ("version", "Version", "The version",
|
||||||
|
0, G_MAXINT, 0, G_PARAM_READABLE));
|
||||||
|
g_object_class_install_property (gobject_class, ARG_CHANNELS,
|
||||||
|
g_param_spec_int ("channels", "Channels", "The number of channels",
|
||||||
|
0, G_MAXINT, 0, G_PARAM_READABLE));
|
||||||
|
g_object_class_install_property (gobject_class, ARG_RATE,
|
||||||
|
g_param_spec_int ("rate", "Rate", "The samplerate",
|
||||||
|
0, G_MAXINT, 0, G_PARAM_READABLE));
|
||||||
|
g_object_class_install_property (gobject_class, ARG_BITRATE_UPPER,
|
||||||
|
g_param_spec_int ("bitrate_upper", "bitrate_upper", "bitrate_upper",
|
||||||
|
0, G_MAXINT, 0, G_PARAM_READABLE));
|
||||||
|
g_object_class_install_property (gobject_class, ARG_BITRATE_NOMINAL,
|
||||||
|
g_param_spec_int ("bitrate_nominal", "bitrate_nominal", "bitrate_nominal",
|
||||||
|
0, G_MAXINT, 0, G_PARAM_READABLE));
|
||||||
|
g_object_class_install_property (gobject_class, ARG_BITRATE_LOWER,
|
||||||
|
g_param_spec_int ("bitrate_lower", "bitrate_lower", "bitrate_lower",
|
||||||
|
0, G_MAXINT, 0, G_PARAM_READABLE));
|
||||||
|
g_object_class_install_property (gobject_class, ARG_BITRATE_WINDOW,
|
||||||
|
g_param_spec_int ("bitrate_window", "bitrate_window", "bitrate_window",
|
||||||
|
0, G_MAXINT, 0, G_PARAM_READABLE));
|
||||||
|
|
||||||
|
gobject_class->get_property = gst_vorbisdec_get_property;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -146,9 +190,6 @@ gst_vorbisdec_loop (GstElement * element)
|
||||||
ogg_page og; /* one Ogg bitstream page. Vorbis packets are inside */
|
ogg_page og; /* one Ogg bitstream page. Vorbis packets are inside */
|
||||||
ogg_packet op; /* one raw packet of data for decode */
|
ogg_packet op; /* one raw packet of data for decode */
|
||||||
|
|
||||||
vorbis_info vi; /* struct that stores all the static vorbis bitstream
|
|
||||||
settings */
|
|
||||||
vorbis_comment vc; /* struct that stores all the bitstream user comments */
|
|
||||||
vorbis_dsp_state vd; /* central working state for the packet->PCM decoder */
|
vorbis_dsp_state vd; /* central working state for the packet->PCM decoder */
|
||||||
vorbis_block vb; /* local working space for packet->PCM decode */
|
vorbis_block vb; /* local working space for packet->PCM decode */
|
||||||
|
|
||||||
|
@ -201,8 +242,8 @@ gst_vorbisdec_loop (GstElement * element)
|
||||||
header is an easy way to identify a Vorbis bitstream and it's
|
header is an easy way to identify a Vorbis bitstream and it's
|
||||||
useful to see that functionality seperated out. */
|
useful to see that functionality seperated out. */
|
||||||
|
|
||||||
vorbis_info_init (&vi);
|
vorbis_info_init (&vorbisdec->vi);
|
||||||
vorbis_comment_init (&vc);
|
vorbis_comment_init (&vorbisdec->vc);
|
||||||
if (ogg_stream_pagein (&os, &og) < 0) {
|
if (ogg_stream_pagein (&os, &og) < 0) {
|
||||||
/* error; stream version mismatch perhaps */
|
/* error; stream version mismatch perhaps */
|
||||||
g_warning ("Error reading first page of Ogg bitstream data.\n");
|
g_warning ("Error reading first page of Ogg bitstream data.\n");
|
||||||
|
@ -215,7 +256,7 @@ gst_vorbisdec_loop (GstElement * element)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (vorbis_synthesis_headerin (&vi, &vc, &op) < 0) {
|
if (vorbis_synthesis_headerin (&vorbisdec->vi, &vorbisdec->vc, &op) < 0) {
|
||||||
/* error case; not a vorbis header */
|
/* error case; not a vorbis header */
|
||||||
g_warning ("This Ogg bitstream does not contain Vorbis audio data.\n");
|
g_warning ("This Ogg bitstream does not contain Vorbis audio data.\n");
|
||||||
return;
|
return;
|
||||||
|
@ -253,7 +294,7 @@ gst_vorbisdec_loop (GstElement * element)
|
||||||
We can't tolerate that in a header. Die. */
|
We can't tolerate that in a header. Die. */
|
||||||
g_warning ("Corrupt secondary header. expect trouble\n");
|
g_warning ("Corrupt secondary header. expect trouble\n");
|
||||||
}
|
}
|
||||||
vorbis_synthesis_headerin (&vi, &vc, &op);
|
vorbis_synthesis_headerin (&vorbisdec->vi, &vorbisdec->vc, &op);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -275,30 +316,23 @@ gst_vorbisdec_loop (GstElement * element)
|
||||||
/* Throw the comments plus a few lines about the bitstream we're
|
/* Throw the comments plus a few lines about the bitstream we're
|
||||||
decoding */
|
decoding */
|
||||||
{
|
{
|
||||||
char **ptr = vc.user_comments;
|
char **ptr = vorbisdec->vc.user_comments;
|
||||||
|
|
||||||
while (*ptr) {
|
while (*ptr) {
|
||||||
gst_element_send_event (GST_ELEMENT (vorbisdec),
|
/* FIXME parse comments */
|
||||||
gst_event_new_info ("comment", GST_PROPS_STRING (*ptr), NULL));
|
|
||||||
++ptr;
|
++ptr;
|
||||||
}
|
}
|
||||||
gst_element_send_event (GST_ELEMENT (vorbisdec),
|
g_object_freeze_notify (G_OBJECT (vorbisdec));
|
||||||
gst_event_new_info ("vendor", GST_PROPS_STRING (vc.vendor), NULL));
|
g_object_notify (G_OBJECT (vorbisdec), "comment");
|
||||||
|
g_object_notify (G_OBJECT (vorbisdec), "vendor");
|
||||||
gst_element_send_event (GST_ELEMENT (vorbisdec),
|
g_object_notify (G_OBJECT (vorbisdec), "version");
|
||||||
gst_event_new_info ("version", GST_PROPS_INT (vi.version), NULL));
|
g_object_notify (G_OBJECT (vorbisdec), "channels");
|
||||||
gst_element_send_event (GST_ELEMENT (vorbisdec),
|
g_object_notify (G_OBJECT (vorbisdec), "rate");
|
||||||
gst_event_new_info ("channels", GST_PROPS_INT (vi.channels), NULL));
|
g_object_notify (G_OBJECT (vorbisdec), "bitrate_upper");
|
||||||
gst_element_send_event (GST_ELEMENT (vorbisdec),
|
g_object_notify (G_OBJECT (vorbisdec), "bitrate_nominal");
|
||||||
gst_event_new_info ("rate", GST_PROPS_INT (vi.rate), NULL));
|
g_object_notify (G_OBJECT (vorbisdec), "bitrate_lower");
|
||||||
gst_element_send_event (GST_ELEMENT (vorbisdec),
|
g_object_notify (G_OBJECT (vorbisdec), "bitrate_window");
|
||||||
gst_event_new_info ("bitrate_upper", GST_PROPS_INT (vi.bitrate_upper), NULL));
|
g_object_thaw_notify (G_OBJECT (vorbisdec));
|
||||||
gst_element_send_event (GST_ELEMENT (vorbisdec),
|
|
||||||
gst_event_new_info ("bitrate_nominal", GST_PROPS_INT (vi.bitrate_nominal), NULL));
|
|
||||||
gst_element_send_event (GST_ELEMENT (vorbisdec),
|
|
||||||
gst_event_new_info ("bitrate_lower", GST_PROPS_INT (vi.bitrate_lower), NULL));
|
|
||||||
gst_element_send_event (GST_ELEMENT (vorbisdec),
|
|
||||||
gst_event_new_info ("bitrate_window", GST_PROPS_INT (vi.bitrate_window), NULL));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
gst_pad_try_set_caps (vorbisdec->srcpad,
|
gst_pad_try_set_caps (vorbisdec->srcpad,
|
||||||
|
@ -310,15 +344,15 @@ gst_vorbisdec_loop (GstElement * element)
|
||||||
"signed", GST_PROPS_BOOLEAN (TRUE),
|
"signed", GST_PROPS_BOOLEAN (TRUE),
|
||||||
"width", GST_PROPS_INT (16),
|
"width", GST_PROPS_INT (16),
|
||||||
"depth", GST_PROPS_INT (16),
|
"depth", GST_PROPS_INT (16),
|
||||||
"rate", GST_PROPS_INT (vi.rate),
|
"rate", GST_PROPS_INT (vorbisdec->vi.rate),
|
||||||
"channels", GST_PROPS_INT (vi.channels)
|
"channels", GST_PROPS_INT (vorbisdec->vi.channels)
|
||||||
));
|
));
|
||||||
|
|
||||||
vorbisdec->convsize = 4096 / vi.channels;
|
vorbisdec->convsize = 4096 / vorbisdec->vi.channels;
|
||||||
|
|
||||||
/* OK, got and parsed all three headers. Initialize the Vorbis
|
/* OK, got and parsed all three headers. Initialize the Vorbis
|
||||||
packet->PCM decoder. */
|
packet->PCM decoder. */
|
||||||
vorbis_synthesis_init (&vd, &vi); /* central decode state */
|
vorbis_synthesis_init (&vd, &vorbisdec->vi); /* central decode state */
|
||||||
vorbis_block_init (&vd, &vb); /* local state for most of the decode
|
vorbis_block_init (&vd, &vb); /* local state for most of the decode
|
||||||
so multiple block decodes can
|
so multiple block decodes can
|
||||||
proceed in parallel. We could init
|
proceed in parallel. We could init
|
||||||
|
@ -366,15 +400,15 @@ gst_vorbisdec_loop (GstElement * element)
|
||||||
|
|
||||||
|
|
||||||
outbuf = gst_buffer_new ();
|
outbuf = gst_buffer_new ();
|
||||||
GST_BUFFER_DATA (outbuf) = g_malloc (2 * vi.channels * bout);
|
GST_BUFFER_DATA (outbuf) = g_malloc (2 * vorbisdec->vi.channels * bout);
|
||||||
GST_BUFFER_SIZE (outbuf) = 2 * vi.channels * bout;
|
GST_BUFFER_SIZE (outbuf) = 2 * vorbisdec->vi.channels * bout;
|
||||||
GST_BUFFER_TIMESTAMP (outbuf) = vorbisdec->total_out * 1000000LL / vi.rate;
|
GST_BUFFER_TIMESTAMP (outbuf) = vorbisdec->total_out * 1000000LL / vorbisdec->vi.rate;
|
||||||
|
|
||||||
vorbisdec->total_out += bout;
|
vorbisdec->total_out += bout;
|
||||||
|
|
||||||
/* convert doubles to 16 bit signed ints (host order) and
|
/* convert doubles to 16 bit signed ints (host order) and
|
||||||
interleave */
|
interleave */
|
||||||
for (i = 0; i < vi.channels; i++) {
|
for (i = 0; i < vorbisdec->vi.channels; i++) {
|
||||||
int16_t *ptr = ((int16_t *) GST_BUFFER_DATA (outbuf)) + i;
|
int16_t *ptr = ((int16_t *) GST_BUFFER_DATA (outbuf)) + i;
|
||||||
float *mono = pcm[i];
|
float *mono = pcm[i];
|
||||||
|
|
||||||
|
@ -391,7 +425,7 @@ gst_vorbisdec_loop (GstElement * element)
|
||||||
clipflag = 1;
|
clipflag = 1;
|
||||||
}
|
}
|
||||||
*ptr = val;
|
*ptr = val;
|
||||||
ptr += vi.channels;
|
ptr += vorbisdec->vi.channels;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -435,9 +469,49 @@ gst_vorbisdec_loop (GstElement * element)
|
||||||
|
|
||||||
vorbis_block_clear (&vb);
|
vorbis_block_clear (&vb);
|
||||||
vorbis_dsp_clear (&vd);
|
vorbis_dsp_clear (&vd);
|
||||||
vorbis_info_clear (&vi); /* must be called last */
|
vorbis_info_clear (&vorbisdec->vi); /* must be called last */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* OK, clean up the framer */
|
/* OK, clean up the framer */
|
||||||
ogg_sync_clear (&oy);
|
ogg_sync_clear (&oy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gst_vorbisdec_get_property (GObject *object, guint prop_id, GValue *value, GParamSpec *pspec)
|
||||||
|
{
|
||||||
|
VorbisDec *vorbisdec;
|
||||||
|
|
||||||
|
g_return_if_fail (GST_IS_VORBISDEC (object));
|
||||||
|
|
||||||
|
vorbisdec = GST_VORBISDEC (object);
|
||||||
|
|
||||||
|
switch (prop_id) {
|
||||||
|
case ARG_COMMENT:
|
||||||
|
g_value_set_string (value, "comment");
|
||||||
|
break;
|
||||||
|
case ARG_VENDOR:
|
||||||
|
g_value_set_string (value, vorbisdec->vc.vendor);
|
||||||
|
break;
|
||||||
|
case ARG_VERSION:
|
||||||
|
g_value_set_int (value, vorbisdec->vi.version);
|
||||||
|
break;
|
||||||
|
case ARG_CHANNELS:
|
||||||
|
g_value_set_int (value, vorbisdec->vi.channels);
|
||||||
|
break;
|
||||||
|
case ARG_RATE:
|
||||||
|
g_value_set_int (value, vorbisdec->vi.rate);
|
||||||
|
break;
|
||||||
|
case ARG_BITRATE_UPPER:
|
||||||
|
g_value_set_int (value, vorbisdec->vi.bitrate_upper);
|
||||||
|
break;
|
||||||
|
case ARG_BITRATE_NOMINAL:
|
||||||
|
g_value_set_int (value, vorbisdec->vi.bitrate_nominal);
|
||||||
|
break;
|
||||||
|
case ARG_BITRATE_LOWER:
|
||||||
|
g_value_set_int (value, vorbisdec->vi.bitrate_lower);
|
||||||
|
break;
|
||||||
|
case ARG_BITRATE_WINDOW:
|
||||||
|
g_value_set_int (value, vorbisdec->vi.bitrate_window);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -162,13 +162,6 @@ gst_vorbisenc_setup (VorbisEnc * vorbisenc)
|
||||||
vorbis_encode_init (&vorbisenc->vi, vorbisenc->channels, vorbisenc->frequency,
|
vorbis_encode_init (&vorbisenc->vi, vorbisenc->channels, vorbisenc->frequency,
|
||||||
-1, vorbisenc->bitrate, -1);
|
-1, vorbisenc->bitrate, -1);
|
||||||
|
|
||||||
gst_element_send_event (GST_ELEMENT (vorbisenc),
|
|
||||||
gst_event_new_info ("channels", GST_PROPS_INT (vorbisenc->channels), NULL));
|
|
||||||
gst_element_send_event (GST_ELEMENT (vorbisenc),
|
|
||||||
gst_event_new_info ("rate", GST_PROPS_INT (vorbisenc->frequency), NULL));
|
|
||||||
gst_element_send_event (GST_ELEMENT (vorbisenc),
|
|
||||||
gst_event_new_info ("bitrate_nominal", GST_PROPS_INT (vorbisenc->bitrate), NULL));
|
|
||||||
|
|
||||||
/* add a comment */
|
/* add a comment */
|
||||||
vorbis_comment_init (&vorbisenc->vc);
|
vorbis_comment_init (&vorbisenc->vc);
|
||||||
vorbis_comment_add (&vorbisenc->vc, (gchar *)comment);
|
vorbis_comment_add (&vorbisenc->vc, (gchar *)comment);
|
||||||
|
|
Loading…
Reference in a new issue