无意间发现一个好用的视频转换gif图片的开源框架
时间:2022-07-22
本文章向大家介绍无意间发现一个好用的视频转换gif图片的开源框架,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
Gifify
是一款工具类的开源框架,可以将任何视频文件转换为优化的动画GIF。
有些时候我们需要将
视频转换为动画GIF图
,可以更生动形象的描述我们想要说明的事物以及框架的使用方式,它对于程序员来说是一个不可或缺的工具
之一。
环境支持
在安装Gifify
之前首先我们需要先安装它所需要的运行环境:
- Node.js(
brew install node
) - FFmpeg(
brew install ffmpeg
) - ImageMagick(
brew install imagemagick
) - giflossy(
brew install giflossy
)
安装
可以通过npm
直接安装Gifify
,如下所示:
npm install -g gifify
命令行参数
下面是Gifify
所支持的命令行参数列表。
➜ ~ gifify -h
Usage: gifify [options] [file]
Options:
-V, --version output the version number
--colors <n> Number of colors, up to 255, defaults to 80 (default: 80)
--compress <n> Compression (quality) level, from 0 (no compression) to 100, defaults to 40 (default: 40)
--from <position> Start position, hh:mm:ss or seconds, defaults to 0
--fps <n> Frames Per Second, defaults to 10 (default: 10)
-o, --output <file> Output file, defaults to stdout
--resize <W:H> Resize output, use -1 when specifying only width or height. `350:100`, `400:-1`, `-1:200`
--reverse Reverses movie
--speed <n> Movie speed, defaults to 1 (default: 1)
--subtitles <filepath> Subtitle filepath to burn to the GIF
--text <string> Add some text at the bottom of the movie
--to <position> End position, hh:mm:ss or seconds, defaults to end of movie
--no-loop Will show every frame once without looping
-h, --help output usage information
视频转换为GIF
我使用Mac自带的屏幕录制软件QuickTime Player
录制了一个测试视频,根据上面的命令行参数来看如果我们不做一些其他的自定义,只添加-o、--output
输出的gif文件名即可,如下所示:
➜ gifify 屏幕录制2020-08-05 上午8.58.01.mov --output example.gif
Generating GIF, please wait...
当我们看到提示信息Generating GIF, please wait...
时,说明已经开始转换了,因为视频文件的大小有差异,所以转换所需要的时间也所有不同。
自动创建的
example.gif
文件与转换的视频文件在同一目录下。
image
GIF截取
如果你只需要转换视频中的一个时间段,我们可以通过指定--from
、--to
参数来配置,如下所示:
➜ gifify 屏幕录制2020-08-05 上午8.58.01.mov --output example.gif --from 00:00:10 --to 00:00:15
GIF压缩
Gifify
默认压缩比例为40%
,压缩后的Gif图可能会比较模糊,我们可以通过--compress
参数来修改压缩比例,0表示无压缩,取值范围为0~100
,如下所示:
➜ gifify 屏幕录制2020-08-05 上午8.58.01.mov --output example.gif --from 00:00:10 --to 00:00:12 --compress 0
总结
Gifify
还有很多隐藏的功能,比如在GIF图片上添加文字描述,缩放视频比例,反转视频等功能,赶快去发掘它的隐藏功能吧。
- Windows下获取网络连线实际名称,加强IP类设置脚本的兼容性
- Android APP 快速 Pad 化实现
- PHP彩蛋还是漏洞?expose_php彩蛋的触发和屏蔽方法
- 深入源码探索 ReactNative 通信机制
- PHP跨站脚本攻击(XSS)漏洞修复思路(二)
- WordPress发布文章自动同步到新浪微博(带特色图片)
- go http 服务器编程(1)
- Linux系统内存监控、性能诊断工具vmstat命令详解
- go http 服务器编程(2)
- 利用placeholder属性来添加输入框默认文字提示,提高用户体验
- Linux系统监控、诊断工具之top命令详解
- 【Dev Club分享】iOS黑客技术大揭秘
- Linux终端:用cat命令查看不可见字符
- golang 函数定义及其接口实例
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- SAP Cloud for Customer Oberon视图里的Ruby Scrip
- 干了SAP开发这么多年,我都积累了哪些程序调试技巧
- 谈谈SOCKET
- 使用ABAP实现Mock测试工具Mockito
- 增强版本的自开发SAP WebClient UI Repository Information System
- 最大子序列和的问题的解(1)
- 10-STM32+ESP8266+AIR202远程升级方案-功能3-手机APP控制STM32远程更新固件程序,基于ESP8266
- 最大子序列和的接口函数(2)
- 最大子序列和的接口函数(3)
- 【剑指Offer】二叉树的深度
- 运行时间中的对数
- IIC协议
- 通过例子学习编写shell
- 【redis6.0.6】redis源码慢慢学,慢慢看 -- 第三天:MakeFile
- 继续学习Shell脚本(详细)