24fps の Quicktime mov ファイルを FFmpeg トランスコードで実行すると、ソース ファイルのタイムスケールが 24000 であるにもかかわらず、ムービー ヘッダーのタイムスケールが 1000 になります。この低いタイムスケール値により、一部のプロフェッショナル ソフトウェア ツールでファイルを検索するときに問題が発生します。
私の場合、ソース ファイルは 1 つのビデオ トラック (DNx115) と 1 つのデータ トラック (タイムコード) を含む Quicktime です。これを DNx36 にトランスコードしています。
「-video_track_timescale 24000」を追加することでビデオのタイムスケールを強制的に 24000 にすることができますが、これはビデオ トラック以外には影響しません。
コマンドは次のとおりです。
ffmpeg -i input.mov -c:v dnxhd -b:v 36M -pix_fmt yuv422p -video_track_timescale 24000 output.mov
未カットのコンソール出力:
ffmpeg version N-90214-gdd3f1e3a11-tessus Copyright (c) 2000-2018 the FFmpeg developers
built with Apple LLVM version 9.0.0 (clang-900.0.39.2)
configuration: --cc=/usr/bin/clang --prefix=/opt/ffmpeg --extra-version=tessus --enable-avisynth --enable-fontconfig --enable-gpl --enable-libass --enable-libbluray --enable-libfreetype --enable-libgsm --enable-libmodplug --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopus --enable-libsnappy --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libvidstab --enable-libvo-amrwbenc --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libx264 --enable-libx265 --enable-libxavs --enable-libxvid --enable-libzimg --enable-libzmq --enable-libzvbi --enable-version3 --pkg-config-flags=--static --disable-ffplay
libavutil 56. 8.100 / 56. 8.100
libavcodec 58. 13.102 / 58. 13.102
libavformat 58. 10.100 / 58. 10.100
libavdevice 58. 2.100 / 58. 2.100
libavfilter 7. 12.100 / 7. 12.100
libswscale 5. 0.102 / 5. 0.102
libswresample 3. 0.101 / 3. 0.101
libpostproc 55. 0.100 / 55. 0.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'input.mov':
Metadata:
major_brand : qt
minor_version : 537199360
compatible_brands: qt
creation_time : 2018-03-06T10:45:16.000000Z
timecode : 01:14:25:22
Duration: 00:00:30.00, start: 0.000000, bitrate: 116392 kb/s
Stream #0:0(eng): Video: dnxhd (DNXHD) (AVdn / 0x6E645641), yuv422p(tv, bt709), 1920x1080, 116391 kb/s, SAR 1:1 DAR 16:9, 24 fps, 24 tbr, 24k tbn, 24k tbc (default)
Metadata:
creation_time : 2018-03-06T10:45:16.000000Z
handler_name : Apple Alias Data Handler
encoder : Avid DNxHD Codec
Stream #0:1(eng): Data: none (tmcd / 0x64636D74), 0 kb/s (default)
Metadata:
creation_time : 2018-03-06T10:45:20.000000Z
handler_name : Apple Alias Data Handler
timecode : 01:14:25:22
Stream mapping:
Stream #0:0 -> #0:0 (dnxhd (native) -> dnxhd (native))
Press [q] to stop, [?] for help
Output #0, mov, to 'output.mov':
Metadata:
major_brand : qt
minor_version : 537199360
compatible_brands: qt
timecode : 01:14:25:22
encoder : Lavf58.10.100
Stream #0:0(eng): Video: dnxhd (DNXHD) (AVdn / 0x6E645641), yuv422p, 1920x1080 [SAR 1:1 DAR 16:9], q=2-1024, 36000 kb/s, 0.04 fps, 24k tbn, 24 tbc (default)
Metadata:
creation_time : 2018-03-06T10:45:16.000000Z
handler_name : Apple Alias Data Handler
encoder : Lavc58.13.102 dnxhd
frame= 720 fps=151 q=4.0 Lsize= 132482kB time=00:00:29.95 bitrate=36226.7kbits/s speed=6.28x
Atom Inspector でタイムスケールの値を確認したところ、input.mov が 24000 に設定されているのに、output.mov で mvhd (ムービー ヘッダー) が 1000 に変更されていることがはっきりとわかりました。
1000 は 24 できれいに割り切れないので、不正確なシークが発生します。
Atom Inspector を使用して、このヘッダーのタイムスケールを手動で 24000 に変更し、期間フィールドをこのタイムスケールに基づいて変更すると、ファイルは期待どおりに動作します。
FFmpeg でオプションとしてムービー ヘッダーのタイムスケール値を設定する方法はありますか?
答え1
libavformat/movenc.h の MOV_TIMESCALE 値によると、これは 1000 に設定されます。これは実際には適切/有用な値ではないため、なぜこれが選択されたのかはわかりません。
これを 600 に変更するパッチを提出しました。