网络上经常可以看到一些“截图某一张视频画面,并把后续字幕连续拼接在一起”的图片,可以快速传递视频内的内容。
当然,这很容易造假。所以当你看到类似内容的时候,需要自行判断。
这个脚本,就是用来实现这个功能的。需要说明的是,这个脚本不是为了造假而生的,仅仅是出于娱乐与交流的目的。
先给出 GitHub 地址:https://github.com/jifengg/ffmpeg-script
比如我用“功夫熊猫 4”里的某个画面,搭配我自己编写的一段话,生成:
脚本运行时间 2 秒左右。
使用方式:
node ffmpeg.subtitle.stack.js -i <video_file> -t <text_file> -font <font_file> [-o <output> ...]
支持的参数:
-i <string> [必须]视频文件路径
-t <string> [必须]文本文件路径。用两个换行符分隔的字幕,支持用一个换行符实现字幕换行
-o <string> 生成的图片文件路径,默认:<输入视频文件名>_subtitle.jpg
-y 是否覆盖已经存在的图片文件,默认:false
-size <number> 生成的图片宽度,默认:400
-ss <number> 从视频的第几秒开始处理,格式同 ffmpeg 的-ss ,默认:0
-interval <number> 截取视频画面的两帧之间的间距,单位秒,默认:5
-sh <number> 要截取的字幕区域占画面高度的比例,取值 0.0 (不含) ~ 1.0 (含),默认:0.1666
-font <string> 字体文件路径,非 windows 下使用时必传,默认:c:/Windows/Fonts/msyh.ttc (微软雅黑)
-h 显示这个帮助信息
-debug 是否开启 debug 模式,打印更详细的日志
注意文本文件的编写要求,格式如下:
第一行
first line
第二行
second line
其它
others
使用一个空行(\n\n )来分隔两个文本信息,只间隔一个\n 的文本会以多行字幕的形式绘制到画面上。
技术点主要是对 ffmpeg 各种滤镜的应用,有:
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.