4

我正在使用 iText 5.3.3 库,我不想使用 PdfAWriter 类创建 PDF,该类需要指定必须遵守的合规性级别。

我不想在我的文档中添加 PdfPTable,但由于此错误,我无法做到这一点:“必须嵌入所有字体。这不是:Helvetica”。

我认为这个问题是因为当我们想用 PDFAConformanceLevel 制作 PDF 时,我们必须嵌入我们使用的字体;这就是我所做的,但在某些情况下,似乎使用了默认字体:Helvetica,并且此默认字体未嵌入且无法嵌入!当我们添加新行、空行、新页面或使用 PdfPTable 等元素时,就会发生这种情况。

我认为当我们使用 PdfPTable 之类的元素时,它必须是一种定义要使用的默认字体的方法;我听说有人设法通过定义一个新的 Chunk 构造函数来做到这一点,但我不知道该怎么做......有人有想法吗?

在这里你可以找到我的代码......我已经简化了它的目的:

我用这段代码定义了 2 种嵌入字体:

FontFactory.register("c:/NewYorker.ttf");
baseFont = (FontFactory.getFont("new yorker","UTF-8",BaseFont.EMBEDDED)).getBaseFont();
baseFont.setSubset(true);
BOLD = new Font(timesbd, 12);
NORMAL = new Font(times, 12);

我使用这些字体在 3 个单元格中添加 3 个段落以放入一个表格中:

Document document = new Document();
PdfAWriter writer = PdfAWriter.getInstance(document, new FileOutputStream(filename), PdfAConformanceLevel.PDF_A_1B);
document.open();

float[] columnWidths = { 3.5f, 4.5f, 2.8f };
PdfPTable table = new PdfPTable(columnWidths);

PdfPCell defaultCell = table.getDefaultCell();
defaultCell.setPhrase(new Phrase("",NORMAL)); 

table.setWidthPercentage(90);
table.setHorizontalAlignment(Element.ALIGN_RIGHT);

PdfPCell cell1 = new PdfPCell(new Phrase("test 1",BOLD));
PdfPCell cell2 = new PdfPCell(new Phrase("test 2",NORMAL));
PdfPCell cell3 = new PdfPCell(new Phrase("test 3",NORMAL));

cell1.setBorder(0);
cell2.setBorder(0);
cell3.setBorder(0);

cell1.setIndent(27);
cell2.setIndent(27);
cell3.setIndent(27);

cell1.setLeading(4.5f, 1);
cell2.setLeading(4.5f, 1);
cell3.setLeading(4.5f, 1);

table.addCell(cell1);
table.addCell(cell2);
table.addCell(cell3);

document.add(table);

document.close();

当我执行我的代码时,我有这个堆栈:

Exception in thread "main" com.itextpdf.text.DocumentException: com.itextpdf.text.pdf.PdfAConformanceException: All the fonts must be embedded. This one isn't: Helvetica
at com.itextpdf.text.pdf.PdfDocument.add(PdfDocument.java:708)
at com.itextpdf.text.Document.add(Document.java:260)
at test.MainClass.createPdfA(MainClass.java:163)
at test.MainClass.main(MainClass.java:68)
4

1 回答 1

4

您的代码中有不同的错误,字体不是最大的问题。

我尽可能好地复制/粘贴您的代码:http: //itextsupport.com/files/stackoverflow/PdfATest.java

  • 我不得不更改字体,因为我的 PC 上没有 NewYorker.ttf。
  • 我没有嵌入完整的字体;这似乎有点矫枉过正。
  • 我添加了一行来创建 XMP 数据(这在 PDF/A 中是强制性的)。
  • 我添加了一个颜色配置文件(也是强制性的;我选择了sRGB)。

我运行了代码,它没有抛出任何异常。您可以自己检查结果:http: //itextsupport.com/files/stackoverflow/pdfa.pdf

当然:如果您看到一个蓝条说这是 PDF/A1b ,请不要相信 Adob​​e Reader 。您需要在 Preflight 工具中检查一致性,如下图所示: 在此处输入图像描述

我猜:

  • 也许您假设“new yorker”是字体的实际 PostScript 名称是错误的。
  • 你为什么使用“UTF-8”作为编码。文档清楚地表明如果要使用 Unicode,则需要使用 Identity-H。

我无法重现您的问题,因此建议您尝试运行我的代码。

于 2012-11-23T12:36:03.310 回答