FFMPEG创建的源文件时长不正确。

4

将AVI转换为mp4时,有时FFMPEG会错误地设置“源持续时间(source duration)”。

这会导致在iOS设备上播放出现问题。具体来说,它会导致视频在“源持续时间”处停止播放,而音频仍然正常播放。

enter image description here

FFMPEG输出转码时没有显示任何异常信息。看起来很正常,没有错误或警告。

  • 我能强制FFMPEG永远不添加“源持续时间”元数据吗?
  • 如何编辑mediainfo显示的轨道元数据?我尝试了Mp4box和其他一些工具,但似乎无法找到如何编辑轨道级别元数据的方法。

谢谢。

以下是日志信息。

ffmpeg version N-77455-g4707497 Copyright (c) 2000-2015 the FFmpeg developers   built with gcc 5.2.0 (GCC)   configuration: --enable-gpl
    --enable-version3 --disable-w32threads --enable-avisynth --enable-bzlib --enable-fontconfig --enable-frei0r --enable-gnutls --enable-iconv --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libdcadec --enable-libfreetype --enable-libgme --enable-libgsm --enable-libilbc --enable-libmodplug --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-librtmp --enable-libschroedinger --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvo-aacenc --enable-libvo-amrwbenc --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxavs --enable-libxvid --enable-libzimg --enable-lzma --enable-decklink --enable-zlib   libavutil      55. 11.100 / 55. 11.100   libavcodec     57. 20.100 / 57. 20.100   libavformat    57. 20.100 / 57. 20.100   libavdevice    57.  0.100 / 57.  0.100   libavfilter     6. 21.101 / 
    6. 21.101   libswscale      4.  0.100 /  4.  0.100   libswresample   2.  0.101 /  2.  0.101   libpostproc    54.  0.100 / 54.  0.100 Input #0, avi, from 'E:\MEDIA\Central.Intelligence.2016.HC.HDRip.XviD.AC3-EVO\Central.Intelligence.2016.HC.HDRip.XviD.AC3-EVO.avi': Metadata:
        encoder         : VirtualDubMod 1.5.10.2 (build 2542/release)   Duration: 01:51:43.27, start: 0.000000, bitrate: 1765 kb/s
        Stream #0:0: Video: mpeg4 (Advanced Simple Profile) (XVID / 0x44495658), yuv420p, 720x304 [SAR 1:1 DAR 45:19], 1563 kb/s, 23.98 fps, 23.98 tbr, 23.98 tbn, 23.98 tbc
        Stream #0:1: Audio: ac3 ([0] [0][0] / 0x2000), 48000 Hz, stereo, fltp, 192 kb/s [libx264 @ 000000f3c80a0a80] using SAR=405/304 [libx264 @ 000000f3c80a0a80] using cpu capabilities: MMX2 SSE2Fast SSSE3 SSE4.2 AVX FMA3 AVX2 LZCNT BMI2 [libx264 @ 000000f3c80a0a80] profile High, level 3.1 [libx264 @ 000000f3c80a0a80] 264 - core 148 r2638 7599210 - H.264/MPEG-4 AVC codec - Copyleft 2003-2015 - http://www.videolan.org/x264.html - options: cabac=1 ref=3 deblock=1:0:0 analyse=0x3:0x113 me=hex subme=7 psy=1 psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=1 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=-2 threads=6 lookahead_threads=1 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=3 b_pyramid=2 b_adapt=1 b_bias=0 direct=1 weightb=1 open_gop=0 weightp=2 keyint=250 keyint_min=23 scenecut=40 intra_refresh=0 rc_lookahead=40 rc=abr mbtree=1 bitrate=1280 ratetol=1.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 ip_ratio=1.40 aq=1:1.00 Output #0, mp4, to 'F:\STREAMS\Central.Intelligence.2016.HC.HDRip.XviD.AC3-EVO.avi.1280x720_1000kbps.TEMP.mp4': Metadata:
        encoder         : Lavf57.20.100
        Stream #0:0: Video: h264 (libx264) ([33][0][0][0] / 0x0021), yuv420p, 1280x720 [SAR 405:304 DAR 45:19], q=-1--1, 1280 kb/s, 23.98 fps, 10000k tbn, 23.98 tbc
        Metadata:
          encoder         : Lavc57.20.100 libx264
        Side data:
          unknown side data type 10 (24 bytes)
        Stream #0:1: Audio: aac ([64][0][0][0] / 0x0040), 44100 Hz, stereo, fltp, 160 kb/s
        Metadata:
          encoder         : Lavc57.20.100 aac Stream mapping:   Stream #0:0 -> #0:0 (mpeg4 (native) -> h264 (libx264))   Stream #0:1 -> #0:1 (ac3 (native) -> aac (native)) Press [q] to stop, [?] for help [mpeg4 @ 000000f3c80ae220] Video uses a non-standard and wasteful way to store B-frames ('packed B-frames'). Consider using the mpeg4_unpack_bframes bitstream filter without encoding but stream copy to fix it. 
