From 538674f6b6cb8139885cf2c8a3d3b8d32b88bc12 Mon Sep 17 00:00:00 2001 From: nicodvb Date: Mon, 1 Jan 2007 22:47:14 +0000 Subject: set dp->stream_pts only when feeding the video stream to workaround strange interleaving patterns in some samples (that show with wild alternations of the OSD timer going back and forth) git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@21807 b3059339-0415-0410-9bf9-f77b7e298cf2 --- libmpdemux/demux_mpg.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/libmpdemux/demux_mpg.c b/libmpdemux/demux_mpg.c index 7a12f9c06a..d70ff19388 100644 --- a/libmpdemux/demux_mpg.c +++ b/libmpdemux/demux_mpg.c @@ -421,7 +421,13 @@ static int demux_mpg_read_packet(demuxer_t *demux,int id){ len = l; dp->pts=pts/90000.0f; dp->pos=demux->filepos; - if(stream_control(demux->stream, STREAM_CTRL_GET_CURRENT_TIME,(void *)&stream_pts)!=STREAM_UNSUPORTED) + /* + workaround: + set dp->stream_pts only when feeding the video stream, or strangely interleaved files + (such as SWIII) will show strange alternations in the stream time, wildly going + back and forth + */ + if(ds == demux->video && stream_control(demux->stream, STREAM_CTRL_GET_CURRENT_TIME,(void *)&stream_pts)!=STREAM_UNSUPORTED) dp->stream_pts = stream_pts; ds_add_packet(ds,dp); if (demux->priv) ((mpg_demuxer_t*)demux->priv)->last_pts = pts/90000.0f; -- cgit v1.2.3