zoukankan      html  css  js  c++  java
  • canvas导出图片方法总结

    html代码
    <canvas id="canvas" width="100" height="100" ></canvas>
    js 代码
    var canvas=document.getElementById("canvas");
    var ctx=canvas.getContext("2d");
    ctx.fileStyle="gray";
    ctx.fillReact(0,0,100,100);

    1.直接调用canvas对象的toDataURL方法转化为指定类型

    var newImg = new Image();
    newImg.src=canvas.toDataURL("image/png"));

    2.利用canvas对象的toBlob方法

    先通过toBlob将canvas对象转化为二进制对象,通过参数形式传入函数,然后利用URL.createObjectURL方法根据传入的参数创建一个指向该参数blob对象的url,然后把url赋给img的src属性即可
    canvas.toBlob && canvas.toBlob(function(blob) {
      var url = URL.createObjectURL(blob);
      var newImg = new Image();
      newImg.onload = function() {
        URL.revokeObjectURL(url)
      };
      newImg.src=url;
    };
     URL.revokeObjectURL()方法会销毁一个通过URL.createObjectURL()创建的对象URL. 当你要把url赋给newImg之后,并且浏览器已经onload成功这个img,那么此时就再不需要指向blob对象的url,这个时候就应该把这个对象销毁掉,避免占用内存。
  • 相关阅读:
    Matplotlib绘图双纵坐标轴设置及控制设置时间格式
    https://www.cnblogs.com/xubing-613/p/5895948.html
    Python科学计算技巧积累四——双y轴图像绘制
    卡尔曼滤波(Kalman Filter)
    python os.path模块常用方法详解 ZZ
    C/C++跨平台的的预编译宏
    WEB版一次选择多个图片进行批量上传(WebUploader)的解决方案
    WEB版一次选择多个文件进行批量上传(WebUploader)的解决方案
    学习ASP.NET MVC(十一)——分页
    学习ASP.NET MVC(十)——排序
  • 原文地址:https://www.cnblogs.com/dupd/p/5893754.html
Copyright © 2011-2022 走看看