summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian Dröge <sebastian@centricular.com>2016-06-27 20:49:38 +0300
committerSebastian Dröge <sebastian@centricular.com>2016-07-04 12:41:20 +0200
commit0fd14074fb214b44bc2d4be9b83fd558335c5e45 (patch)
treea0c839e10b8bb709fa333308669c1c13aff05137
parent6aa3b25643a3208dc86f27af33ebd100d38b6442 (diff)
downloadgstreamer-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.c13
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,