我正在使用jsPDF通过Appcelerator的Titanium生成PDF文档。现在我需要添加一个包含两个段的简单饼图。我怎么能以最简单的方式做到这一点?
它不需要任何花哨的东西。我正在考虑首先生成图像,并将该图像添加到文档中。也许有一个库可以生成饼图的图像并将其保存到手机中。但是,我不确定jsPDF对图像的支持,我似乎无法找到任何关于图书馆的好文档。
答案 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)