• HTML2Canvas---合成海报遇到问题总结


    在使用HTML2Canvas合成图片项目中,通过不同手机测试,发现很多问题,总结一下,分享给大家。

    1. 在iPhone的safari浏览器上,合成海报分享到微信,会报“网络错误,无法分享”。

    解决方案:

    var userAgent = navigator.userAgent.toLowerCase();
    var bIsIphoneOs = userAgent.match(/iphone os/i) == "iphone os";
    
    
    
    if (bIsIphoneOs && userAgent.indexOf("safari") > -1 ) {
        this.imgUrl = URL.createObjectURL(this.base64ToBlob(canvas.toDataURL())) 
    }
    
    
    //base64转blob
                base64ToBlob(code) {
                    let parts = code.split(';base64,');
                    let contentType = parts[0].split(':')[1];
                    let raw = window.atob(parts[1]);
                    let rawLength = raw.length;
         
                    let uInt8Array = new Uint8Array(rawLength);
         
                    for (let i = 0; i < rawLength; ++i) {
                    uInt8Array[i] = raw.charCodeAt(i);
                    }
                    return new Blob([uInt8Array], {type: contentType});
                },

    2.  部分安卓手机,非微信,也有分享问题。

    var bIsAndroid = userAgent.match(/android/i)== "android";
     var	ua = navigator.userAgent.toLocaleUpperCase();
     var isWX = /micromessenger/i.test(ua);
    
    if(bIsAndroid && !isWX) {
         that.imgUrl =  URL.createObjectURL(that.base64ToBlob(canvas.toDataURL()))                     
    }else {
         that.imgUrl =  canvas.toDataURL()
    }
    
    
                       
    
  • 相关阅读:
    Git 常用命令汇总
    Vue 双向绑定原理
    移动端开发调试总结
    GPU硬件加速
    对象方法、类方法、原型方法 && 私有属性、公有属性、公有静态属性
    页面跳转
    引用对象深度赋值
    grunt、Browsersync服务及weinre远程调试
    Promise
    数据库Job定时任务
  • 原文地址:https://www.cnblogs.com/Super-scarlett/p/10856151.html
Copyright © 2020-2023  润新知