diff options
author | Sebastian Dröge <sebastian@centricular.com> | 2016-06-27 20:49:38 +0300 |
---|---|---|
committer | Sebastian Dröge <sebastian@centricular.com> | 2016-07-04 12:41:20 +0200 |
commit | 0fd14074fb214b44bc2d4be9b83fd558335c5e45 (patch) | |
tree | a0c839e10b8bb709fa333308669c1c13aff05137 | |
parent | 6aa3b25643a3208dc86f27af33ebd100d38b6442 (diff) | |
download | gstreamer-plugins-base-0fd14074fb214b44bc2d4be9b83fd558335c5e45.tar.gz |
playsink: Force STEP events on the video-sink for GST_FORMAT_BUFFERS
It does not make much sense for audio sinks.
-rw-r--r-- | gst/playback/gstplaysink.c | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/gst/playback/gstplaysink.c b/gst/playback/gstplaysink.c index b687f519c..e17c4392a 100644 --- a/gst/playback/gstplaysink.c +++ b/gst/playback/gstplaysink.c @@ -4703,10 +4703,11 @@ gst_play_sink_handle_message (GstBin * bin, GstMessage * message) * to them in case it's source is different from the a/v stream's source. */ static gboolean -gst_play_sink_send_event_to_sink (GstPlaySink * playsink, GstEvent * event) +gst_play_sink_send_event_to_sink (GstPlaySink * playsink, GstEvent * event, + gboolean force_video) { gboolean res = TRUE; - if (playsink->send_event_mode == MODE_FIRST) { + if (playsink->send_event_mode == MODE_FIRST || force_video) { if (playsink->textchain && playsink->textchain->sink) { gst_event_ref (event); if ((res = @@ -4727,7 +4728,7 @@ gst_play_sink_send_event_to_sink (GstPlaySink * playsink, GstEvent * event) } GST_DEBUG_OBJECT (playsink, "Event failed when sent to video sink"); } - if (playsink->audiochain) { + if (!force_video && playsink->audiochain) { gst_event_ref (event); if ((res = gst_element_send_event (playsink->audiochain->chain.bin, @@ -4736,6 +4737,8 @@ gst_play_sink_send_event_to_sink (GstPlaySink * playsink, GstEvent * event) goto done; } GST_DEBUG_OBJECT (playsink, "Event failed when sent to audio sink"); + } else { + res = FALSE; } } else { return @@ -4761,7 +4764,7 @@ gst_play_sink_send_event (GstElement * element, GstEvent * event) switch (event_type) { case GST_EVENT_SEEK: GST_DEBUG_OBJECT (element, "Sending event to a sink"); - res = gst_play_sink_send_event_to_sink (playsink, event); + res = gst_play_sink_send_event_to_sink (playsink, event, FALSE); break; case GST_EVENT_STEP: { @@ -4774,7 +4777,7 @@ gst_play_sink_send_event (GstElement * element, GstEvent * event) if (format == GST_FORMAT_BUFFERS) { /* for buffers, we will try to step video frames, for other formats we * send the step to all sinks */ - res = gst_play_sink_send_event_to_sink (playsink, event); + res = gst_play_sink_send_event_to_sink (playsink, event, TRUE); } else { res = GST_ELEMENT_CLASS (gst_play_sink_parent_class)->send_event (element, |