diff options
author | Martin Storsjö <martin@martin.st> | 2014-10-12 00:03:25 +0300 |
---|---|---|
committer | Martin Storsjö <martin@martin.st> | 2014-10-12 17:46:31 +0300 |
commit | dbb472cb2f2f799295a12b4922a6a8be2cccfdee (patch) | |
tree | a2a4f3db055be328ebe435b929f1ebb7ddfa23aa | |
parent | 95ee4e2ce774e0339632d067161596bf3dadfc72 (diff) | |
download | ffmpeg-dbb472cb2f2f799295a12b4922a6a8be2cccfdee.tar.gz |
movenc: Write edit lists for fragmented files as well, if necessary
This is necessary to get the right timestamp offset for content
that starts with dts != 0.
This currently only helps when writing fragmented files with a non-empty
moov atom. When writing an empty moov atom, we don't have any packets
yet, so we don't know the starting dts for the tracks.
Signed-off-by: Martin Storsjö <martin@martin.st>
-rw-r--r-- | libavformat/movenc.c | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/libavformat/movenc.c b/libavformat/movenc.c index 218aa5012a..be11cfa444 100644 --- a/libavformat/movenc.c +++ b/libavformat/movenc.c @@ -1595,7 +1595,8 @@ static int mov_write_tapt_tag(AVIOContext *pb, MOVTrack *track) } // This box seems important for the psp playback ... without it the movie seems to hang -static int mov_write_edts_tag(AVIOContext *pb, MOVTrack *track) +static int mov_write_edts_tag(AVIOContext *pb, MOVMuxContext *mov, + MOVTrack *track) { int64_t duration = av_rescale_rnd(track->track_duration, MOV_TIMESCALE, track->timescale, AV_ROUND_UP); @@ -1645,6 +1646,13 @@ static int mov_write_edts_tag(AVIOContext *pb, MOVTrack *track) duration += delay; } + /* For fragmented files, we don't know the full length yet. Setting + * duration to 0 allows us to only specify the offset, including + * the rest of the content (from all future fragments) without specifying + * an explicit duration. */ + if (mov->flags & FF_MOV_FLAG_FRAGMENT) + duration = 0; + /* duration */ if (version == 1) { avio_wb64(pb, duration); @@ -1758,8 +1766,7 @@ static int mov_write_trak_tag(AVIOContext *pb, MOVMuxContext *mov, if (track->mode == MODE_PSP || track->flags & MOV_TRACK_CTTS || (track->entry && track->cluster[0].dts) || is_clcp_track(track)) { - if (!(mov->flags & FF_MOV_FLAG_FRAGMENT)) - mov_write_edts_tag(pb, track); // PSP Movies require edts box + mov_write_edts_tag(pb, mov, track); // PSP Movies require edts box } if (track->tref_tag) mov_write_tref_tag(pb, track); |