Aspose.PDF for .NET是一种高PDF处理和解析API,用于在跨平台应用程序中执行文档管理和操作任务。API可以轻松用于生成、修改、转换、渲染、保护和打印PDF文档,而无需使用Adobe Acrobat。此外,API还提供PDF压缩选项,表格创建和操作,图形和图像功能,广泛的超链接功能,印章和水印任务,扩展的安全控制和自定义字体处理。
在现有的PDF文件中嵌入字体
PDF阅读器支持14种字体的核心,因此无论以何种平台显示文档,都可以以相同方式显示文档。当PDF包含不是14种核心字体之一的字体时,请将其嵌入PDF文件中以避免字体替换。
Aspose.PDF for .NET支持在现有PDF文件中嵌入字体,可以嵌入完整的字体或字体的子集。要嵌入字体,请使用Document该类打开PDF文件。然后使用Aspose.Pdf.Text.Font该类将字体嵌入到PDF文件中。要嵌入完整字体,请使用Fontclass的IsEmbeded属性。要使用字体的子集,请使用IsSubset属性。以下代码段显示了如何在PDF文件中嵌入字体。
- // 文档目录的路径。
- string dataDir = RunExamples.GetDataDir_AsposePdf_WorkingDocuments();
-
- //加载现有的PDF文件
- Document doc = new Document(dataDir + "input.pdf");
-
- //遍历所有页面
- foreach (Page page in doc.Pages)
- {
- if (page.Resources.Fonts != null)
- {
- foreach (Aspose.Pdf.Text.Font pageFont in page.Resources.Fonts)
- {
- //检查字体是否已经嵌入
- if (!pageFont.IsEmbedded)
- pageFont.IsEmbedded = true;
- }
- }
-
- // 检查Form对象
- foreach (XForm form in page.Resources.Forms)
- {
- if (form.Resources.Fonts != null)
- {
- foreach (Aspose.Pdf.Text.Font formFont in form.Resources.Fonts)
- {
- //检查字体是否嵌入
- if (!formFont.IsEmbedded)
- formFont.IsEmbedded = true;
- }
- }
- }
- }
- dataDir = dataDir + "EmbedFont_out.pdf";
- //保存PDF文档
- doc.Save(dataDir);
嵌入标准类型1字体
一些PDF文档的字体来自特殊的Adobe字体集。该集合中的字体称为“标准类型1字体”。这套字体包括14种字体,嵌入此类字体需要使用特殊标志,即
Aspose.Pdf.Document.EmbedStandardFonts。以下是可用于获取嵌入了所有字体(包括标准类型1字体)的文档的代码段:
- //文档目录的路径。
- string dataDir = RunExamples.GetDataDir_AsposePdf_Text();
- //加载现有的PDF文档
- Document pdfDocument = new Document(dataDir + "input.pdf");
- // 设置文档的EmbedStandardFonts属性
- pdfDocument.EmbedStandardFonts = true;
- foreach (Aspose.Pdf.Page page in pdfDocument.Pages)
- {
- if (page.Resources.Fonts != null)
- {
- foreach (Aspose.Pdf.Text.Font pageFont in page.Resources.Fonts)
- {
- //检查字体是否已经嵌入
- if (!pageFont.IsEmbedded)
- {
- pageFont.IsEmbedded = true;
- }
- }
- }
- }
- pdfDocument.Save(dataDir + "EmbeddedFonts-updated_out.pdf");
创建PDF文件时嵌入字体
如果需要使用Adobe Reader支持的14种核心字体以外的其他字体,则必须在生成Pdf文件时嵌入字体说明。如果未嵌入字体信息,则Adobe Reader将在操作系统上安装它,如果安装在系统上,则会从操作系统中获取它,否则它将根据Pdf中的字体描述符构造替代字体。
使用Font类的IsEmbedded属性将字体信息嵌入到Pdf文件中。将此属性的值设置为'True'会将完整的字体文件嵌入到Pdf中,因为它会增加Pdf文件的大小。以下是可用于将字体信息嵌入到Pdf中的代码段。
- //文档目录的路径。
- string dataDir = RunExamples.GetDataDir_AsposePdf_WorkingDocuments();
-
- //通过调用其空构造函数实例化Pdf对象
- Aspose.Pdf.Document doc = new Aspose.Pdf.Document();
-
- // 在Pdf对象中创建一个部分
- Aspose.Pdf.Page page = doc.Pages.Add();
-
- Aspose.Pdf.Text.TextFragment fragment = new Aspose.Pdf.Text.TextFragment("");
-
- Aspose.Pdf.Text.TextSegment segment = new Aspose.Pdf.Text.TextSegment(" This is a sample text using Custom font.");
- Aspose.Pdf.Text.TextState ts = new Aspose.Pdf.Text.TextState();
- ts.Font = FontRepository.FindFont("Arial");
- ts.Font.IsEmbedded = true;
- segment.TextState = ts;
- fragment.Segments.Add(segment);
- page.Paragraphs.Add(fragment);
-
- dataDir = dataDir + "EmbedFontWhileDocCreation_out.pdf";
- //保存PDF文档
- doc.Save(dataDir);
如果您有任何疑问或需求,请随时加入Aspose技术交流群(642018183)!