我有一个脚本使用
HTML2Canvas在页面中截取div的截图,然后使用jsPDF将其转换为pdf.
问题是生成的pdf只有一页,在某些情况下屏幕截图需要多个页面.例如,屏幕截图大于8.5×11.宽度很好,但我需要它来创建多个页面以适应整个屏幕截图.
这是我的脚本:
var pdf = new jsPDF('portrait','pt','letter');
$('.export').click(function() {
pdf.addHTML($('.profile-expand')[0],function () {
pdf.save('bfc-schedule.pdf');
});
});
有什么想法我可以修改它以允许多个页面?
解决方法
pdf.addHtml doesnot work if there are svg images on the web page..
I copy the solution here: // suppose your picture is already in a canvas var imgData = canvas.toDataURL(‘image/png’); /* Here are the numbers (paper width and height) that I found to work. It still creates a little overlap part between the pages,but good enough for me. if you can find an official number from jsPDF,use them. */
var imgWidth = 210;
var pageHeight = 295;
var imgHeight = canvas.height * imgWidth / canvas.width;
var heightLeft = imgHeight;
var doc = new jsPDF('p','mm');
var position = 0;
doc.addImage(imgData,'PNG',position,imgWidth,imgHeight);
heightLeft -= pageHeight;
while (heightLeft >= 0) {
position = heightLeft - imgHeight;
doc.addPage();
doc.addImage(imgData,imgHeight);
heightLeft -= pageHeight;
}
doc.save( 'file.pdf');`