image-processing - ffmpeg - 将回帧合并到具有相同编码的视频

标签 image-processing ffmpeg

我有一个使用 H264 以 23.98 fps 编码的视频,持续时间为 00:00:06.42。

我从那个视频中提取了帧,然后我一张一张地处理了这些图像。现在我想将它们作为视频重新组合在一起,但我想与源视频相同(相同的持续时间、相同的音频等)。

无论我尝试什么,都会带来不同的东西。持续时间总是更长(大约 00:00:06.59),音频似乎一直到视频的结尾(如预期的那样),但帧编码不正确,它们似乎在结尾处卡住,音频继续。

除了最后的卡住之外,看起来几乎相同的那个看起来像这样:

ffmpeg -i input.mov \
       -pattern_type glob -i 'result_*.tif' 
       -map 1 -map 0:a \
       -map_metadata 0 \
       -map_metadata:s:v 0:s:v \
       -map_metadata:s:a 0:s:a \
       output.mov

我使用输入视频中的元数据和音频,并使用我的第二个输入中的帧。

编辑:正如这里所建议的源视频的详细信息。
ffmpeg version 2.8.15 Copyright (c) 2000-2018 the FFmpeg developers
  built with gcc 4.8.5 (GCC) 20150623 (Red Hat 4.8.5-28)
  configuration: --prefix=/usr --bindir=/usr/bin --datadir=/usr/share/ffmpeg --incdir=/usr/include/ffmpeg --libdir=/usr/lib64 --mandir=/usr/share/man --arch=x86_64 --optflags='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -m64 -mtune=generic' --extra-ldflags='-Wl,-z,relro ' --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libvo-amrwbenc --enable-version3 --enable-bzlib --disable-crystalhd --enable-gnutls --enable-ladspa --enable-libass --enable-libcdio --enable-libdc1394 --disable-indev=jack --enable-libfreetype --enable-libgsm --enable-libmp3lame --enable-openal --enable-libopenjpeg --enable-libopus --enable-libpulse --enable-libschroedinger --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libvorbis --enable-libv4l2 --enable-libx264 --enable-libx265 --enable-libxvid --enable-x11grab --enable-avfilter --enable-avresample --enable-postproc --enable-pthreads --disable-static --enable-shared --enable-gpl --disable-debug --disable-stripping --shlibdir=/usr/lib64 --enable-runtime-cpudetect
  libavutil      54. 31.100 / 54. 31.100
  libavcodec     56. 60.100 / 56. 60.100
  libavformat    56. 40.101 / 56. 40.101
  libavdevice    56.  4.100 / 56.  4.100
  libavfilter     5. 40.101 /  5. 40.101
  libavresample   2.  1.  0 /  2.  1.  0
  libswscale      3.  1.101 /  3.  1.101
  libswresample   1.  2.101 /  1.  2.101
  libpostproc    53.  3.100 / 53.  3.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'Transparent.mov':
  Metadata:
    major_brand     : qt
    minor_version   : 0
    compatible_brands: qt
    creation_time   : 2019-09-17 22:06:44
  Duration: 00:00:06.42, start: 0.000000, bitrate: 47798 kb/s
    Stream #0:0(und): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, stereo, fltp, 113 kb/s (default)
    Metadata:
      creation_time   : 2019-09-17 22:06:44
      handler_name    : Core Media Data Handler
    Stream #0:1(und): Video: h264 (High) (avc1 / 0x31637661), yuv420p(tv, bt709), 3840x2160 [SAR 1:1 DAR 16:9], 47541 kb/s, 23.98 fps, 23.98 tbr, 24k tbn, 48k tbc (default)
    Metadata:
      creation_time   : 2019-09-17 22:06:44
      handler_name    : Core Media Data Handler
      encoder         : H.264
      timecode        : 00:00:00:00
    Stream #0:2(und): Data: none (tmcd / 0x64636D74), 0 kb/s (default)
    Metadata:
      creation_time   : 2019-09-17 22:06:44
      handler_name    : Core Media Data Handler
      timecode        : 00:00:00:00
At least one output file must be specified

最佳答案

您输入的帧速率为 24000/1001,但 image demuxer 的默认帧速率是 25。添加 -framerate输入选项:

ffmpeg -i input.mov \
       -framerate 24000/1001 -pattern_type glob -i 'result_*.tif' \
       -map 1 -map 0:a \
       -map_metadata 0 \
       -map_metadata:s:v 0:s:v \
       -map_metadata:s:a 0:s:a \
       output.mov

关于image-processing - ffmpeg - 将回帧合并到具有相同编码的视频,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58081970/

相关文章:

image-processing - 多 View 中校正图像点的三角测量

performance - 计算图像中已识别像素的局部均值和方差

windows - 如何使用 JpegTran 在使用 Windows 的目录中递归处理所有图像并覆盖它们?

ffmpeg 无法提取所有帧

ffmpeg - 在 ffmpeg 中进行后处理以在 MP4 文件中移动 'moov atom' (qt-faststart)

audio - ffmpeg:生成空的音频和视频(为视频工作)

c# - 在 C# 中调整 JPEG 图像的大小会降低其分辨率

python - OpenCV cap.get(cv2.CAP_PROP_FRAME_COUNT)返回-1

python - 使用 FFMPEG 和 FFSERVER 流式传输视频

encoding - MPEG-TS 分段 HTTP 直播