解决canvas转base64/jpeg时透明区域变成黑色背景的方法

2020-04-21 07:51:34易采站长站整理

  
        // 在canvas绘制前填充白色背景   
        context.fillStyle = "#fff";   
        context.fillRect(0, 0, canvas.width, canvas.height);   
  
        context.drawImage(img, 0, 0);   
  
        // 展示base64位的图片   
        getBase64(canvas, function(dataUrl) {   
            var newImg = document.createElement("img");   
                newImg.src = dataUrl;   
  
            base64Img.appendChild(newImg);   
        });   
    }, false);   
  
    // 获取canvas的base64图片的dataURL(图片格式为image/jpeg)   
    function getBase64(canvas, callback) {   
        var dataURL = canvas.toDataURL("image/jpeg");   
  
        if(typeof callback !== undefined) {   
            callback(dataURL);   
        }   
    }   
</script>  

效果如下:

Perfect!

显然,在canvas绘制前填充白色背景这种方法,不仅简单,而且对png图片的半透明区域填充难看的黑色块。推荐这种解决方案。

另:canvas.toDataURL()方法不允许处理跨域图片。否则会报错。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。