2

我用 ASP.NET + iTextSharp 生成了一个 pdf 报告。
我在其中使用了几种类型的字体,出于艺术原因,每种字体都应用于一个或 2 个单词。
所以文件很大。

我怎样才能只嵌入我实际使用的字体?就像我们使用 MS Office Options 所做的一样。

MS Office Word 2007 是这样的:
“在文件中嵌入字体:
仅嵌入文档中使用的字符(最适合减小文件大小)
不要嵌入常用系统字体”

或者我也可以接受另一种解决方案。
将整个页面展平为高分辨率图片。
如果编程方便的话,我其实更喜欢这个方案。

谢谢。

4

1 回答 1

2

创建BaseFont启用嵌入的实例时,您需要调用myBaseFont.setSubset(true). 请注意,使用编码“Identity-H”(AKA BaseFont.IDENTITY_H),这会自动发生:

// find all fonts in the usual places across multiple OSs.
// This can be pretty slow if you have a large number fonts, or the fonts
// themselves are Really Big (ArialUnicodeMS: 23mb).
FontFactory.registerDirectories();

// here's one way to do it, using identity-h forces subsetting
Font myFontSubset1 = FontFactory.getFont(fontName1, BaseFont.IDENTITY_H);

// here's another, explicitly enable subsetting for the underlying BaseFont.
Font myFontSubset2 = FontFactory.getFont(fontName2, FontFactory.defaultEncoding, true);
myFontSubset2.getBaseFont().setSubset(true);

//or you can create the BaseFont yourself, with automagic subsetting
BaseFont myFontSubset3 = BaseFont.createFont(fontPath, BaseFont.IDENTITY_H);

// or create it with some other encoding, and enable subsetting.
BaseFont myFontSubset4 = BaseFont.createFont(fontPath, BaseFont.WINANSI, true);
myFontSubset4.setSubset(true);

请注意,这都是 Java。在 C# 中,函数名称的第一个字母大写setX(newX)getX()成为属性。

于 2011-04-14T22:54:05.610 回答