网站首页
网站导航
Ctrl+D收藏
首 页
代码段
源码包
文档库
工具箱
代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
JS
】
NW.JS之MP4转GIF
作者:
L3ve
/ 发布于
2015/2/15
/
525
zweiGif = (function () { var video = ele("#zweiVideo"), canvas = document.createElement("canvas"), i, w = 100, h = 100, status = "start", gif = new GIF({ workers: 4, quality: 10, workerScript: 'gif.worker.js' }); function Zweigif() { } function loop() { canvas.getContext("2d").drawImage(video, 0, 0, w, h); gif.addFrame(canvas, {copy: true, delay: 20}); i = requestAnimationFrame(loop); } document.onkeydown = function () { console.log(window.event.keyCode); if (window.event && window.event.keyCode == 32) { event.cancelBubble = true; makeGif(); } }; function makeGif() { if (status == "start") { gif.abort(); gif.frames = []; i = loop(); document.querySelector("#drag").classList.add("flashing"); ele("#per").innerHTML = "录制中!~"; status = "end"; this.innerHTML = "end"; } else { cancelAnimationFrame(i); gif.render(); status = "start"; this.innerHTML = "start"; } } canvas.width = w; canvas.height = h; //视频转gif Zweigif.prototype.makeGif = function () { gif.on('finished', function (blob) { var img = document.createElement("img"), div = document.createElement("div"); img.setAttribute("src", URL.createObjectURL(blob)); div.setAttribute("class", "box"); div.appendChild(img); ele("#video-gif").appendChild(div); document.querySelector("#drag").classList.remove("flashing"); //消除子元素继承父元素的事件 img.addEventListener('click', function (e) { e.stopPropagation(); }, false); div.addEventListener('click', function () { div.parentNode.removeChild(div); }, false); }); gif.on('progress', function (p) { if (p == 1) { ele("#per").innerHTML = "已完成!~"; } else { ele("#per").innerHTML = Math.round(p * 100) + "%"; } }); }; Zweigif.prototype.setGif = function (neww, newh) { gif = null; w = neww; h = newh; canvas.width = w; canvas.height = h; gif = new GIF({ workers: 4, quality: 1, workerScript: 'gif.worker.js', width: neww, height: newh }); }; return new Zweigif(); })();
评论列表
本站所提供的代码,版权归原作者所有,若有侵犯作者版权,请与我们联系,我们将立即删除或修改。谢谢!
本站所有代码发布及提供者。
试试其它关键字
MP4转GIF
同语言下
.
Jquery搜索框获取回车事件
.
H5页面添加倒计时,然后自动跳转
.
通过user-agent判断h5页面是在哪个手机App(QQ、微信
.
nginx 禁止未绑定的域名访问
.
JavaScript 获取按键,并屏蔽系统 Window 事件
.
H5之只允许微信浏览器打开,禁止从外部浏览器访问
.
微信打开网址添加在浏览器中打开提示的办法
.
实现JS复制、粘贴,Chrome/Firefox下可用
.
video视频播放,play()、pause()、duration时长、onen
.
HTML5实现MP3上传前的预览和播放时长的获取
可能有用的
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
.
实现对图片上传的接收
.
判断用户输入的是否为IP地址
L3ve
贡献的其它代码
(
1
)
.
NW.JS之MP4转GIF
地图
本站
我们
服务
版权
联系
回馈
博客