hello ,兄弟们,我又来分享我的 ffmpeg 脚本啦。
前段时间看到一个视频,对某个游戏的物体进行了评分排行,然后用滚动的方式展示出来,想着这种方式应该可以用自动化的方式实现,于是就想着用 ffmpeg 实现一下。
声明:请不要用这个脚本产生内容单调的垃圾视频。
先给出 GitHub 地址:https://github.com/jifengg/ffmpeg-script
GitHub 上有生成的效果视频,或直接点击这里查看。
使用方式:
node ffmpeg.images.rolling.js -i <image_folder> [-o <output> ...]
支持的参数:
-i <string> [必须]图片所在的目录
-duration <number> 每张图片从出现到消失的时长(秒),默认:20
-direction <string> 图片滚动的方向,可选:rl (从右到左,默认),lr (从左到右)
-margin <number[|number[|number|number]]>
图片之间的间距,支持的格式:all 、vertical|horizontal 、top|right|bottom|left ,默认 all=20
-o <string> 输出视频的路径,默认为输入目录下的 output.mp4
-fps <number> 输出视频的帧率,默认:25
-y 是否覆盖已经存在的输出文件,默认:false
-bgimage <string> 背景图片的路径,比 bgcolor 优先,默认:无
-blursigma <number> 背景图片虚化的 sigma 值,为 0 表示不虚化,默认:15
-bgcolor <string> 背景颜色,值的格式同 ffmpeg 的 color ,默认:black
-width <number> 输出视频的宽度,默认:1920
-height <number> 输出视频的高度,默认:1080
-top <number> 图片区距离视频顶部的距离,默认:0
-bottom <number> 图片区距离视频底部的距离,默认:0
-title <string> 视频的标题,显示在画面上方,默认:无
-tsize <number> 标题文字大小,默认:80
-tcolor <string> 标题文字颜色,值的格式同 ffmpeg 的 color ,默认:white
-tbordercolor <string> 标题边框颜色,值的格式同 ffmpeg 的 color ,默认:black
-tfont <string> 标题字体文件路径,非 windows 下使用时必传,默认:c:/Windows/Fonts/msyh.ttc (微软雅黑)
-footer <string> 视频的底部文字(脚注),显示在画面下方,默认:无
-fsize <number> 脚注文字大小,默认:30
-fcolor <string> 脚注文字颜色,值的格式同 ffmpeg 的 color ,默认:white
-fbordercolor <string> 脚注边框颜色,值的格式同 ffmpeg 的 color ,默认:black
-ffont <string> 脚注字体文件路径,非 windows 下使用时必传,默认:c:/Windows/Fonts/msyh.ttc (微软雅黑)
-h 显示这个帮助信息
-debug 是否开启 debug 模式,打印更详细的日志
我也写了这个脚本编写过程遇到的一些问题及解决方案,可以到 GitHub 上查看ffmpeg.images.rolling.md。
1
lozzow 224 天前
如果是我的话,我只会写个 web,然后录屏😭
|
3
maymay5 224 天前
我超,我觉得可以跟我融合一下,我用的也是 ffmpeg 合成的: https://www.v2ex.com/t/1020294
|
4
weak 224 天前 via iPhone
对我来说 还是 AE 简单
|
5
HUZHUANGZHUANG 224 天前
为什么我的眼睛看 <以水平滚动的方式,展示多张图片的例子>,感觉视频有些抖动
|
6
jifengg OP @HUZHUANGZHUANG
一方面呢,视频在显示这种匀速运动的时候,人眼很容易有错觉。这个也和显示器刷新率有关, https://github.com/jifengg/ffmpeg-script/blob/main/docs/ffmpeg.images.rolling.md#%E5%B8%A7%E7%8E%87 文档关于帧率这块有一个说明,链接的 B 站视频也可以看看。 可以自己尝试做一些不同帧率的视频看看效果。 |
7
wen20 221 天前
抖动的很严重,费眼,得优化。
|
9
unii23i 220 天前
马一下
|