javascript - html2canvas 捕获低质量图片

标签 javascript jquery fabricjs jspdf html2canvas

我正在尝试用 Canvas 捕获一个 div。它是一个 T 恤编辑器。现在我用 html2canvas 捕获这个 div,然后使用 jspdf 将它打印在 pdf 中。现在的问题是捕获的图像质量非常低且模糊。它的dpi非常低。

这是原始的div图片:

original div picture

这是该 div 的打印版本:

printed version of that div

你可以看到它们之间的质量差异是巨大的。

无论如何这里是捕获div然后将其转换为pdf的代码

var myimage;
function print() {
    window.scrollTo(0, 0);
    html2canvas(document.getElementById('shirtDiv')).then(function(canvas) {
        myimage = canvas.toDataURL("image/jpeg");
        setTimeout(print2, 1);
        var doc = new jsPDF();
        doc.addImage(myimage, 'JPEG', 35, 20, 130, 155);
        doc.save('Test.pdf');
    });
}



                <div id="shirtDiv" class="page" style="width: 530px; height: 630px; position: relative; background-color: rgb(255, 255, 255); " >
                    <img name="tshirtview" id="tshirtFacing" src="img/crew_front.png">
                    <div id="drawingArea" style="position: absolute;top: 100px;left: 160px;z-index: 10;width: 200px;height: 400px;">
        </div></div>

请忽略在线 CSS

最佳答案

好的,我这样做是因为其他人在此 link 中提出了类似的问题但答案没有标记为正确,因为他可能没有正确解释。无论如何,这是解决方案。

 var myimage;

    function print() {
        window.scrollTo(0, 0);
        html2canvas(document.getElementById('shirtDiv')[0],{scale:4}).then(function(canvas) {

        myimage = canvas.toDataURL("image/jpeg");

            var doc = new jsPDF();
            doc.addImage(myimage, 'JPEG', 35, 20, 130, 155);
            doc.save('Test.pdf');
        });
    }

到处都提到了 scale 属性,但我在应用它时遇到了麻烦。是的,我知道我很愚蠢,但也许其他人和我一样,这可能会帮助他们:)

更新版本

这个 HTML2CANVAS 解决方案对我来说仍然不起作用,因为缩放选项在捕获它之前确实增加了目标 div 的大小,但是如果你在那个 div 里面有一些不会调整大小的东西,它就不起作用 例如 就我而言,它是我的编辑工具的 Canvas 。无论如何为此我选择了 domtoimage 相信我,我认为这是最好的解决方案。我不必面对 html2canvas 的任何问题,例如:需要在网页顶部,以便 html2canvas 可以完全捕获镜头和低 dpi 问题

无论如何对这个故事感到抱歉,但我认为每个人都应该知道,这是代码
function print() {
var node = document.getElementById('shirtDiv');
var options = {
    quality: 0.95
};

domtoimage.toJpeg(node, options).then(function (dataUrl) {


    var doc = new jsPDF();
    doc.addImage(dataUrl, 'JPEG', -18, 20, 240, 134.12);
    doc.save('Test.pdf');
});
}

用于 dom 镜像的 Cdn:https://cdnjs.com/libraries/dom-to-image

jspdf的cdn:https://cdnjs.com/libraries/jspdf

关于javascript - html2canvas 捕获低质量图片,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61899078/

相关文章:

javascript - JQuery 全屏仅适用于按钮

javascript - 完整的 Javascript Ajax php 混淆

javascript - 使用 Chrome native 消息传递触发时批处理文件不提示用户输入

javascript - 支持 JavaScript 中的 POST 数据

javascript - 如何将 jQuery 事件处理程序应用于多个缓存选择器?

ruby-on-rails - 在模型或 Controller 中获取消化的 asset_path

javascript - 在 facebook 中分享 SVG xml

javascript - 在 fabricjs 上下文中更改文本不起作用

javascript - 下拉选择选项显示价格?

javascript - jQuery 验证 addClassRules 返回 NaN 而不是最大值