Canvas与Image互相转换示例代码


Posted in HTML / CSS onAugust 09, 2013

JS Canvas与Image互相转换
原文演示: JavaScript Canvas Image Conversion Demo
在上周的Mozilla Web开发 会议,最后我们花了大半天的时间讨论未来的Mozilla市场应用。Instagram是近期最火爆的移动应用,以10亿美元的天价卖给了FaceBook。
我不介意赚取一些外快,所以我决定创建一个Instagram样式的应用(以后将会分享出来)

本文向您展示怎样转换Image为canvas,以及canvas如何提取出一个Image。

转换 Image为 Canvas
要把图片转换为Canvas(画板,画布),可以使用canvas元素 context 的drawImage方法:

复制代码
代码如下:

// 把image 转换为 canvas对象
function convertImageToCanvas(image) {
// 创建canvas DOM元素,并设置其宽高和图片一样
var canvas = document.createElement("canvas");
canvas.width = image.width;
canvas.height = image.height;
// 坐标(0,0) 表示从此处开始绘制,相当于偏移。
canvas.getContext("2d").drawImage(image, 0, 0);
return canvas;
}

转换 Canvas 为 Image
假设图像已经在canvas上处理好,那么可以使用以下方法,把canvas转变为图片Image对象。
复制代码
代码如下:

// 从 canvas 提取图片 image
function convertCanvasToImage(canvas) {
//新Image对象,可以理解为DOM
var image = new Image();
// canvas.toDataURL 返回的是一串Base64编码的URL,当然,浏览器自己肯定支持
// 指定格式 PNG
image.src = canvas.toDataURL("image/png");
return image;
}

额!图像image和canvas的互相转换比你想象的还要容易,以后我将向你演示不同的图像处理技术,相信在未来你肯定能用这些技术赚到大钱。
HTML / CSS 相关文章推荐
全面解析CSS Media媒体查询使用操作(推荐)
Aug 15 HTML / CSS
可以随进度显示不同颜色的css3进度条分享
Apr 11 HTML / CSS
几个CSS3的flex弹性盒模型布局的简单例子演示
May 12 HTML / CSS
用html5实现语音搜索框的方法
Mar 18 HTML / CSS
html5摇一摇代码优化包括DeviceMotionEvent等等
Sep 01 HTML / CSS
HTML5实现多张图片上传功能
Mar 11 HTML / CSS
HTML5的Video标签有部分MP4无法播放的问题解析(多图)
Aug 18 HTML / CSS
html5写一个BUI折叠菜单插件的实现方法
Sep 11 HTML / CSS
html5中使用hotcss.js实现手机端自适配的方法
Apr 23 HTML / CSS
AmazeUI 面板的实现示例
Aug 17 HTML / CSS
AmazeUI 模态窗口的实现代码
Aug 18 HTML / CSS
CSS 还能这样玩?奇思妙想渐变的艺术
Apr 27 HTML / CSS
通过Canvas及File API缩放并上传图片完整示例
Aug 08 #HTML / CSS
HTML5新增的Css选择器、伪类介绍
Aug 07 #HTML / CSS
HTML5 自动聚焦(autofocus)属性使用介绍
Aug 07 #HTML / CSS
HTML5 placeholder(空白提示)属性介绍
Aug 07 #HTML / CSS
5个你不知道的HTML5的接口介绍
Aug 07 #HTML / CSS
HTML5梦幻之旅——炫丽的流星雨效果实现过程
Aug 06 #HTML / CSS
使用HTML5拍照示例代码
Aug 06 #HTML / CSS
You might like
URL Rewrite的设置方法
2007/01/02 PHP
php处理静态页面:页面设置缓存时间实例
2017/06/22 PHP
php实现获取农历(阴历)、节日、节气的类与用法示例
2017/11/20 PHP
Javascript 通过json自动生成Dom的代码
2010/04/01 Javascript
js清空表单数据的两种方式(遍历+reset)
2014/07/18 Javascript
JS日期格式化之javascript Date format
2015/10/01 Javascript
AngularJs实现分页功能不带省略号的代码
2016/05/30 Javascript
jquery实现上传文件大小类型的验证例子(推荐)
2016/06/25 Javascript
js单页hash路由原理与应用实战详解
2017/08/14 Javascript
Vue2.0用 watch 观察 prop 变化(不触发)
2017/09/08 Javascript
详解Vuex管理登录状态
2017/11/13 Javascript
完美解决axios跨域请求出错的问题
2018/02/05 Javascript
layDate插件设置开始和结束时间
2018/11/15 Javascript
JS中创建自定义类型的常用模式总结【工厂模式,构造函数模式,原型模式,动态原型模式等】
2019/01/19 Javascript
vue组件开发props验证的实现
2019/02/12 Javascript
vue实现微信获取用户信息的方法
2019/03/21 Javascript
基于elementUI实现图片预览组件的示例代码
2019/03/31 Javascript
常见的浏览器存储方式(cookie、localStorage、sessionStorage)
2019/05/07 Javascript
vue 解决兄弟组件、跨组件深层次的通信操作
2020/07/27 Javascript
openLayer4实现动态改变标注图标
2020/08/17 Javascript
[00:35]DOTA2上海特级锦标赛 VP战队宣传片
2016/03/04 DOTA
Python进程池Pool应用实例分析
2019/11/27 Python
windows下的pycharm安装及其设置中文菜单
2020/04/23 Python
物业管理个人自我评价
2013/11/08 职场文书
单位提档介绍信
2014/01/17 职场文书
机关财务管理制度
2014/01/17 职场文书
茶叶店创业计划书范文
2014/01/19 职场文书
财务学生的职业生涯发展
2014/02/11 职场文书
学习十八届三中全会精神实施方案
2014/02/17 职场文书
《油菜花开了》教学反思
2014/02/22 职场文书
岗位职责说明书
2014/05/07 职场文书
领导干部对照检查材料
2014/08/24 职场文书
医生党的群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
提档介绍信范文
2015/10/22 职场文书
校园安全教育心得体会
2016/01/15 职场文书
八年级英语教学反思
2016/02/15 职场文书