Canvas与Image互相转换示例代码
程序员文章站
2023-11-17 15:01:22
本文向大家展示怎样转换Image为canvas,以及canvas如何提取出一个Image,示例代码如下,有此需求的朋友可以参考下,希望对大家有所帮助... 13-08-09...
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的互相转换比你想象的还要容易,以后我将向你演示不同的图像处理技术,相信在未来你肯定能用这些技术赚到大钱。
原文演示: 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的互相转换比你想象的还要容易,以后我将向你演示不同的图像处理技术,相信在未来你肯定能用这些技术赚到大钱。