使用FFMPEG制作GIF

来源:互联网 发布:three.js注释库 编辑:程序博客网 时间:2024/04/29 07:14

只需要用到 FFmpeg。绝大多数发行版都已经将它收录官方仓库,通过包管理器就可以安装。

假设我们需要转换的视频文件是 input.ogg,输出的GIF文件是 output.gif。这里不讨论如何截取视频中的段落(因为命令太繁琐了)等视频剪辑的问题,需要转换的视频已经经过简单处理,可以直接使用。

基本命令:

1
ffmpeg -i input.ogg output.gif

第一次制作的gif就是这么来的。然后当我试图上传到 Google+ 的时候发现…

区区几百KB的视频片段制作出来的GIF竟然有20M之巨啊! 原视频是1080p 50fps的 flv

于是需要两个参数,一个是缩小分辨率一个是减少帧数。50帧确实少见,但是一般来讲 gif 有15帧左右就比较流畅了。命令

1
ffmpeg -i input.ogg -s 640x320 -r 15 output.gif

很多人喜欢把 -r 选项放在前面… 按照某个早就忘记在哪的邮件列表里的说法,-r 放在 输入文件 的 后面 才是输出文件的效果。上面的命令出来的结果就是分辨率为640×320,帧率为15的gif了。640x320 中间是小写字母 x

----------------------------------------------------------------------------------------------------------------------

----------------------------------------------------------------------------------------------------------------------

     把gif拖进浏览器预览,结果发现:即使帧率降到了1 fps(从源视频里每隔一秒抽取一帧图像输出到目标文件),整个动画播放还是持续了10秒钟,看着很揪心!能不能在源视频跳帧的情况下同时提高GIF的播放速率呢(比如说在2秒内播完)?查了一遍FFmpeg的说明文档,似乎没有哪个参数可以快速达到这样的目的。也罢,那就分两步走吧:
首先,执行:

 ffmpeg -ss 25 -t 10 -i D:\Media\bear.wmv -r 1 -s 320x240 -f image2 D:\foo-%03d.jpeg
从源视频中每秒钟抽取一帧图像,保存为一系列JPEG文件。

然后,再执行:
 ffmpeg -f image2 -framerate 5 -i D:\foo-%03d.jpeg D:\c.gif
将这一系列JPEG图像合成为帧率5 fps的GIF文件。

Bingo!

上面提到,把GIF文件拖进浏览器可以进行预览。当然,使用ffplay.exe工具也是可以的——命令行:ffplay D:\a.gif。


0 0
原创粉丝点击