mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 09:08:14 +00:00
media: only set keyframe flag when modifying start
Only set the keyframe flag when we modify the start position. The keyframe flag should probably be ignored when no change is requested but until we can claim this is all documented properly and all demuxer implement this, avoid setting the flag. See also https://bugzilla.gnome.org/show_bug.cgi?id=723075
This commit is contained in:
parent
b1845b0864
commit
450b9d0a14
1 changed files with 11 additions and 5 deletions
|
@ -1487,7 +1487,6 @@ gst_rtsp_media_seek (GstRTSPMedia * media, GstRTSPTimeRange * range)
|
||||||
{
|
{
|
||||||
GstRTSPMediaClass *klass;
|
GstRTSPMediaClass *klass;
|
||||||
GstRTSPMediaPrivate *priv;
|
GstRTSPMediaPrivate *priv;
|
||||||
GstSeekFlags flags;
|
|
||||||
gboolean res;
|
gboolean res;
|
||||||
GstClockTime start, stop;
|
GstClockTime start, stop;
|
||||||
GstSeekType start_type, stop_type;
|
GstSeekType start_type, stop_type;
|
||||||
|
@ -1520,10 +1519,6 @@ gst_rtsp_media_seek (GstRTSPMedia * media, GstRTSPTimeRange * range)
|
||||||
if (!priv->seekable)
|
if (!priv->seekable)
|
||||||
goto not_seekable;
|
goto not_seekable;
|
||||||
|
|
||||||
/* depends on the current playing state of the pipeline. We might need to
|
|
||||||
* queue this until we get EOS. */
|
|
||||||
flags = GST_SEEK_FLAG_FLUSH | GST_SEEK_FLAG_KEY_UNIT;
|
|
||||||
|
|
||||||
start_type = stop_type = GST_SEEK_TYPE_NONE;
|
start_type = stop_type = GST_SEEK_TYPE_NONE;
|
||||||
|
|
||||||
if (!klass->convert_range (media, range, GST_RTSP_RANGE_NPT))
|
if (!klass->convert_range (media, range, GST_RTSP_RANGE_NPT))
|
||||||
|
@ -1546,6 +1541,8 @@ gst_rtsp_media_seek (GstRTSPMedia * media, GstRTSPTimeRange * range)
|
||||||
stop_type = GST_SEEK_TYPE_SET;
|
stop_type = GST_SEEK_TYPE_SET;
|
||||||
|
|
||||||
if (start != GST_CLOCK_TIME_NONE || stop != GST_CLOCK_TIME_NONE) {
|
if (start != GST_CLOCK_TIME_NONE || stop != GST_CLOCK_TIME_NONE) {
|
||||||
|
GstSeekFlags flags;
|
||||||
|
|
||||||
GST_INFO ("seeking to %" GST_TIME_FORMAT " - %" GST_TIME_FORMAT,
|
GST_INFO ("seeking to %" GST_TIME_FORMAT " - %" GST_TIME_FORMAT,
|
||||||
GST_TIME_ARGS (start), GST_TIME_ARGS (stop));
|
GST_TIME_ARGS (start), GST_TIME_ARGS (stop));
|
||||||
|
|
||||||
|
@ -1553,6 +1550,15 @@ gst_rtsp_media_seek (GstRTSPMedia * media, GstRTSPTimeRange * range)
|
||||||
if (priv->blocked)
|
if (priv->blocked)
|
||||||
media_streams_set_blocked (media, TRUE);
|
media_streams_set_blocked (media, TRUE);
|
||||||
|
|
||||||
|
/* depends on the current playing state of the pipeline. We might need to
|
||||||
|
* queue this until we get EOS. */
|
||||||
|
flags = GST_SEEK_FLAG_FLUSH;
|
||||||
|
|
||||||
|
/* only set keyframe flag when modifying start */
|
||||||
|
if (start_type != GST_SEEK_TYPE_NONE)
|
||||||
|
flags |= GST_SEEK_FLAG_KEY_UNIT;
|
||||||
|
|
||||||
|
/* FIXME, we only do forwards */
|
||||||
res = gst_element_seek (priv->pipeline, 1.0, GST_FORMAT_TIME,
|
res = gst_element_seek (priv->pipeline, 1.0, GST_FORMAT_TIME,
|
||||||
flags, start_type, start, stop_type, stop);
|
flags, start_type, start, stop_type, stop);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue