为什么drawImage和putImageData结果不一样?

新手上路,请多包涵


var cArr = document.querySelectorAll("canvas");
var ctx1 = cArr[0].getContext("2d");
var ctx2 = cArr[1].getContext("2d");
var ctx3 = cArr[2].getContext("2d");
ctx1.textAlign = "center";
ctx1.textBaseline = "middle";
ctx1.font = "bold 24px serif";
ctx1.strokeStyle = "blue";
cArr[0].onclick = function(event){
ctx1.strokeText("canvas",event.offsetX,event.offsetY);
var img = new Image();
img.onload = function(event){
ctx2.drawImage(img,0,0);
}
img.src = cArr[0].toDataURL();
var data = ctx1.getImageData(0,0,cArr[0].width,cArr[0].height);
ctx3.putImageData(data,0,0);
}

canvas1分别drawImage、putImageData到canvas2,canvas3。

阅读 2.6k
1 个回答

结果其实是一样的,不过drawImage()是在Canvas上绘制图像,而不是覆盖,也就是不会清空之前的内容;按照你现在的代码,在每次drawImage之前清空下就行

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题