gpt4 book ai didi

video - FFmpeg 复杂过滤器和 -vf 将图像填充和缩放到视频

转载 作者:行者123 更新时间:2023-12-04 22:52:21 29 4
gpt4 key购买 nike

我正在尝试在不同时间点用多个图像覆盖视频。这里的问题是图像可能比视频大,但它们应该按比例缩小(保持纵横比)并且缺失的空间应该用黑色填充。

这是我到目前为止所拥有的:

-i 'input_video.mp4' 
-i 'input_image_1.jpg'
-i 'input_image_2.jpg'
-i 'input_image3.jpg'
-i 'input_image4.jpg'
-filter_complex "[0][1] overlay=0:0:enable='between(t,0.0,2.0)'[s1];
[s1][2] overlay=0:0:enable='between(t,7.0,9.0)'[s2];
[s2][3] overlay=0:0:enable='between(t,18.0,20.0)'[s3];
[s3][4] overlay=0:0:enable='between(t,20.0,22.0)'[s4];"
-vf 'scale=min(iw*540/ih,960):min(540,ih*960/iw),
pad=960:540:(960-iw)/2:(540-ih)/2'
-pix_fmt yuv420p -c:a copy
'output_image.mp4'

scale 和 pad 中的值是动态得出的,并且对应于视频高度和视频宽度。

然而,有了这个突击队,FFmpeg 提示 -filter_complex-vf不能用于同一个突击队。我想避免先缩小图像或从中创建视频文件,然后再叠加这些视频。

任何指针表示赞赏。

最佳答案

利用

-i 'input_video.mp4' 
-i 'input_image_1.jpg'
-i 'input_image_2.jpg'
-i 'input_image3.jpg'
-i 'input_image4.jpg'
-filter_complex
"[1]scale=min(iw*540/ih,960):min(540,ih*960/iw),
pad=960:540:(960-iw)/2:(540-ih)/2[img1];
[2]scale=min(iw*540/ih,960):min(540,ih*960/iw),
pad=960:540:(960-iw)/2:(540-ih)/2[img2];
[3]scale=min(iw*540/ih,960):min(540,ih*960/iw),
pad=960:540:(960-iw)/2:(540-ih)/2[img3];
[4]scale=min(iw*540/ih,960):min(540,ih*960/iw),
pad=960:540:(960-iw)/2:(540-ih)/2[img4];
[0][img1] overlay=0:0:enable='between(t,0.0,2.0)'[s1];
[s1][img2] overlay=0:0:enable='between(t,7.0,9.0)'[s2];
[s2][img3] overlay=0:0:enable='between(t,18.0,20.0)'[s3];
[s3][img4] overlay=0:0:enable='between(t,20.0,22.0)'[s4];"
-c:a copy 'output_image.mp4'

关于video - FFmpeg 复杂过滤器和 -vf 将图像填充和缩放到视频,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47419154/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com