iText - Anotación de enlace

En este capítulo, veremos cómo agregar una anotación de enlace a un documento PDF usando la biblioteca iText.

Creación de una anotación de enlace en un PDF

Puede crear un documento PDF vacío creando una instancia del Documentclase. Al crear una instancia de esta clase, debe pasar unPdfDocument objeto como parámetro de su constructor.

Para usar la anotación de texto en su documento PDF, debe crear un objeto de la clase PdfTextAnnotation y agregarlo a PdfPage.

A continuación se muestran los pasos para utilizar la anotación de texto en un documento PDF.

Paso 1: crear un objeto PdfWriter

los PdfWriterclass representa el DocWriter de un PDF. Esta clase pertenece al paquetecom.itextpdf.kernel.pdf. El constructor de esta clase acepta una cadena, que representa la ruta del archivo donde se creará el PDF.

Instancia del PdfWriter class pasando un valor de cadena (que representa la ruta donde necesita crear un PDF) a su constructor, como se muestra a continuación.

// Creating a PdfWriter 
String dest = "C:/itextExamples/linkAnnotation.pdf"; 
PdfWriter writer = new PdfWriter(dest);

Cuando un objeto de este tipo se pasa a un PdfDocument (clase), todos los elementos agregados a este documento se escribirán en el archivo especificado.

Paso 2: crear un objeto PdfDocument

los PdfDocumentclass es la clase que representa el documento PDF en iText. Esta clase pertenece al paquetecom.itextpdf.kernel.pdf. Para crear una instancia de esta clase (en modo de escritura), debe pasar un objeto de la clasePdfWriter a su constructor.

Cree una instancia de la clase PdfDocument pasando el PdfWriter objeto a su constructor, como se muestra a continuación.

// Creating a PdfDocument  
PdfDocument pdfDoc = new PdfDocument(writer);

Una vez que se crea un objeto PdfDocument, puede agregar varios elementos como página, fuente, archivo adjunto y controlador de eventos usando los métodos respectivos proporcionados por su clase.

Paso 3: crear el objeto de documento

los Document clase del paquete com.itextpdf.layoutes el elemento raíz al crear un PDF autosuficiente. Uno de los constructores de esta clase acepta un objeto de la clase.PdfDocument.

Instancia del Document class pasando el objeto de la clase PdfDocument creada en los pasos anteriores, como se muestra a continuación.

// Creating a Document  
Document document = new Document(pdfDoc);

Paso 4: Creación del objeto PdfAnnotation

los PdfAnnotation clase del paquete com.itextpdf.kernel.pdf.annot representa la superclase de todas las anotaciones.

Entre sus clases derivadas, PdfLinkAnnotationclass representa la anotación de enlace. Cree un objeto de esta clase, como se muestra a continuación.

// Creating a PdfLinkAnnotation object 
Rectangle rect = new Rectangle(0, 0); 
PdfLinkAnnotation annotation = new PdfLinkAnnotation(rect);

Paso 5: Configurar la acción de la anotación

Establezca la acción para la anotación usando el setAction() método del PdfLinkAnnotation clase, como se muestra a continuación.

// Setting action of the annotation 
PdfAction action = PdfAction.createURI("http: // www.tutorialspoint.com/"); 
annotation.setAction(action);

Paso 6: crear un enlace

Cree un enlace instanciando el Link clase del paquete com.itextpdf.layout.element, Como se muestra abajo.

// Creating a link 
Link link = new Link("Click here", annotation);

Paso 7: agregar la anotación del enlace a un párrafo

Cree un nuevo párrafo instanciando el Paragraph class y agregue el enlace creado en el paso anterior usando el add() método de esta clase, como se muestra a continuación.

// Creating a paragraph 
Paragraph paragraph = new Paragraph("Hi welcome to Tutorialspoint ");        

// Adding link to paragraph 
paragraph.add(link.setUnderline());

Paso 8: Agregar párrafo al documento

Agregue el párrafo al documento usando el add() método del Document clase, como se muestra a continuación.

// Adding paragraph to document 
document.add(paragraph);

Paso 9: Cerrar el documento

Cierre el documento con el close() método del Document clase, como se muestra a continuación.

// Closing the document 
document.close();

Ejemplo

El siguiente programa Java demuestra cómo agregar una anotación de enlace a un documento PDF utilizando la biblioteca iText.

Crea un documento PDF con el nombre linkAnnotation.pdf, le agrega una anotación de enlace y la guarda en la ruta C:/itextExamples/

Guarde este código en un archivo con el nombre 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");    
   } 
}

Compile y ejecute el archivo Java guardado desde el símbolo del sistema utilizando los siguientes comandos:

javac LinkAnnotation.java 
java LinkAnnotation

Tras la ejecución, el programa anterior crea un documento PDF que muestra el siguiente mensaje.

Annotation added successfully

Si verifica la ruta especificada, puede encontrar el documento PDF creado, como se muestra a continuación.