PDF管理控件Aspose.PDF for .Net使用教程:在PDF文件中嵌入字体

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字体
spa

一些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中的字体描述符构造替代字体。orm

使用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)文档

相关文章
相关标签/搜索