前端 canvas toDataURL() 转图片生成空白图片问题

本文介绍了前端使用canvas toDataURL转换图片时遇到的生成空白图片问题及其原因,主要是由于canvas的缓冲区机制。解决方案是设置preserveDrawingBuffer为true,以确保在获取数据URL时读取完整内容。在Vue项目中应用此方法时,若涉及多个图层,可能需要结合html2canvas来完成截图。
摘要由CSDN通过智能技术生成

前端 canvas toDataUrl() 转图片生成空白图片问题

前言:如果你在开发过程中,也发生该类似情况,不妨尝试一下以下方法!

感谢大神

感谢 stackoverflow 格曼大神的答案
原文链接:Canvas toDataURL() returns blank image

解决方法

// 页面初始化时候,自执行该函数
<script>
HTMLCanvasElement.prototype.getContext = function(origFn) {
   
  return function(type, attributes) {
   
    if (type === 'webgl') {
   
      attributes = Object.assign({
   }, attributes, {
   
        preserveDrawingBuffer: true,
      });
    }
    return origFn.call(this, type, attributes);
  };
}(HTMLCanvasElement.prototype.getContext);
</script>

问题发生

用过百度、高德、谷歌等任意地图的你,必然有遇上这么一个情况:当你快速放大/缩小地图时,必然会优先预加载一块一块白布,然后主要地图内容才跟着展示出来(网速慢的时候更明显!࿰

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值