jsPDF添加图表

时间:2013-01-06 19:16:56

标签: javascript jspdf

我正在使用jsPDF通过Appcelerator的Titanium生成PDF文档。现在我需要添加一个包含两个段的简单饼图。我怎么能以最简单的方式做到这一点?

它不需要任何花哨的东西。我正在考虑首先生成图像,并将该图像添加到文档中。也许有一个库可以生成饼图的图像并将其保存到手机中。但是,我不确定jsPDF对图像的支持,我似乎无法找到任何关于图书馆的好文档。

2 个答案:

答案 0 :(得分:7)

我知道它已经闲置了将近一年,但由于它没有接受答案,我会尽力回答。

将图表添加到jsPDF

1.使用HTML Canvas将图表转换为支持的图像格式(在base64中编码的JPEG或PNG)。

2.确保addImage功能可用的图像URL。

下面是将图像添加到jsPDF doc而不必包含原始base64代码的示例。它取自jsPDF示例。

function demoImages() {
    // Because of security restrictions, getImageFromUrl will
    // not load images from other domains.  Chrome has added
    // security restrictions that prevent it from loading images
    // when running local files.  Run with: chromium --allow-file-access-from-files --allow-file-access
    // to temporarily get around this issue.
    var getImageFromUrl = function(url, callback) {
        var img = new Image(), data, ret = {
            data: null,
            pending: true
        };

        img.onError = function() {
            throw new Error('Cannot load image: "'+url+'"');
        };
        img.onload = function() {
            var canvas = document.createElement('canvas');
            document.body.appendChild(canvas);
            canvas.width = img.width;
            canvas.height = img.height;

            var ctx = canvas.getContext('2d');
            ctx.drawImage(img, 0, 0);
            // Grab the image as a jpeg encoded in base64, but only the data
            data = canvas.toDataURL('image/jpeg').slice('data:image/jpeg;base64,'.length);
            // Convert the data to binary form
            data = atob(data);
            document.body.removeChild(canvas);

            ret['data'] = data;
            ret['pending'] = false;

            console.log("data",data);

            if (typeof callback === 'function') {
                callback(data);
            }
        };
        img.src = url;

        return ret;
    };

    // Since images are loaded asyncronously, we must wait to create
    // the pdf until we actually have the image data.
    // If we already had the jpeg image binary data loaded into
    // a string, we create the pdf without delay.
    var createPDF = function(imgData) {
        var doc = new jsPDF();

        doc.addImage(imgData, 'JPEG', 10, 10, 50, 50);
        doc.addImage(imgData, 'JPEG', 70, 10, 100, 120);

        doc.save('output.pdf');

    }

    getImageFromUrl('thinking-monkey.jpg', createPDF);
}

jsPDF的良好文档

您将从 practical documentation 中学习很多jsPDF功能。例如源代码,不要从GitHub下载,因为缺少某些文件。您可以从here下载。

注意:删除basic.js第312行的分号以使代码正常工作。

干杯,...

答案 1 :(得分:2)

也许您可以首先查看jsPDF网站,您可以使用库生成图像(可能是谷歌图表),将图表另存为图像,然后使用插件jspdf.plugin.addimage.js添加到PDF和一些代码。 这是从他们的网站上获取的example

var imgData = 'here the jpeg image string on base64';
var doc = new jsPDF();

doc.setFontSize(40);
doc.text(35, 25, "Octonyan loves jsPDF");
doc.addImage(imgData, 'JPEG', 15, 40, 180, 180);