PDFKit 插件的阿拉伯语文本问题

时间:2021-07-20 11:51:55

标签: javascript node.js pdf arabic pdfkit

要生成动态 PDF 文件,我使用了 PDFKit。 这一代工作正常,但即使安装了阿拉伯字体,我也无法显示阿拉伯字符。 此外,阿拉伯语文本生成正确,但我认为词序不正确。

举个例子

我目前正在使用 pdfkit:“0.11.0”

文本:مرحبا كيف حالك(你好,你好吗)

字体:Amiri-Regular.ttf

const PDFDocument = require("pdfkit");
var doc = new PDFDocument({
  size: [595.28, 841.89],
  margins: {
    top: 0,
    bottom: 0,
    left: 0,
    right: 0,
  },
});
const customFont = fs.readFileSync(`${_tmp}/pdf/Amiri-Regular.ttf`);
doc.registerFont(`Amiri-Regular`, customFont);
doc.fontSize(15);
doc.font(`Amiri-Regular`).fillColor("black").text("مرحبا كيف حالك");
doc.pipe(fs.createWriteStream(`${_tmp}/pdf/arabic.pdf`));
doc.end();

输出:

PDF with arabic text

2 个答案:

答案 0 :(得分:1)

你是对的,阿拉伯语单词的顺序是错误的,你必须设置句子的方向

尝试使用这个

doc.rtl(true);

或此作为单行或文本的配置

doc.font(`Amiri-Regular`).fillColor("black").text("مرحبا كيف حالك", {rtl: true});

答案 1 :(得分:1)

根据信息 here 改编的答案:

  1. 安装软件包:npm install twitter_cldr

  2. 运行这个函数来生成文本:

const TwitterCldr = TwitterCldrLoader.load("en");
     
private maybeRtlize(text: string) {
  if (this.isHebrew(text)) {
    var bidiText = TwitterCldr.Bidi.from_string(text, { direction: "RTL" });
    bidiText.reorder_visually();
    return bidiText.toString();
  } else {
    return text;
  }
}
     
Value = maybeRtlize("مرحبا كيف حالك")

doc.font(`Amiri-Regular`).fillColor("black").text(Value);

另一种可能的方法是反转文本(使用诸如 text.split(' ').reverse().join(' '); 之类的东西,但是虽然这适用于简单的阿拉伯语文本,但它会在您引入英语数字时开始出现问题,例如。所以推荐第一种方法。