iText - Anotasi Garis

Pada bab ini, kita akan melihat bagaimana menambahkan anotasi garis ke dokumen PDF menggunakan pustaka iText.

Membuat Anotasi Garis dalam Pdf

Anda dapat membuat Dokumen PDF kosong dengan membuat instance Documentkelas. Saat membuat instance kelas ini, Anda harus meneruskan aPdfDocument objek sebagai parameter, untuk konstruktornya.

Untuk menggunakan anotasi teks dalam dokumen PDF Anda, Anda perlu membuat objek PdfTextAnnotation kelas dan tambahkan ini ke PdfPage.

Berikut adalah langkah-langkah untuk menggunakan anotasi teks dalam dokumen PDF.

Langkah 1: Membuat objek PdfWriter

Itu PdfWriterkelas mewakili DocWriter untuk PDF. Kelas ini termasuk dalam paketcom.itextpdf.kernel.pdf. Konstruktor kelas ini menerima string, mewakili jalur file tempat PDF akan dibuat.

Membuat instance kelas PdfWriter dengan meneruskan nilai string yang mewakili jalur tempat Anda perlu membuat PDF, ke konstruktornya, seperti yang ditunjukkan di bawah ini.

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

Saat objek jenis ini diteruskan ke PdfDocument (kelas), setiap elemen yang ditambahkan ke dokumen ini akan ditulis ke file yang ditentukan.

Langkah 2: Membuat objek PdfDocument

Itu PdfDocumentkelas adalah kelas yang mewakili PDFDocument di iText. Kelas ini termasuk dalam paketcom.itextpdf.kernel.pdf. Untuk membuat instance kelas ini (dalam mode menulis), Anda perlu meneruskan objek kelasPdfWriter ke konstruktornya.

Buat instance kelas PdfDocument dengan meneruskan objek PdfWriter ke konstruktornya, seperti yang ditunjukkan di bawah ini.

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

Setelah objek PdfDocument dibuat, Anda dapat menambahkan berbagai elemen seperti halaman, font, lampiran file, penanganan kejadian menggunakan metode masing-masing yang disediakan oleh kelasnya.

Langkah 3: Membuat objek Dokumen

Itu Document kelas paket com.itextpdf.layoutadalah elemen root saat membuat PDF mandiri. Salah satu konstruktor kelas ini menerima objek kelasPdfDocument.

Buat instance kelas Dokumen dengan meneruskan objek kelas PdfDocument dibuat pada langkah sebelumnya, seperti yang ditunjukkan di bawah ini.

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

Langkah 4: Membuat objek PdfAnnotation

Itu PdfAnnotation kelas paket com.itextpdf.kernel.pdf.annot diwakili adalah superclass dari semua anotasi.

Di antara kelas turunannya, PdfLineAnnotationkelas mewakili anotasi garis. Buat objek dari kelas ini seperti yang ditunjukkan di bawah ini.

// Creating PdfAnnotation 
Rectangle rect = new Rectangle(20, 800, 0, 0); 
PdfAnnotation annotation = new PdfLineAnnotation(rect);

Langkah 5: Mengatur warna anotasi

Setel warna pada anotasi menggunakan setColor() metode dari PdfAnnotationkelas. Untuk metode ini, teruskan objek warna yang mewakili warna anotasi sebagai parameter.

// Setting color to the annotation 
annotation.setColor(Color.BLUE);

Langkah 6: Mengatur judul dan konten anotasi

Tetapkan judul dan konten anotasi menggunakan setTitle() dan setContents() metode dari PdfAnnotation kelas masing-masing, seperti yang ditunjukkan di bawah ini.

// Setting title to the PdfLineAnnotation 
annotation.setTitle(new PdfString("iText"));        

// Setting contents of the PdfLineAnnotation 
annotation.setContents("Hi welcome to Tutorialspoint");

Langkah 7: Menambahkan anotasi ke halaman

Buat yang baru PdfPage kelas menggunakan addNewPage() metode dari PdfDocument kelas dan tambahkan anotasi yang dibuat di atas menggunakan metode addAnnotation () dari kelas PdfPage, seperti yang ditunjukkan di bawah ini.

// Creating a new page 
PdfPage page = pdf.addNewPage();

// Adding annotation to a page in a PDF 
page.addAnnotation(annotation);

Langkah 8: Menutup Dokumen

Tutup dokumen menggunakan close() metode dari Document kelas, seperti yang ditunjukkan di bawah ini.

// Closing the document 
document.close();

Contoh

Program Java berikut mendemonstrasikan cara menambahkan anotasi garis ke dokumen PDF menggunakan pustaka iText. Ini membuat dokumen PDF dengan namalineAnnotation.pdf, menambahkan anotasi baris ke dalamnya, dan menyimpannya di jalur C:/itextExamples/.

Simpan kode ini dalam file dengan nama LineAnnotation.java.

import com.itextpdf.kernel.color.Color; 
import com.itextpdf.kernel.geom.Rectangle; 
import com.itextpdf.kernel.pdf.PdfDocument; 
import com.itextpdf.kernel.pdf.PdfPage; 
import com.itextpdf.kernel.pdf.PdfString; 
import com.itextpdf.kernel.pdf.PdfWriter; 
import com.itextpdf.kernel.pdf.annot.PdfAnnotation; 
import com.itextpdf.kernel.pdf.annot.PdfLineAnnotation; 
import com.itextpdf.layout.Document;  

public class LineAnnotation {
   public static void main(String args[]) throws Exception {             
      // Creating a PdfWriter       
      String dest = "C:/itextExamples/lineAnnotations.pdf";       
      PdfWriter writer = new PdfWriter(dest);               

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

      // Creating a Document        
      Document document = new Document(pdf);              
      
      // Creating a PdfPage       
      PdfPage page = pdf.addNewPage();              

      // creating PdfLineAnnotation object       
      Rectangle rect = new Rectangle(0, 0);
      float[] floatArray  = new float[]{
         20, 790, page.getPageSize().getWidth() - 20, 790
      };
      PdfAnnotation annotation = new PdfLineAnnotation(rect, floatArray);              
      
      // Setting color of the PdfLineAnnotation       
      annotation.setColor(Color.BLUE);              
      
      // Setting title to the PdfLineAnnotation       
      annotation.setTitle(new PdfString("iText"));              
      
      // Setting contents of the PdfLineAnnotation       
      annotation.setContents("Hi welcome to Tutorialspoint");              
      
      // Adding annotation to the page       
      page.addAnnotation(annotation);               
      
      // Closing the document       
      document.close();              
      
      System.out.println("Annotation added successfully");   
   } 
}

Kompilasi dan jalankan file Java yang disimpan dari command prompt menggunakan perintah berikut -

javac LineAnnotation.java 
java LineAnnotation

Setelah dijalankan, program di atas membuat dokumen PDF yang menampilkan pesan berikut.

Annotation added successfully

Jika Anda memverifikasi jalur yang ditentukan, Anda dapat menemukan dokumen PDF yang dibuat seperti yang ditunjukkan di bawah ini.