在使用 pdf-lib.js 库时,如果你遇到中文编码问题,比如 Error: WinAnsi cannot encode "方" (0x65b9),这是因为 WinAnsi 编码不支持中文字符。为了在 PDF 中正确显示中文字符,你需要使用支持中文的字体,比如 SimSun(宋体)或者其他支持中文的字体。
以下是一个示例代码,展示如何在 pdf-lib.js 中使用中文字体:
首先,确保你有一个支持中文的字体文件(例如 SimSun.ttf)。使用 pdf-lib.js 加载字体文件并将其嵌入到 PDF 中。使用嵌入的字体绘制中文字符。const { PDFDocument, StandardFonts, rgb } = require('pdf-lib'); const fontkit = require('@pdf-lib/fontkit'); const fs = require('fs'); async function createPdfWithChineseText() { // 加载字体文件 const fontBytes = fs.readFileSync('path/to/SimSun.ttf'); // 创建一个新的PDF文档 const pdfDoc = await PDFDocument.create(); // 注册字体 pdfDoc.registerFontkit(fontkit); const customFont = await pdfDoc.embedFont(fontBytes); // 创建一页 const page = pdfDoc.addPage(); // 使用嵌入的字体绘制中文字符 page.drawText('你好,世界!', { x: 50, y: page.getHeight() - 100, size: 30, font: customFont, color: rgb(0, 0, 0), }); // 保存PDF文档 const pdfBytes = await pdfDoc.save(); // 将PDF文档写入文件 fs.writeFileSync('output.pdf', pdfBytes); } createPdfWithChineseText().catch(console.error);
在这个示例中,我们做了以下几步:
使用 fs.readFileSync 读取字体文件 SimSun.ttf。创建一个新的 PDF 文档。注册 fontkit 以便能够嵌入字体。使用 pdfDoc.embedFont 嵌入字体文件。创建一页并在页面上使用嵌入的字体绘制中文字符。保存 PDF 文档并将其写入文件。确保你有一个支持中文的字体文件,并将其路径替换为实际路径。这样,你就可以在 PDF 中正确显示中文字符了。
网友回复