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)文檔

相關文章
相關標籤/搜索