zoukankan      html  css  js  c++  java
  • html2canvas截取div内容下载解决图片模糊和图片偏移

            $("#btnsave").click(function(){
                var copyDom = $("#modalcontent");
                var width = copyDom.offsetWidth;//dom宽
                var height = copyDom.offsetHeight;//dom高
                var scale = 2;//放大倍数
                var canvas = document.createElement('canvas');
                canvas.width = width*scale;//canvas宽度
                canvas.height = height*scale;//canvas高度
                var content = canvas.getContext("2d");
                content.scale(scale,scale);
                var rect = copyDom.get(0).getBoundingClientRect();//获取元素相对于视察的偏移量
                content.translate(-rect.left,-rect.top);//设置context位置,值为相对于视窗的偏移量负值,让图片复位
                html2canvas(copyDom[0], {
                    dpi: window.devicePixelRatio*2,
                    scale:scale,
                    canvas:canvas,
                    width,
                    heigth:height,
                }).then(function (canvas) {
                    var url = canvas.toDataURL();
                    var triggerDownload = $("<a>").attr("href", url).attr("download", "详情.png").appendTo("body");
                    triggerDownload[0].click();
                    triggerDownload.remove();
    
                });
    
            })
    

    用的是2018 年8月22号在官网上下载的html2canvas.js代码。上述代码可以解决图片模糊和偏移的问题。

    另外还有一种方法,设置配置即可,不存在图片偏移的问题,需要下载新版本,老版本的js不能用。

     dpi: window.devicePixelRatio,scale:2,这两个配置 DPI是指每英寸的像素,scale是按比例增加像素

            $("#btnsave").click(function(){
                var copyDom = $("#modalcontent");
                var width = copyDom.offsetWidth;//dom宽
                var height = copyDom.offsetHeight;//dom高
                var scale = 2;//放大倍数
                html2canvas(copyDom[0], {
                    dpi: window.devicePixelRatio*2,
                    scale:scale,
                    width,
                    heigth:height,
                }).then(function (canvas) {
                    var url = canvas.toDataURL();
                    var triggerDownload = $("<a>").attr("href", url).attr("download", "详情.png").appendTo("body");
                    triggerDownload[0].click();
                    triggerDownload.remove();
                });
            })
    
  • 相关阅读:
    UML--->用例图梳理
    UML--->活动图梳理
    论懂产品对程序员的重要性
    markdown时序图语法
    bootstrap 设置表格固定宽度 内容换行
    gitlab的本地搭建和部署使用
    layer.load的使用
    git fatal: remote origin already exists. 报错解决
    导出csv xls文件数字会自动变科学计数法的解决方式
    git常用命令
  • 原文地址:https://www.cnblogs.com/stt-bky/p/9518591.html
Copyright © 2011-2022 走看看