最近在做一个“在图片上进行绘图”的功能,将图片画到canvas上之后,进行绘制操作时chrome浏览器一直报错,说:
原因:
canvas绘制图片,由于浏览器的安全考虑,如果在使用canvas绘图的过程中,使用到了外域的图片资源,使用toDataURL()
时会抛出安全异常。
解决方案:
因为在项目中图片只能用跨域的图片,不能将其保存在本地,所以参考这篇文章:启用了 CORS 的图片
最重要的一点就是要给画上canvas的图片给一个属性:
var img = new Image();
img.crossOrigin = "Anonymous";
img.src = $("#canvasImg")[0].src;
$canvas.drawImage({
source: img,
x: 0, y: 0,
width: painter.canvasW,
height: painter.canvasH,
fromCenter: false
});