ffmpeg png 到 gif 使用 fifo 过滤器丢失帧列表的前半部分

ffmpeg png 到 gif 使用 fifo 过滤器丢失帧列表的前半部分

有人能为我在 Windows 10 中遇到的以下问题提出解决方案(或至少找出原因)吗?虽然我最初认为这可能是源图像的问题,但现在我专注于功能上的困难fifo——但我准备接受纠正。

问题
使用以下命令创建动画 gif 时,我丢失了三十八帧 1920x1080px 幻灯片中的最后十七帧以外的所有帧:

    ffmpeg -framerate 1 -i PREFIX_%4d.png -filter_complex "scale=w=iw/2:h=ih/2,split=2[palette_in][gif];[palette_in]palettegen[palette_out];[gif]fifo[gif_fifo]; [gif_fifo][palette_out]paletteuse"  -r 1 -y PREFIX.gif

目的是拆分输入,创建一个调色板,然后使用它来创建输出 gif。为什么?因为StackExchange教我这样做。

PREFIX_????.png文件集是原始 jpg 照片序列的按顺序编号的副本。使用此图像集多次运行后,帧丢失始终存在,包括使用在具有 1.0 秒持续时间参数的 concat 文件中指定的“原始”第一遍副本 png(文件名不按顺序编号)。

基本输出

ffmpeg version N-94174-gfeade2b403 Copyright (c) 2000-2019 the FFmpeg developers
  built with gcc 9.1.1 (GCC) 20190621
  configuration: --enable-gpl --enable-version3 --enable-sdl2 --enable-fontconfig --enable-gnutls --enable-iconv --enable-libass --enable-libdav1d --enable-libbluray --enable-libfreetype --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libtheora --enable-libtwolame --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxml2 --enable-libzimg --enable-lzma --enable-zlib --enable-gmp --enable-libvidstab --enable-libvorbis --enable-libvo-amrwbenc --enable-libmysofa --enable-libspeex --enable-libxvid --enable-libaom --enable-libmfx --enable-amf --enable-ffnvcodec --enable-cuvid --enable-d3d11va --enable-nvenc --enable-nvdec --enable-dxva2 --enable-avisynth --enable-libopenmpt
  libavutil      56. 30.100 / 56. 30.100
  libavcodec     58. 53.101 / 58. 53.101
  libavformat    58. 28.101 / 58. 28.101
  libavdevice    58.  7.100 / 58.  7.100
  libavfilter     7. 56.100 /  7. 56.100
  libswscale      5.  4.101 /  5.  4.101
  libswresample   3.  4.100 /  3.  4.100
  libpostproc    55.  4.100 / 55.  4.100
Input #0, image2, from 'PREFIX_%4d.png':
  Duration: 00:00:38.00, start: 0.000000, bitrate: N/A
    Stream #0:0: Video: png, rgb24(pc), 1920x1080 [SAR 2834:2834 DAR 16:9], 1 tbr, 1 tbn, 1 tbc
Stream mapping:
  Stream #0:0 (png) -> scale
  paletteuse -> Stream #0:0 (gif)
Press [q] to stop, [?] for help
Output #0, gif, to 'PREFIX.gif':
  Metadata:
    encoder         : Lavf58.28.101
    Stream #0:0: Video: gif, pal8, 960x540 [SAR 1:1 DAR 16:9], q=2-31, 200 kb/s, 1 fps, 100 tbn, 1 tbc
    Metadata:
      encoder         : Lavc58.53.101 gif
[Parsed_palettegen_2 @ 0000023393365180] 255(+1) colors generated out of 492243 colors; ratio=0.000518
frame=   17 fps=2.9 q=-0.0 Lsize=    6098kB time=00:00:37.01 bitrate=1349.8kbits/s speed=6.21x
video:6098kB audio:0kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.000320%

该问题尚未出现在其他测试图像集上,并且如果删除 split/fifo/palette 部分则不会出现。

ffmpeg -framerate 1 -i PREFIX_%4d.png  -r 1 -y PREFIX.gif

缩放过滤器仅作为测试包含,尽管它确实有助于降低测试 gif 的尺寸!

答案1

ffmpeg 中的大多数过滤器都要求输入在所有帧中具有一致的属性。只有少数过滤器被编码为能够感知和适应不断变化的属性(其中之一就是 scale)。

日志显示,过滤器图在第 15 帧和第 22 帧被重新初始化两次,这意味着存在一些属性不一致的情况。需要更多日志来识别这些不一致的情况。重新初始化时,fifo 过滤器会丢失在重新初始化之前缓冲的所有帧,因此会导致帧丢失。

尝试

ffmpeg -reinit_filter 0 -framerate 1 -i PREFIX_%4d.png -filter_complex "scale=w=iw/2:h=ih/2,format=bgra,split=2[palette_in][gif];[palette_in]palettegen[palette_out];[gif]fifo[gif_fifo]; [gif_fifo][palette_out]paletteuse"  -r 1 -y PREFIX.gif

告诉-reinit_filter 0ffmpeg 跳过重新初始化。filtergraph 前面的比例和格式确保*所有后续过滤器都收到统一的输入。

*有点。应将比例参数设置为固定大小以确保这一点。在这种情况下,我相信像素格式已经改变,格式过滤器会处理这个问题。

相关内容