Aspose.PDF for .NET是一種高PDF處理和解析API,用於在跨平臺應用程序中執行文檔管理和操做任務。API能夠輕鬆用於生成、修改、轉換、渲染、保護和打印PDF文檔,而無需使用Adobe Acrobat。此外,API還提供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");
若是須要使用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)!文檔