fpsdisplaysink: fix setting sync on child bin

Use GST_IS_BIN instead of G_OBJECT_TYPE to check if the
internal sink is a bin. Using the later won't work when
the sink is not a bin directly (but inherits from one, like
autovideosink).

Fixes #604280
This commit is contained in:
Thiago Santos 2009-12-16 18:32:42 -03:00
parent 9c03149e7b
commit d2dce72c60

View file

@ -33,9 +33,6 @@
*/ */
/* FIXME: /* FIXME:
* - can we avoid plugging the textoverlay? * - can we avoid plugging the textoverlay?
* - We are using autovideosink now, but then sync doesn't work
* - but then we have to lookup the realsink to be able to set sync
* - or we could make autovideosink proxy the property
* - gst-seek 15 "videotestsrc ! fpsdisplaysink" dies when closing gst-seek * - gst-seek 15 "videotestsrc ! fpsdisplaysink" dies when closing gst-seek
* - if we make ourself RANK_PRIMARY+10 autovideosink asserts * - if we make ourself RANK_PRIMARY+10 autovideosink asserts
* *
@ -172,7 +169,7 @@ on_video_sink_data_flow (GstPad * pad, GstMiniObject * mini_obj,
} }
static void static void
update_sink_sync (GstElement * sink, gpointer data) update_sub_sync (GstElement * sink, gpointer data)
{ {
/* Some sinks (like autovideosink) don't have the sync property so /* Some sinks (like autovideosink) don't have the sync property so
* we check it exists before setting it to avoid a warning at * we check it exists before setting it to avoid a warning at
@ -183,11 +180,28 @@ update_sink_sync (GstElement * sink, gpointer data)
GST_WARNING ("Internal sink doesn't have sync property"); GST_WARNING ("Internal sink doesn't have sync property");
} }
static void
fps_display_sink_update_sink_sync (GstFPSDisplaySink * self)
{
GstIterator *iterator;
if (self->video_sink == NULL)
return;
if (GST_IS_BIN (self->video_sink)) {
iterator = gst_bin_iterate_sinks (GST_BIN (self->video_sink));
gst_iterator_foreach (iterator, (GFunc) update_sub_sync,
(void *) &self->sync);
gst_iterator_free (iterator);
} else
update_sub_sync (self->video_sink, (void *) &self->sync);
}
static void static void
update_video_sink (GstFPSDisplaySink * self, GstElement * video_sink) update_video_sink (GstFPSDisplaySink * self, GstElement * video_sink)
{ {
GstPad *sink_pad; GstPad *sink_pad;
GstIterator *iterator;
if (self->video_sink) { if (self->video_sink) {
@ -208,13 +222,7 @@ update_video_sink (GstFPSDisplaySink * self, GstElement * video_sink)
/* create child elements */ /* create child elements */
self->video_sink = video_sink; self->video_sink = video_sink;
if (G_OBJECT_TYPE (self->video_sink) == GST_TYPE_BIN) { fps_display_sink_update_sink_sync (self);
iterator = gst_bin_iterate_sinks (GST_BIN (self->video_sink));
gst_iterator_foreach (iterator, (GFunc) update_sink_sync,
(void *) &self->sync);
gst_iterator_free (iterator);
} else
update_sink_sync (self->video_sink, (void *) &self->sync);
/* take a ref before bin takes the ownership */ /* take a ref before bin takes the ownership */
gst_object_ref (self->video_sink); gst_object_ref (self->video_sink);
@ -395,18 +403,11 @@ fps_display_sink_set_property (GObject * object, guint prop_id,
const GValue * value, GParamSpec * pspec) const GValue * value, GParamSpec * pspec)
{ {
GstFPSDisplaySink *self = GST_FPS_DISPLAY_SINK (object); GstFPSDisplaySink *self = GST_FPS_DISPLAY_SINK (object);
GstIterator *iterator;
switch (prop_id) { switch (prop_id) {
case ARG_SYNC: case ARG_SYNC:
self->sync = g_value_get_boolean (value); self->sync = g_value_get_boolean (value);
if (G_OBJECT_TYPE (self->video_sink) == GST_TYPE_BIN) { fps_display_sink_update_sink_sync (self);
iterator = gst_bin_iterate_sinks (GST_BIN (self->video_sink));
gst_iterator_foreach (iterator, (GFunc) update_sink_sync,
(void *) &self->sync);
gst_iterator_free (iterator);
} else
update_sink_sync (self->video_sink, (void *) &self->sync);
break; break;
case ARG_TEXT_OVERLAY: case ARG_TEXT_OVERLAY:
self->use_text_overlay = g_value_get_boolean (value); self->use_text_overlay = g_value_get_boolean (value);
@ -462,6 +463,12 @@ fps_display_sink_change_state (GstElement * element, GstStateChange transition)
case GST_STATE_CHANGE_NULL_TO_READY: case GST_STATE_CHANGE_NULL_TO_READY:
fps_display_sink_start (self); fps_display_sink_start (self);
break; break;
case GST_STATE_CHANGE_READY_TO_PAUSED:
case GST_STATE_CHANGE_PAUSED_TO_PLAYING:
/* reinforce our sync to children, as they might have changed
* internally */
fps_display_sink_update_sink_sync (self);
break;
default: default:
break; break;
} }