frame=   15 fps=0.0 q=0.0 size=       0kB time=00:00:01.18 bitrate=   0.3kbits/s dup=1 drop=0 speed=2.36x   
--SNIP---
frame=160704 fps= 16 q=30.0 size= 1180376kB time=01:51:43.08 bitrate=1442.6kbits/s dup=1 drop=0 speed=0.671x     
[libx264 @ 0000001f60c5d900] frame I:1167  Avg QP:19.08  size: 44465
[libx264 @ 0000001f60c5d900] frame P:63049 Avg QP:22.26  size: 12774
[libx264 @ 0000001f60c5d900] frame B:110691 Avg QP:24.81  size:  2739
[libx264 @ 0000001f60c5d900] consecutive B-frames:  6.0% 22.8% 18.3% 53.0%
[libx264 @ 0000001f60c5d900] mb I  I16..4: 14.0% 76.1%  9.9%
[libx264 @ 0000001f60c5d900] mb P  I16..4:  2.5%  6.6%  0.4%  P16..4: 44.5% 10.8%  5.2%  0.0%  0.0%    skip:30.0%
[libx264 @ 0000001f60c5d900] mb B  I16..4:  0.1%  0.3%  0.0%  B16..8: 32.1%  1.6%  0.2%  direct: 0.9%  skip:64.9%  L0:37.9% L1:58.7% BI: 3.5%
[libx264 @ 0000001f60c5d900] final ratefactor: 23.25
[libx264 @ 0000001f60c5d900] 8x8 transform intra:70.8% inter:85.8%
[libx264 @ 0000001f60c5d900] coded y,uvDC,uvAC intra: 47.1% 56.6% 19.5% inter: 10.7% 14.2% 0.4%
[libx264 @ 0000001f60c5d900] i16 v,h,dc,p: 46% 20%  8% 26%
[libx264 @ 0000001f60c5d900] i8 v,h,dc,ddl,ddr,vr,hd,vl,hu: 21% 17% 25%  5%  7%  7%  7%  6%  6%
[libx264 @ 0000001f60c5d900] i4 v,h,dc,ddl,ddr,vr,hd,vl,hu: 27% 20% 12%  5% 10%  9%  8%  5%  4%
[libx264 @ 0000001f60c5d900] i8c dc,h,v,p: 58% 18% 18%  6%
[libx264 @ 0000001f60c5d900] Weighted P-Frames: Y:1.4% UV:0.8%
[libx264 @ 0000001f60c5d900] ref P L0: 62.6% 12.9% 18.9%  5.6%  0.1%
[libx264 @ 0000001f60c5d900] ref B L0: 87.6% 11.0%  1.4%
[libx264 @ 0000001f60c5d900] ref B L1: 94.6%  5.4%
[libx264 @ 0000001f60c5d900] kb/s:1272.59
[aac @ 0000001f60b52180] Qavg: 954.859

编辑

这与数据有关,当我运行此命令(在10分钟后停止)时:

ffmpeg.exe -i CI.mp4 -ss 00:00:00 -t 00:08:00 -vcodec copy  -map_metadata 0 -acodec copy CI2.mp4

Mediainfo显示

Duration                    : 9mn 49s
Source duration             : 2mn 40s

当我运行此程序时(18分钟)
ffmpeg.exe -i CI.mp4 -ss 00:00:00 -t 00:18:00 -vcodec copy  -map_metadata 0 -acodec copy CI2.mp4

Mediainfo显示
Duration                    : 17mn 49s
Source duration             : 3mn 30s

如何直接编辑元数据

1
展示转换命令及其完整的控制台输出。您可以在命令中添加“-report”并粘贴生成的日志文件。 - Gyan
@Mulvya 谢谢,我附上了FFMPEG日志。 - Byron Whitlock
3
无法执行命令。 - Gyan
@ByronWhitlock 你用了哪些命令来生成输出?它们可以用来重新创建你的问题并检查修复。你知道,像 ffmpeg -i somefile.mp4 -options=showUsed ...etc etc. 这样的命令。 - VC.One
1
在 MP4 的元数据中,你不会找到“源持续时间”,FFmpeg 甚至没有将其放在那里。它只是由 MediaInfo 计算得出的(但我不知道是如何计算的)。无论如何,CI.mp4 是 avi 转换为 mp4 的结果,对吗?那么,如果输出效果很差,为什么要使用不好的文件作为修剪这些 10 和 18 分钟测试的输入呢?结果仍然会很糟糕……还有,avi 文件的音频是 ac3 格式吗?在 avi 转换为 mp4 的命令中,你是否使用了 -acodec copy?Mp4 需要 mp3 或 aac 格式的音频。 - VC.One
显示剩余5条评论
1个回答

1

最近,我遇到了一个类似的问题。我有三个相似的(1080x1920,即竖屏)由手机拍摄的MP4视频。 我使用以下ffmpeg命令将它们转换为1280x720(横屏):

fmpeg -i input.MP4 -vf "scale=w=1280:h=720:force_original_aspect_ratio=decrease,pad=1280:720:(ow-iw)/2:(oh-ih)/2" -c:a copy -y output.MP4

它调整视频大小并在两侧添加宽黑边。其中两个视频效果良好,但第三个视频导致我的视频编辑器崩溃。然而,通过VLC可以显示它。我使用MediaInfo检查了它的标签,并发现它有一个源持续时间视频标签(我以前从未见过)。其值为9秒628毫秒,而持续时间为48秒21毫秒。另外两个视频没有源持续时间标签。由于VLC可以显示它,我尝试使用它来纠正视频,方法如下(我已在“视图”菜单中选中“高级控件”):
  1. 选择媒体 -> 转换/保存...
  2. 添加... -> 浏览输入.MP4 -> 打开
  3. 转换/保存 -> 转换
  4. 选择配置文件视频 - H.264 + MP3(MP4),点击编辑所选配置文件按钮
  5. 封装标签,MP4/MOV,除章节外所有功能
  6. 视频编解码器标签,选中视频和保留原始视频轨道
  7. 音频编解码器标签,选中音频和保留原始音频轨道
  8. 字幕标签,取消选中字幕,因为该视频没有字幕
  9. 保存
  10. 浏览目标文件,浏览输出文件夹,输入输出.MP4的文件名
  11. 保存
  12. 开始

VLC快速完成了“转换”,大功告成!根据MediaInfo,源持续时间标记已经不存在了,我的视频编辑器也欣然接受了结果视频。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接