使用canvas截图或者改变灰度
简述
html5新添加的canvas API可以让我们对画布进行开发应用,典型的是可以使用canvas截图或者
手工绘制“迷你图”(即嵌入在文本中的高清小图片)。
实现截图的方法很简单,就是创建一个canvas并用drawImage来获取该时刻视频帧,并使用canvas的
toDataURL转换成data URI。
也可对视频帧或者图片帧数据进行操作,drawImage返回ImageData对象,我们可以对该对象进行相关
处理计算。
在对canvas的事件处理中,我们有时需要判断当前点是否在某条路经或者某个图片上,可以通过event.clientX(Y)
来获取点击点在客户区的坐标,因此需要转换为canvas坐标系中的坐标,并且需要考虑到canvas坐标系的放缩。
因此可以这样实现:
//判断当前点是否已经绘制。
function isInPaint(graphic,e){
var cx = e.clientX,cy = e.clientY;
var r = graphic.canvas.getBoundingClientRect();
var imgData;
cx = (cx - r.left) * (graphic.canvas.width / r.width);
cy = (cy - r.top) * (graphic.canvas.height / r.height);
//取出点击的该像素的数据
//判断当前像素的alpha值是否为0
imgData = graphic.getImageData(cx,cy,,);
for(var i=,len=imgData.length;i<len;i+=){
if(imgData[i+] == )
return false;
}
return true;
}
//判断点是否在路径上,使用context的原生方法
function isInPath(graphic,e){
var cx = e.clientX,cy = e.clientY;
var r = graphic.canvas.getBoundingClientRect();
var imgData;
cx = (cx - r.left) * (graphic.canvas.width / r.width);
cy = (cy - r.top) * (graphic.canvas.height / r.height);
return graphic.isPointInPath(cx,cy);
}
视频截图的demo:
<div>
<video id="v" controls="controls" autoplay="autoplay" src="a.mp4" width="500" height="300"></video>
</div>
<canvas id="c" width="500" height="300"></canvas>
<div>
<img id="shot" width="500" height="300" >
</div>
<button id="btn">点击截图</button>
<script>
function $(i){return document.getElementById(i)}
var c = $("c"),v = $("v");
var g = c.getContext("2d");
var btn = $("btn"),img = $("shot");
function gray(g){
var imageData,data,avr;
g.drawImage(v,0,0,g.canvas.width, g.canvas.height);
imageData = g.getImageData(0,0, g.canvas.width, g.canvas.height);
data = imageData.data;
//data包含图片像素信息,每个像素按照R、G、B、A 4个字节依次排列。
//其中 data.width 为列数,data.height 为行数。
// 可以使用 imageData_cache = g.createImageData(imgdata)创建缓存
for(var i=0,len=data.length;i<len;i+=4){
avr = (data[i] + data[i+1] + data[i+2]) / 3;
data[i+2] = data[i+1] = data[i] = avr;
}
// 使用putImageData,则对全局透明度globalAlpha以及其他合成处理则
// 没有效果,即参数中的imageData为最终处理值。
g.putImageData(imageData,0,0);
requestAnimationFrame(function(){gray(g)});
}
function shot(){
var imageData,data,avr,canvas,graphic;
canvas = document.createElement("canvas");
canvas.style.cssText = "width:500px;height:300px;"
graphic = canvas.getContext("2d");
graphic.drawImage(v,0,0,graphic.canvas.width, graphic.canvas.height);
img.src = canvas.toDataURL();
canvas = null;
} window.onload = function(){
v.addEventListener('play', function(){
requestAnimationFrame(function(){gray(g)});
},false);
btn.addEventListener("click",function(){
shot()
},false)
} </script>
使用canvas截图或者改变灰度的更多相关文章
- webRTC结合canvas截图
直接看代码.css基础弱鸡,将就看吧.慢慢学习 <!DOCTYPE html> <html> <head> <meta charset="utf-8 ...
- 小程序canvas截图组件
最近做一个小程序的过程中,需要用到截图功能,网上搜了一下,发现没有符合要求的,就自己搞了个组件,方便复用. 目前功能很简单,传入宽高和图片路径即可,宽高是为了计算截图的比例,只支持缩放和移动. 实现思 ...
- 使用canvas截图网页为图片并解决跨域空白以及模糊问题
前几天给了个需求对浏览器网页进行截图,把网页统计数据图形表等截图保存至用户本地. 首先对于网页截图,我用的是canvas实现,获取你需要截图的模块的div,从而使用canvas对你需要的模块进行截图. ...
- Wx-小程序-使用canvas截图保存
1. wxml 页面 使用画布来站位,并给按钮添加绑定事件 <button class='btn btn-theme' bindtap='setSaveImage'>保存图片到本地< ...
- 用canvas实现图片滤镜效果详解之灰度效果
前面展示了一些canvas实现图片滤镜效果的展示,并且给出了相应的算法,下面来介绍一下具体的实现方法. 前面介绍的特效中灰度效果最简单,就从这里开始介绍吧. 1.获取图像数据 img.src = ’h ...
- 带你从0到1实现canvas的undo和redo功能
不知不觉又到了周末,又到了Fly写文章的日子,今天给大家介绍下一个web中很常见的功能, 就是撤销和复原这样一个功能,对于任何一个画图软件,或者是建模软件.没有撤销和复原.这不是傻了对啊吧,所以本篇文 ...
- Unity5.3——UI之Canvas
原文:http://docs.unity3d.com/Manual/UISystem.html Canvas 所有的UI都应该放在Canvas里面(子层).Canvas是一个带有Canvas组件的Ga ...
- H5新特性-canvas绘图--渐变对象路径(最复杂)--图片--变形操作
今天的目标 3.1:canvas绘图--(重点掌握:渐变对象.路径.图片.变形) 3.2:canvas绘图--渐变对象 线性渐变: linearGradient 径向渐变: var g = ctx.c ...
- Unity中UGUI之Canvas属性解读版本二
Canvas Render Modes(渲染模式) 1.在screen空间中渲染2.在world空间中渲染 Screen Space-Overlay 在这个渲染模式中,UI元素将在场景的上面.如果场景 ...
随机推荐
- 如何在select下拉列表中添加复选框?
近来在给一个公司做考试系统的项目,遇到的问题不少,但其中的几个让我对表单的使用颇为感兴趣,前端程序员都知道,下拉列表有select标签,复选框有checkbox,但是两者合在一起却少有人去研究,当时接 ...
- Python之路第一课Day7--随堂笔记(面向对象编程进阶...未完待续 )
本节内容: 面向对象高级语法部分 静态方法.类方法.属性方法 类的特殊方法 反射 异常处理 Socket开发基础 作业:开发一个支持多用户在线的FTP程序 面向对象高级语法部分 一.静态方法 通过@s ...
- 深入理解css BFC 模型
如果要深入理解css布局的各种原理,要在重构页面做得心应手的话,那么你就必须先理解这玩意 "BFC" , BlockFormatting Context(块级格式化上下文): 这里 ...
- Ajax的二次封装
function handleAjax(url,_data,method) { return ajax(url,_data,method).then(function (res) { if(res){ ...
- Nginx模块参考手册:HTTP核心模块
FROM: http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=17238776&id=2982697 这些模块默认会全部编 ...
- linux 实践2.2 编译模块
1. 理解模块原理 linux模块是一些可以作为独立程序来编译的函数和数据类型的集合.之所以提供模块机制,是因为Linux本身是一个单内核.单内核由于所有内容都集成在一起,效率很高,但可扩展性和可维 ...
- XMPP iOS客户端实现二:xcode项目配置
1.下载XMPPFramework,下载地址:https://github.com/robbiehanson/XMPPFramework 2.创建项目并将XMPP库引入: 3.添加需要的库文件: 4. ...
- CYQ.Data 快速开发EasyUI
EasyUI: 前端UI框架之一, 相对ExtJs来说,算是小了,这两天,抽空看了下EasyUI的相关知识,基本上可以和大伙分享一下: 官网: http://www.jeasyui.com/ 学习的话 ...
- Guava Supplier实例
今天想讲一下Guava Suppliers的几点用法.Guava Suppliers的主要功能是创建包裹的单例对象,通过get方法可以获取对象的值.每次获取的对象都为同一个对象,但你和单例模式有所区别 ...
- [.net 面向对象程序设计进阶] (27) 团队开发利器(六)分布式版本控制系统Git——在Visual Studio 2015中使用Git
[.net 面向对象程序设计进阶] (26) 团队开发利器(六)分布式版本控制系统Git——在Visual Studio 2015中使用Git 本篇导读: 接上两篇,继续Git之旅 分布式版本控制系统 ...