PDFBoxライブラリを使用してフォントファイルを解析する方法
温馨提示:
本文最后更新于 2024年04月12日,已超过 37 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我。
PDFドキュメントをロードして埋め込みフォントをすべて取得し、解析する必要がありますが、フォントを解析しようとするとfont.getFontDescriptor().getFontFile3()
例外が発生して問題が発生します。
Exception in thread "main" java.io.IOException: 'head' table is mandatory
at org.apache.fontbox.ttf.TTFParser.parseTables(TTFParser.java:198)
at org.apache.fontbox.ttf.TTFParser.parse(TTFParser.java:165)
at org.apache.fontbox.ttf.TTFParser.parse(TTFParser.java:110)
at org.example.Main.main(Main.java:175)
PDF リソースを解析するためのコードは次のとおりです。
try (PDDocument pdf = PDDocument.load(new File(path2))) {
final int numberOfPages = pdf.getNumberOfPages();
for (int pageId = 0; pageId < numberOfPages; pageId++) {
final PDPage page = pdf.getPage(pageId);
final PDResources pageResources = page.getResources();
final Iterable<COSName> fontNames = pageResources.getFontNames();
for (COSName fontResource : fontNames) {
final String fontName = fontResource.getName();
final PDFont font = pageResources.getFont(fontResource);
final PDStream fontFile2 = font.getFontDescriptor().getFontFile3();
final TTFParser ttfParser = new TTFParser(true);
final TrueTypeFont font1 = ttfParser.parse(fontFile2.createInputStream());
final byte[] encoded = font.encode("A");
System.out.println("FONT_NAME: " + fontName);
System.out.println("FONT: " + font.getName());
}
}
}
AFMParser
機能もありません。
AFMParser afmParser = new AFMParser(fontFile2.createInputStream());
final FontMetrics parse = afmParser.parse(true);
これAdobe Reader のフォントが解析されない。誰かこの問題について助けてくれませんか?からフォントを解析するにはどうすればよいですかfontFile3
?
正文到此结束
- 本文标签: 家庭宠物
- 本文链接: https://www.coder6.net/article/2573
- 版权声明: 本文由蚂蚁原创发布,转载请遵循《署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)》许可协议授权