HTML5 Canvas 撤销上一次操作

利用canvas的getImageData复制当前画布(canvas)上的内容进行保存,再通过putImageData将之前保存的canvas内容覆盖到画布(canvas)上,以达到撤销的功能。

getImageData() 方法返回 ImageData 对象,该对象拷贝了画布指定矩形的像素数据。

对于 ImageData 对象中的每个像素,都存在着四方面的信息,即 RGBA 值:

  • R - 红色 (0-255)
  • G - 绿色 (0-255)
  • B - 蓝色 (0-255)
  • A - alpha 通道 (0-255; 0 是透明的,255 是完全可见的)

color/alpha 以数组形式存在,并存储于 ImageData 对象的 data 属性中。

putImageData() 方法将图像数据(从指定的 ImageData 对象)放回画布上。

参考:http://www.w3school.com.cn/tags/canvas_getimagedata.asp

 

 1     var imgData;
 2     function canvas_copy(){
 3         var context = document.getElementById("pic").getContext('2d');
 4         var width = context.canvas.width;
 5         var height = context.canvas.height;
 6         imgData = context.getImageData(0, 0, width, height);
 7     }
 8 
 9     function canvas_paste(){
10         var context = document.getElementById("pic").getContext('2d');
11         context.putImageData(imgData,0,0);
12     }
13 
14     function pic_cancel(){
15         canvas_paste();
16     }

 

转载于:https://www.cnblogs.com/moyan03/p/5620320.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值