用canvas给视频图片添加特效
Canvas制作视频图片特效
1. Canvas介绍
1.1Canvas是html5上的一个画布标签,功能有点类似java的swing.可以在canvas上画线条 弧线, 文字 就是画布的功能.
具体提供的js函数看http://www.w3school.com.cn/tags/html_ref_canvas.asp
2 简单介绍一下使用:
Var canvas = document.documentElementById(“canvasId”);
Var ctx = canvas.getContext(“2d”);//获取维数对象
ctx.drawImage(img);//img为dom图片对象, 还有其他可选参数 剪切坐标 和 放置到canvas上的坐标
3给图片添加特效
原理: 图片通过drawImage函数 绘制到 canvas 上之后, 用getImageData函数可以获得
图片的imageData对象, imageData里有一个data数组存放的是 此图片的r g b a (三原色 和透明度). 将取出的data数组修改成对应特效数组, 用putImageData函数 重新数据放回canvas上即可.
小demo 代码(将图片设置成灰白效果 原理: 将r g b 设置成rgb平均数):
<!---------------- html --------------------->
<img id=”image1” src=”/img.jpg” />
<canvas id=”can” width=”500” heigth=”300”> </canvas>
<!-- 注意: canvas的宽高只能通过属性设置, 在style中设置没有效果 -->
<!---------------- js --------------------->
Var img = document.documentElementById(“imgage1”);
Var canvas = document.documentElementById(“can”);
Var ctx = canvas.getContext(“2d”);//获取维数对象
ctx.drawImage(img);
Var imgData = ctx.getImageData(0, 0, 500, 300);
For ( var i = 0, len = imgData.data.length, avgRgb; i < len; i += 4) {
avgRgb = (imgData.data[i] + imgData.data[i + 1] + imgData.data[i + 2]) / 3;
imgData.data[i] = avgRgb;
imgData.data[i + 1] = avgRgb;
imgData.data[i + 2 ] = avgRgb;
}
ctx.putImageData(imgData, 0, 0);
4 给视频添加特效
原理: 与图片的原理类似,只是要绘制视频每一帧的画面, 视频每播放一帧,就在canvas上绘制一帧画面
小demo 代码 (将视频画面红色调高 原理: 将r g b 中的r 调高)
<!---------------- html --------------------->
<video id=”vid1” src=”/vid1.mp4” autoplay/>
<canvas id=”can” width=”500” heigth=”300”> </canvas>
<!---------------- js --------------------->
Var vid= document.documentElementById(“vid1”);
Var canvas = document.documentElementById(“can”);
Var ctx = canvas.getContext(“2d”);//获取2维对象
function drawVidEffect() {
ctx.drawImage(vid);
Var imgData = ctx.getImageData(0, 0, 500, 300);
For ( var i = 0, len = imgData.data.length, avgRgb; i < len; i += 4) {
imgData.data[i] += 50;
}
ctx.putImageData(imgData, 0, 0);
setTimeout( drawVidEffect, 20 );
}
5 注意
如果视频或者图片所在的域名 跟canvas所在域名不一样 或者 不在服务器上运行 会报错:
Uncaught SecurityError: Failed to execute 'getImageData' on 'CanvasRenderingContext2D': The canvas has been tainted by cross-origin data.
解决办法:将图片或者视频加上属性crossOrigin但是添加后不能更换src地址
详见:
http://camnpr.com/archives/1117.html
http://camnpr.com/TuiJianTools/html5/canvas-cross-domain-images.html
用canvas给视频图片添加特效的更多相关文章
- Win10技巧:使用“照片”应用剪辑视频、添加特效
Win10内置了很多实用的应用,你不仅可以通过“Win键+G”快速录制电脑屏幕,如软件操作.游戏界面等,你还可以利用“照片”应用来对视频进行快速的剪辑,把录制前后多余的内容去除,同时你也可以对游戏中的 ...
- 基于HTML5 Canvas实现的图片马赛克模糊特效
效果请点击下面网址: http://hovertree.com/texiao/html5/1.htm 一.开门见山受美国肖像画家Chuck Close的启发,此脚本通过使用HTML5 canvas元素 ...
- 使用Kdenlive为视频加入马赛克特效
Kdenlive(KDE Non-Linear Video Editor)是一种基于MLT框架.KDE和Qt的自由开源的非线性影片编辑器.其底层包含了FFmpeg,所以可以支持FFmpeg中的所有视频 ...
- 使用图片视频展示插件blueimp Gallery改造网站的视频图片展示
在很多情况下,我们网站可能会展示我们的产品图片.以及教程视频等内容,结合一个比较好的图片.视频展示插件,能够使得我们的站点更加方便使用,也更加酷炫,在Github上有很多相关的处理插件可以找来使用,有 ...
- 在object,embed上添加跳转链接(视频上添加跳转)
今天遇到个问题,就是在视频上添加跳转链接时,谷歌浏览器能正常跳转,但是ie下,却无效,视频使用object引入,<a>标签跟随其后采用绝对定位,和平时的图片加跳转操作一样.原来是需要加上& ...
- 基于 HTML5 Canvas 实现的文字动画特效
前言 文字是网页中最基本的元素,一般我们在网页上都是展示的静态文字,但是就效果来说,还是比较枯燥的.文字淡入淡出的动画效果在项目中非常实用,如果有某些关键的文字,可以通过这种动态的效果来提醒用户阅读. ...
- 微信小程序--canvas画布实现图片的编辑
技术:微信小程序 概述 上传图片,编辑图片大小,添加文字,改变文字颜色等 详细 代码下载:http://www.demodashi.com/demo/14789.html 概述 微信小程序--ca ...
- [Xcode 实际操作]六、媒体与动画-(5)使用CoreImage框架给图片添加马赛克效果
目录:[Swift]Xcode实际操作 本文将演示如何使用CoreImage图像处理框架,给图片添加像素化的滤镜效果. 在项目导航区,打开视图控制器的代码文件[ViewController.swift ...
- android图像处理系列之四-- 给图片添加边框(上)
图片处理时,有时需要为图片加一些边框,下面介绍一种为图片添加简单边框的方法. 基本思路是:将边框图片裁剪成八张小图片(图片大小最好一致,不然后面处理会很麻烦),分别对应左上角,左边,左下角,下边,右下 ...
随机推荐
- [Java]LeetCode297. 二叉树的序列化与反序列化 | Serialize and Deserialize Binary Tree
Serialization is the process of converting a data structure or object into a sequence of bits so tha ...
- [Swift]LeetCode381. O(1) 时间插入、删除和获取随机元素 - 允许重复 | Insert Delete GetRandom O(1) - Duplicates allowed
Design a data structure that supports all following operations in averageO(1) time. Note: Duplicate ...
- [Swift]LeetCode554. 砖墙 | Brick Wall
There is a brick wall in front of you. The wall is rectangular and has several rows of bricks. The b ...
- [Swift]LeetCode864. 获取所有钥匙的最短路径 | Shortest Path to Get All Keys
We are given a 2-dimensional grid. "." is an empty cell, "#" is a wall, "@& ...
- [Swift]LeetCode955. 删列造序 II | Delete Columns to Make Sorted II
We are given an array A of N lowercase letter strings, all of the same length. Now, we may choose an ...
- kubernetes系列之ConfigMap使用方式
作用理解 核心用途就是容器和配置的分离解耦. 如启用一个mysql容器,mysql容器重要的文件有两部分,一部分为存储数据文件,一部分为配置文件my.cnf,存储数据可以用持久存储实现和容器的分离解耦 ...
- Python内置函数(64)——tuple
英文文档: The constructor builds a tuple whose items are the same and in the same order as iterable‘s it ...
- Zara精讲C#.Cache、它和Redis区别是什么???
前言:今天在博客园看到大佬在用Cache,非常不懂,原来它是搞缓存的,原来我只知道Redis是搞这个的,才知道有这个玩腻. 那它们的区别是什么呢?? 区别: redis是分布式缓存,是将数据随机分配到 ...
- C# for Python(Nugut Iron包)
cInronPython是一种在.NET和Mono上实现的Python语言,使用InronPython就可以在.NET环境中调用Python代码 安装InronPython Python: port ...
- PV UV QPS 并发数
TPS(Transactions Per Second):每秒事务数 QPS(Query Per Second):每秒请求数,QPS其实是衡量吞吐量的一个常用指标,就是说服务器在一秒的时间内处理了多少 ...