javascript – JS / HTML5 – 使用数组中的图像数据重绘画布
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – JS / HTML5 – 使用数组中的图像数据重绘画布,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1765字,纯文字阅读大概需要3分钟。
内容图文
我正在尝试为画布实现撤消功能.基本上人们可以在画布上绘画,然后将其恢复到以前的状态.这就是理论.
每次调用函数绘制时,我都会保存当前的imageData.它保存在数组eD(名称空间).history中.即使我操作imageData,绘图也能正常工作.这是我的绘图功能(cD是一个命名空间):
editorClass.prototype.draw = function(){
eD.history.push(cD.imageData);
cD.context.putImageData(cD.imageData, 0, 0);
}
现在,如果我尝试撤消我之间所做的更改,我会使用一个名为undo的函数,它看起来像这样:
editorClass.prototype.undo = function(){
var temp = eD.history.pop();
cD.context.createImageData(cD.width,cD.height); //Can leave this out, nothing changes
cD.context.putImageData(temp, 0, 0);
}
如上所述,这是行不通的.我使用的画布是在用户加载网站后创建的. cD.imageData源自此函数:
editorClass.prototype.getPixels = function(){
cD.imageData = cD.context.getImageData(0, 0, cD.width, cD.height);
// get the image data of the context and save them into namespace
cD.pixels = cD.imageData.data;
// get the pixels
cD.pixelsLength = cD.width * cD.height * 4;
// precompute the length of the pixel array
}
如果需要,两个名称空间都是可见的.因为我对画布很陌生,所以它可能是一个简单的问题 – 所以如果你有改进:我是空洞的,请把我填满;)
谢谢
解决方法:
没有看到所有的代码,我不确定为什么你的代码没有工作,但我怀疑它只是试图用像素数组而不是图像数据对象做一个putImageData.
这是我写的一个可行的演示
这是相关的代码
var savedData = [];
undoButt.addEventListener("click", function () {
// as long as there is data put it onto the canvas.
if (savedData.length > 0) {
var imgData = savedData.pop();
drawCtx.putImageData(imgData, 0, 0);
}
});
drawCanvas.addEventListener("mousedown", function (e) {
// push the current state
var imgData = drawCtx.getImageData(0, 0, drawCanvas.width, drawCanvas.height);
savedData.push(imgData);
});
它与您使用的概念相同,似乎工作正常.
内容总结
以上是互联网集市为您收集整理的javascript – JS / HTML5 – 使用数组中的图像数据重绘画布全部内容,希望文章能够帮你解决javascript – JS / HTML5 – 使用数组中的图像数据重绘画布所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。