[FFmpeg-devel] [PATCH 1/3] Round the mov track duration to 3 decimals.
Baptiste Coudurier
baptiste.coudurier
Wed Mar 2 20:34:15 CET 2011
On 3/2/11 9:27 AM, Benjamin Larsson wrote:
> ---
> libavformat/movenc.c | 4 +++-
> 1 files changed, 3 insertions(+), 1 deletions(-)
>
> diff --git a/libavformat/movenc.c b/libavformat/movenc.c
> index 8feb06e..f816273 100644
> --- a/libavformat/movenc.c
> +++ b/libavformat/movenc.c
> @@ -1256,6 +1256,8 @@ static int mov_write_minf_tag(AVIOContext *pb, MOVTrack *track, int est_nb_frame
>
> static int mov_write_mdhd_tag(AVIOContext *pb, MOVTrack *track)
> {
> + uint64_t tmptrackDuration = av_rescale_rnd(track->trackDuration, MOV_TIMESCALE,
> + track->timescale, AV_ROUND_UP) * track->timescale/MOV_TIMESCALE;
> int version = track->trackDuration < INT32_MAX ? 0 : 1;
>
> (version == 1) ? avio_wb32(pb, 44) : avio_wb32(pb, 32); /* size */
> @@ -1270,7 +1272,7 @@ static int mov_write_mdhd_tag(AVIOContext *pb, MOVTrack *track)
> avio_wb32(pb, track->time); /* modification time */
> }
> avio_wb32(pb, track->timescale); /* time scale (sample rate for audio) */
> - (version == 1) ? avio_wb64(pb, track->trackDuration) : avio_wb32(pb, track->trackDuration); /* duration */
> + (version == 1) ? avio_wb64(pb, tmptrackDuration) : avio_wb32(pb, tmptrackDuration); /* duration */
> avio_wb16(pb, track->language); /* language */
> avio_wb16(pb, 0); /* reserved (quality) */
>
Hummm, trackDuration is exact in track timescale. Why do you want to
round it ?
--
Baptiste COUDURIER
Key fingerprint 8D77134D20CC9220201FC5DB0AC9325C5C1ABAAA
FFmpeg maintainer http://www.ffmpeg.org
More information about the ffmpeg-devel
mailing list