Tainted canvases may not be exported.(被污染的画布无法输出)

最近在做一个“在图片上进行绘图”的功能,将图片画到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
});
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值