mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
mov: copy timecode metadata from tmcd track to the related video stream.
Apple softwares seem not to add a tref for the timecode (the next commit fixes this issue), but at least FFmpeg does. This can be used to generate a sample that demonstrates the feature: ./ffmpeg -f lavfi -i testsrc \ -f lavfi -i mptestsrc \ -f lavfi -i rgbtestsrc \ -map 0 -map 1 -map 2 \ -metadata:s:0 timecode=00:00:00:12 \ -metadata:s:2 timecode=01:02:12:20 \ -t 10 -y out.mov ./ffprobe out.mov The timecode metadata being transmitted to the video streams, it can be kept while transmuxed/transcoded.
This commit is contained in:
parent
0d96ec19eb
commit
1ec23d9c02
@ -2876,7 +2876,7 @@ static int mov_read_header(AVFormatContext *s)
|
||||
{
|
||||
MOVContext *mov = s->priv_data;
|
||||
AVIOContext *pb = s->pb;
|
||||
int err;
|
||||
int i, err;
|
||||
MOVAtom atom = { AV_RL32("root") };
|
||||
|
||||
mov->fc = s;
|
||||
@ -2900,7 +2900,6 @@ static int mov_read_header(AVFormatContext *s)
|
||||
av_dlog(mov->fc, "on_parse_exit_offset=%"PRId64"\n", avio_tell(pb));
|
||||
|
||||
if (pb->seekable) {
|
||||
int i;
|
||||
if (mov->chapter_track > 0)
|
||||
mov_read_chapters(s);
|
||||
for (i = 0; i < s->nb_streams; i++)
|
||||
@ -2908,8 +2907,23 @@ static int mov_read_header(AVFormatContext *s)
|
||||
mov_read_timecode_track(s, s->streams[i]);
|
||||
}
|
||||
|
||||
/* copy timecode metadata from tmcd tracks to the related video streams */
|
||||
for (i = 0; i < s->nb_streams; i++) {
|
||||
AVStream *st = s->streams[i];
|
||||
MOVStreamContext *sc = st->priv_data;
|
||||
if (sc->tref_type == AV_RL32("tmcd") && sc->trefs_count) {
|
||||
AVDictionaryEntry *tcr;
|
||||
int tmcd_st_id = sc->trefs[0] - 1;
|
||||
|
||||
if (tmcd_st_id < 0 || tmcd_st_id >= s->nb_streams)
|
||||
continue;
|
||||
tcr = av_dict_get(s->streams[tmcd_st_id]->metadata, "timecode", NULL, 0);
|
||||
if (tcr)
|
||||
av_dict_set(&st->metadata, "timecode", tcr->value, 0);
|
||||
}
|
||||
}
|
||||
|
||||
if (mov->trex_data) {
|
||||
int i;
|
||||
for (i = 0; i < s->nb_streams; i++) {
|
||||
AVStream *st = s->streams[i];
|
||||
MOVStreamContext *sc = st->priv_data;
|
||||
|
Loading…
x
Reference in New Issue
Block a user