JsPDFライブラリを使用してクライアント側でPDFを生成しようとしています。私のコードは次のようになります
<script type="text/javascript" src="libs/base64.js"></script>
<script type="text/javascript" src="libs/sprintf.js"></script>
<script type="text/javascript" src="jspdf.js"></script>
<script>
var doc = new jsPDF();
var imgData = '';
doc.setFontSize(40);
doc.text(30, 20, 'Hello world!');
doc.output('datauri');
doc.addImage(imgData, 'JPEG', 15, 40, 200, 114);
</script>
しかし、それはテキストのみを印刷し、画像を印刷しないようです。
ここでの問題は何ですか?
png画像を追加する場合は、最新のjspdf.jsを取得し、サポートpngライブラリを追加する必要があります。
<script type="text/javascript" src="libs/png_support/zlib.js"></script>
<script type="text/javascript" src="libs/png_support/png.js"></script>
<script type="text/javascript" src="jspdf.plugin.addimage.js"></script>
<script type="text/javascript" src="jspdf.plugin.png_support.js"></script>
<script type="text/javascript" src="jspdf.js"></script>
次に、スクリプトで、形式を「PNG」に変更します
<script>
var doc = new jsPDF();
var imgData = '...
doc.setFontSize(40);
doc.text(30, 20, 'Hello world!');
doc.addImage(imgData, 'PNG', 15, 40, 200, 114);
doc.output('datauri');
</script>
次のファイルをHTMLに含めます。
<script src="Scripts/jspdf/png_support/zlib.js"></script>
<script src="Scripts/jspdf/png_support/png.js"></script>
<script src="Scripts/jspdf/FileSaver.js"></script>
<script src="Scripts/jspdf/jspdf.js"></script>
<script src="Scripts/jspdf/jspdf.plugin.addimage.js"></script>
<script src="Scripts/jspdf/jspdf.plugin.png_support.js"></script>
これらのファイルはすべて https://github.com/MrRio/jsPDF から取得できます。
Libs/FileSaver.jsのFileSaver.jszlib.jsおよびlibs/png_support.jsのpng.js
PDFファイルを保存する必要がない場合は、FileSaver.jsを除外できます。
一部の関数の欠落を警告する場合は、dist/jspdf.debug.jsを開き、名前を検索してそれを含む特定のモジュールを見つけ、上記のリスト(jspdf.jsファイルの後)に含めます。
ドキュメントを作成した後、doc.output
を呼び出します。
doc.addImage(imgData, 'JPEG', 15, 40, 200, 114);
doc.output('datauri');