PDF轉(zhuǎn)換控件Aspose.PDF for .Net使用教程(九):在PDF文件中創(chuàng)建、更新和提取鏈接
Aspose.PDF for .NET是一種高PDF處理和解析API,用于在跨平臺(tái)應(yīng)用程序中執(zhí)行文檔管理和操作任務(wù)。API可以輕松用于生成、修改、轉(zhuǎn)換、渲染、保護(hù)和打印PDF文檔,而無(wú)需使用Adobe Acrobat。此外,API還提供PDF壓縮選項(xiàng),表格創(chuàng)建和操作,圖形和圖像功能,廣泛的超鏈接功能,印章和水印任務(wù),擴(kuò)展的安全控制和自定義字體處理。
【下載體驗(yàn)Aspose.PDF for .NET最新版】
在接下來(lái)的系列教程中,將為開發(fā)者帶來(lái)Aspose.PDF for .NET的一系列使用教程,例如進(jìn)行文檔間的轉(zhuǎn)換,如何標(biāo)記PDF文件,如何使用表單和圖表等等。
第三章:使用鏈接和操作
▲第一節(jié):創(chuàng)建、更新和提取鏈接
在PDF文件中創(chuàng)建應(yīng)用程序鏈接
通過(guò)將應(yīng)用程序的鏈接添加到文檔中,可以鏈接到文檔中的應(yīng)用程序。例如,讀者在教程中的特定點(diǎn)執(zhí)行某個(gè)操作或創(chuàng)建功能豐富的文檔時(shí),這功能非常有用。要?jiǎng)?chuàng)建應(yīng)用程序鏈接:
- 創(chuàng)建一個(gè)Document對(duì)象。
- 獲取Page要添加鏈接的鏈接。
- LinkAnnotation使用Page和Rectangle對(duì)象創(chuàng)建對(duì)象。
- 使用LinkAnnotation對(duì)象設(shè)置鏈接屬性。
- 設(shè)置LaunchAction對(duì)象的Action屬性。
- 創(chuàng)建LaunchAction對(duì)象時(shí),請(qǐng)指定要啟動(dòng)的應(yīng)用程序。
- 將鏈接添加到Page對(duì)象的Annotations屬性。
- 使用Document對(duì)象的Save方法保存更新的PDF。
以下代碼段顯示了如何在PDF文件中創(chuàng)建指向應(yīng)用程序的鏈接:
//文檔目錄的路徑。 string dataDir = RunExamples.GetDataDir_AsposePdf_LinksActions(); //打開文檔 Document document = new Document( dataDir + "CreateApplicationLink.pdf"); //創(chuàng)建鏈接 Page page = document.Pages[1]; LinkAnnotation link = new LinkAnnotation(page, new Aspose.Pdf.Rectangle(100, 100, 300, 300)); link.Color = Aspose.Pdf.Color.FromRgb(System.Drawing.Color.Green); link.Action = new LaunchAction(document, dataDir + "CreateApplicationLink.pdf"); page.Annotations.Add(link); dataDir = dataDir + "CreateApplicationLink_out.pdf"; //保存更新的文檔 document.Save(dataDir);
在PDF文件中創(chuàng)建PDF文檔鏈接
Aspose.PDF for .NET允許添加指向外部PDF文件的鏈接,以便可以將多個(gè)文檔鏈接在一起。要?jiǎng)?chuàng)建PDF文檔鏈接:
- 創(chuàng)建一個(gè)Document對(duì)象。
- 獲取Page要添加鏈接的特定內(nèi)容。
- LinkAnnotation使用Page和Rectangle對(duì)象創(chuàng)建對(duì)象。
- 使用LinkAnnotation對(duì)象設(shè)置鏈接屬性。
- 將Action屬性設(shè)置為GoToRemoteAction對(duì)象。
- 創(chuàng)建GoToRemoteAction對(duì)象時(shí),請(qǐng)指定應(yīng)啟動(dòng)的PDF文件以及應(yīng)打開的頁(yè)碼。
- 將鏈接添加到Page對(duì)象的Annotations集合中。
- 使用Document對(duì)象的Save方法保存更新的PDF。
以下代碼段顯示了如何在PDF文件中創(chuàng)建PDF文檔鏈接:
// 文檔目錄的路徑 string dataDir = RunExamples.GetDataDir_AsposePdf_LinksActions(); //打開文檔 Document document = new Document(dataDir+ "CreateDocumentLink.pdf"); //創(chuàng)建鏈接 Page page = document.Pages[1]; LinkAnnotation link = new LinkAnnotation(page, new Aspose.Pdf.Rectangle(100, 100, 300, 300)); link.Color = Aspose.Pdf.Color.FromRgb(System.Drawing.Color.Green); link.Action = new GoToRemoteAction(dataDir + "RemoveOpenAction.pdf", 1); page.Annotations.Add(link); dataDir = dataDir + "CreateDocumentLink_out.pdf"; //保存更新的文檔 document.Save(dataDir);
更新PDF文件中的鏈接
如在PDF文件中添加超鏈接中所述,LinkAnnotation該類可以在PDF文件中添加鏈接。還有一個(gè)類似的類用于從PDF文件內(nèi)部獲取現(xiàn)有鏈接。如果需要更新現(xiàn)有鏈接,請(qǐng)使用此選項(xiàng)。要更新現(xiàn)有鏈接:
- 加載PDF文件。
- 轉(zhuǎn)到PDF文件中的特定頁(yè)面。
- 使用GoToAction對(duì)象的Destination屬性指定鏈接目標(biāo)。
- 使用XYZExplicitDestination構(gòu)造函數(shù)指定目標(biāo)頁(yè)面。
將鏈接目標(biāo)設(shè)置為同一文檔中的頁(yè)面
以下代碼段顯示如何更新PDF文件中的鏈接并將其目標(biāo)設(shè)置為文檔的第二頁(yè):
// 文檔目錄的路徑. string dataDir = RunExamples.GetDataDir_AsposePdf_LinksActions(); //加載PDF文件 Document doc = new Document(dataDir + "UpdateLinks.pdf"); // 從文檔的第一頁(yè)獲取第一個(gè)鏈接注釋 LinkAnnotation linkAnnot = (LinkAnnotation)doc.Pages[1].Annotations[1]; // 修改鏈接:更改鏈接目標(biāo) GoToAction goToAction = (GoToAction)linkAnnot.Action; //指定鏈接對(duì)象的目標(biāo) // 第一個(gè)參數(shù)是文檔對(duì)象,第二個(gè)是目標(biāo)頁(yè)碼。 // 顯示相應(yīng)頁(yè)面時(shí),5ht參數(shù)是縮放系數(shù)。使用2時(shí),頁(yè)面將以200%縮放顯示 goToAction.Destination = new Aspose.Pdf.Annotations.XYZExplicitDestination(1, 1, 2, 2); dataDir = dataDir + "PDFLINK_Modified_UpdateLinks_out.pdf"; //使用更新的鏈接保存文檔 doc.Save(dataDir);
將鏈接目標(biāo)設(shè)置為Web地址
要更新超鏈接以使其指向Web地址,請(qǐng)實(shí)例化GoToURIAction對(duì)象并將其傳遞給LinkAnnotations Action屬性。以下代碼段顯示了如何更新PDF文件中的鏈接并將其目標(biāo)設(shè)置為Web地址。
//文檔目錄的路徑。 string dataDir = RunExamples.GetDataDir_AsposePdf_LinksActions(); //加載PDF文件 Document doc = new Document(dataDir + "UpdateLinks.pdf"); //從文檔的第一頁(yè)獲取第一個(gè)鏈接注釋 LinkAnnotation linkAnnot = (LinkAnnotation)doc.Pages[1].Annotations[1]; //修改鏈接:更改鏈接操作并將目標(biāo)設(shè)置為Web地址 linkAnnot.Action = new GoToURIAction("www.aspose.com"); dataDir = dataDir + "SetDestinationLink_out.pdf"; //使用更新的鏈接保存文檔 doc.Save(dataDir);
將鏈接目標(biāo)設(shè)置為另一個(gè)PDF文件
以下代碼段顯示如何更新PDF文件中的鏈接并將其目標(biāo)設(shè)置為另一個(gè)PDF文件。
//文檔目錄的路徑 string dataDir = RunExamples.GetDataDir_AsposePdf_LinksActions(); //加載PDF文件 Document document = new Document(dataDir + "UpdateLinks.pdf"); LinkAnnotation linkAnnot = (LinkAnnotation)document.Pages[1].Annotations[1]; GoToRemoteAction goToR = (GoToRemoteAction)linkAnnot.Action; //下一行更新目標(biāo),不要更新文件 goToR.Destination = new XYZExplicitDestination(2, 0, 0, 1.5); //下一行更新文件 goToR.File = new FileSpecification(dataDir + "input.pdf"); dataDir = dataDir + "SetTargetLink_out.pdf"; //使用更新的鏈接保存文檔 document.Save(dataDir);
更新LinkAnnotation文本顏色
鏈接注釋不包含文本,而是將文本放在注釋下的頁(yè)面內(nèi)容中。因此,要更改文本的顏色,請(qǐng)?zhí)鎿Q頁(yè)面文本的顏色,而不是嘗試更改注釋的顏色。以下代碼段顯示了如何更新PDF文件中鏈接批注的顏色。
// 文檔目錄的路徑. string dataDir = RunExamples.GetDataDir_AsposePdf_LinksActions(); //加載PDF文件 Document doc = new Document(dataDir + "UpdateLinks.pdf"); foreach (Annotation annotation in doc.Pages[1].Annotations) { if (annotation is LinkAnnotation) { //搜索注釋下的文本 TextFragmentAbsorber ta = new TextFragmentAbsorber(); Rectangle rect = annotation.Rect; rect.LLX -= 10; rect.LLY -= 10; rect.URX += 10; rect.URY += 10; ta.TextSearchOptions = new TextSearchOptions(rect); ta.Visit(doc.Pages[1]); //更改文本的顏色. foreach (TextFragment tf in ta.TextFragments) { tf.TextState.ForegroundColor = Color.Red; } } } dataDir = dataDir + "UpdateLinkTextColor_out.pdf"; //使用更新的鏈接保存文檔 doc.Save(dataDir);
從PDF文件中提取鏈接
鏈接在PDF文件中表示為注釋,因此要提取鏈接,請(qǐng)?zhí)崛∷蠰inkAnnotation對(duì)象:
- 創(chuàng)建一個(gè)Document對(duì)象。
- 獲取要從中提取鏈接的頁(yè)面。
- 使用AnnotationSelector類從指定頁(yè)面中提取所有LinkAnnotation對(duì)象。
- 將AnnotationSelector對(duì)象傳遞給Page對(duì)象的Accept方法。
- 使用AnnotationSelector對(duì)象的Selected屬性將所有選定的鏈接注釋添加到IList對(duì)象中。
以下代碼段顯示了如何從PDF文件中提取鏈接:
//文檔目錄的路徑. string dataDir = RunExamples.GetDataDir_AsposePdf_LinksActions(); //打開文檔 Document document = new Document(dataDir+ "ExtractLinks.pdf"); //提取動(dòng)作 Page page = document.Pages[1]; AnnotationSelector selector = new AnnotationSelector(new LinkAnnotation(page, Aspose.Pdf.Rectangle.Trivial)); page.Accept(selector); IListlist = selector.Selected; Annotation annotation = (Annotation)list[0]; dataDir = dataDir + "ExtractLinks_out.pdf"; //保存更新的文檔 document.Save(dataDir);
*想要購(gòu)買Aspose.PDF for .NET正版授權(quán)的朋友可以聯(lián)系在線客服了解詳情哦~
歡迎加入ASPOSE技術(shù)交流QQ群,各類資源及時(shí)分享,技術(shù)問(wèn)題交流討論!(掃描下方二維碼加入群聊)