📅  最后修改于: 2020-10-16 02:55:02             🧑  作者: Mango
在本章中,我们将看到如何使用iText库将链接注释添加到PDF文档。
您可以通过实例化Document类来创建一个空的PDF Document。在实例化此类时,您需要将PdfDocument对象作为参数传递给其构造函数。
要在PDF文档中使用文本注释,您需要创建一个PdfTextAnnotation类的对象并将其添加到PdfPage中。
以下是在PDF文档中使用文本注释的步骤。
PdfWriter类表示PDF的DocWriter。此类属于包com.itextpdf.kernel.pdf 。此类的构造函数接受一个字符串,该字符串表示要在其中创建PDF的文件的路径。
实例化PdfWriter类,方法是将一个字符串值(代表您需要在其中创建PDF的路径)传递给它的构造函数,如下所示。
// Creating a PdfWriter
String dest = "C:/itextExamples/linkAnnotation.pdf";
PdfWriter writer = new PdfWriter(dest);
当将此类型的对象传递到PdfDocument(类)时,添加到此文档的每个元素都将被写入指定的文件。
PdfDocument类是表示iText中PDF文档的类。此类属于包com.itextpdf.kernel.pdf 。要实例化此类(以编写模式),您需要将PdfWriter类的对象传递给其构造函数。
通过将PdfWriter对象传递给其构造函数来实例化PdfDocument类,如下所示。
// Creating a PdfDocument
PdfDocument pdfDoc = new PdfDocument(writer);
创建PdfDocument对象后,您可以使用其类提供的相应方法添加各种元素,如页面,字体,文件附件和事件处理程序。
包com.itextpdf.layout的Document类是创建自足PDF的根元素。此类的构造函数之一接受PdfDocument类的对象。
通过传递在先前步骤中创建的PdfDocument类的对象来实例化Document类,如下所示。
// Creating a Document
Document document = new Document(pdfDoc);
包com.itextpdf.kernel.pdf.annot的PdfAnnotation类表示所有注释的超类。
在其派生类中, PdfLinkAnnotation类表示链接注释。创建此类的对象,如下所示。
// Creating a PdfLinkAnnotation object
Rectangle rect = new Rectangle(0, 0);
PdfLinkAnnotation annotation = new PdfLinkAnnotation(rect);
使用PdfLinkAnnotation类的setAction()方法将操作设置为注释,如下所示。
// Setting action of the annotation
PdfAction action = PdfAction.createURI("http: // www.tutorialspoint.com/");
annotation.setAction(action);
通过实例化com.itextpdf.layout.element包的Link类来创建链接,如下所示。
// Creating a link
Link link = new Link("Click here", annotation);
通过实例化Paragraph类创建一个新段落,并使用该类的add()方法添加在上一步中创建的链接,如下所示。
// Creating a paragraph
Paragraph paragraph = new Paragraph("Hi welcome to Tutorialspoint ");
// Adding link to paragraph
paragraph.add(link.setUnderline());
如下所示,使用Document类的add()方法将段落添加到文档中。
// Adding paragraph to document
document.add(paragraph);
使用Document类的close()方法关闭文档,如下所示。
// Closing the document
document.close();
以下Java程序演示了如何使用iText库将链接注释添加到PDF文档。
它创建一个名为linkAnnotation.pdf的PDF文档,向其中添加链接注释,并将其保存在路径C:/ itextExamples /
将此代码保存在名为LinkAnnotation.java的文件中。
import com.itextpdf.kernel.geom.Rectangle;
import com.itextpdf.kernel.pdf.PdfDocument;
import com.itextpdf.kernel.pdf.PdfWriter;
import com.itextpdf.kernel.pdf.action.PdfAction;
import com.itextpdf.kernel.pdf.annot.PdfLinkAnnotation;
import com.itextpdf.layout.Document;
import com.itextpdf.layout.element.Link;
import com.itextpdf.layout.element.Paragraph;
public class LinkAnnotation {
public static void main(String args[]) throws Exception {
// Creating a PdfWriter
String dest = "C:/itextExamples/linkAnnotation.pdf";
PdfWriter writer = new
PdfWriter(dest);
// Creating a PdfDocument
PdfDocument pdf = new PdfDocument(writer);
// Creating a Document
Document document = new Document(pdf);
// Creating a PdfLinkAnnotation object
Rectangle rect = new Rectangle(0, 0);
PdfLinkAnnotation annotation = new PdfLinkAnnotation(rect);
// Setting action of the annotation
PdfAction action = PdfAction.createURI("http:// www.tutorialspoint.com/");
annotation.setAction(action);
// Creating a link
Link link = new Link("Click here", annotation);
// Creating a paragraph
Paragraph paragraph = new Paragraph("Hi welcome to Tutorialspoint ");
// Adding link to paragraph
paragraph.add(link.setUnderline());
// Adding paragraph to document
document.add(paragraph);
// Closing the document
document.close();
System.out.println("Annotation added successfully");
}
}
使用以下命令从命令提示符处编译并执行保存的Java文件-
javac LinkAnnotation.java
java LinkAnnotation
执行后,上述程序将创建一个显示以下消息的PDF文档。
Annotation added successfully
如果验证指定的路径,则可以找到创建的PDF文档,如下所示。