mirror of
https://github.com/mpv-player/mpv
synced 2025-01-05 03:06:28 +01:00
demux_lavf: for avi, use packet .dts instead of .pts
When playing avi files take timestamps from the .dts field of the packet instead of .pts. For avi libavformat returns the original avi timestamps in .dts; without GENPTS set .pts is sometimes unset, with GENPTS set it'll contain some made up values which are not correct pts. Current libavformat also has a bug take makes it loop over the whole avi file if you use GENPTS with video streams disabled. The timing code can cope with the avi timestamps even though they're not really pts.
This commit is contained in:
parent
d707da9e65
commit
759231566a
@ -76,6 +76,7 @@ typedef struct lavf_priv {
|
|||||||
int cur_program;
|
int cur_program;
|
||||||
int nb_streams_last;
|
int nb_streams_last;
|
||||||
bool internet_radio_hack;
|
bool internet_radio_hack;
|
||||||
|
bool use_dts;
|
||||||
}lavf_priv_t;
|
}lavf_priv_t;
|
||||||
|
|
||||||
static int mp_read(void *opaque, uint8_t *buf, int size) {
|
static int mp_read(void *opaque, uint8_t *buf, int size) {
|
||||||
@ -516,8 +517,14 @@ static demuxer_t* demux_open_lavf(demuxer_t *demuxer){
|
|||||||
|
|
||||||
if (lavfdopts->cryptokey)
|
if (lavfdopts->cryptokey)
|
||||||
parse_cryptokey(avfc, lavfdopts->cryptokey);
|
parse_cryptokey(avfc, lavfdopts->cryptokey);
|
||||||
if (opts->user_correct_pts != 0)
|
if (matches_avinputformat_name(priv, "avi")) {
|
||||||
avfc->flags |= AVFMT_FLAG_GENPTS;
|
/* for avi libavformat returns the avi timestamps in .dts,
|
||||||
|
* some made-up stuff that's not really pts in .pts */
|
||||||
|
priv->use_dts = true;
|
||||||
|
} else {
|
||||||
|
if (opts->user_correct_pts != 0)
|
||||||
|
avfc->flags |= AVFMT_FLAG_GENPTS;
|
||||||
|
}
|
||||||
if (index_mode == 0)
|
if (index_mode == 0)
|
||||||
avfc->flags |= AVFMT_FLAG_IGNIDX;
|
avfc->flags |= AVFMT_FLAG_IGNIDX;
|
||||||
|
|
||||||
@ -721,8 +728,9 @@ static int demux_lavf_fill_buffer(demuxer_t *demux, demux_stream_t *dsds){
|
|||||||
av_free_packet(&pkt);
|
av_free_packet(&pkt);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(pkt.pts != AV_NOPTS_VALUE){
|
int64_t ts = priv->use_dts ? pkt.dts : pkt.pts;
|
||||||
dp->pts=pkt.pts * av_q2d(priv->avfc->streams[id]->time_base);
|
if(ts != AV_NOPTS_VALUE){
|
||||||
|
dp->pts = ts * av_q2d(priv->avfc->streams[id]->time_base);
|
||||||
priv->last_pts= dp->pts * AV_TIME_BASE;
|
priv->last_pts= dp->pts * AV_TIME_BASE;
|
||||||
// always set endpts for subtitles, even if PKT_FLAG_KEY is not set,
|
// always set endpts for subtitles, even if PKT_FLAG_KEY is not set,
|
||||||
// otherwise they will stay on screen to long if e.g. ASS is demuxed from mkv
|
// otherwise they will stay on screen to long if e.g. ASS is demuxed from mkv
|
||||||
|
Loading…
Reference in New Issue
Block a user