html5中不同图片资源跨域画布污染怎么解决?canvas画布解决方法分享!
2021-07-27 14:27:34
浏览数 (2935)
最近收到不少小伙伴们私信,这边小编就来说说:“html5中不同图片资源跨域画布污染怎么解决?canvas画布解决方法分享! ”这个问到比较多的问题吧!下面是小编整理的相关内容,希望对大家的学习有所帮助!
我们要绘制一张图片,内容包括一张背景图和一个动态生成的二维码,前提是背景图是项目本身的静态资源,二维码是服务端动态生成的,二者不在同一域名下。
解决办法:把所有图片都重定向同一个域名下:
let count = 0;
let bgImg = document.creatElement('img');
let qrImg = document.creatElement('img');
bgImg.src = redirectUrl('x.png');
qrImg.src = redirectUrl('y.png');
[bgImg, qrImg].forEach((e) => {
e.onload = () => {
count ++;
if (count === 2) {
drawerImg(bgImg, qrImg);
}
}
})
function redirectUrl (url) {
return 'https://xxx/view?fileUrl=' + encodeURIComponent(url);
}
function drawerImg (imgContent, qrContent, scaleBy = 2) {
let {bgImgW, bgImgH} = {375, 800};
let {qrx, qry, qrw, qrh} = {20, 700, 50, 50};
let Canvas = document.createElement('canvas');
let ctx = Canvas.getContext("2d");
Canvas.width = bgImgW * scaleBy;
Canvas.height= bgImgH * scaleBy;
ctx.drawImage(imgContent, 0, 0, bgImgW * scaleBy, bgImgH * scaleBy);
ctx.drawImage(qrContent, qrx * scaleBy, qry * scaleBy, qrw * scaleBy, qrh * scaleBy);
let nodeI = document.createElement("img");
nodeI.src = Canvas.toDataURL();
document.body.appendChild(nodeI)
}
讲解完 :“html5中不同图片资源跨域画布污染怎么解决?canvas画布解决方法分享! ”这个问题的相关内容相信很多小伙伴们应该都有所了解,更多有关于html5这个方面的相关内容我们都可以在W3Cschool中进行学习!