iText - Memformat Perbatasan Sel

Dalam bab ini, kita akan melihat bagaimana memformat batas sel dalam tabel menggunakan pustaka iText.

Memformat Perbatasan Sel

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

Kemudian, untuk menambahkan tabel ke dokumen, Anda perlu membuat instance Table kelas dan tambahkan objek ini ke dokumen menggunakan add() metode.

Anda dapat menambahkan berbagai jenis perbatasan seperti DashedBorder, SolidBorder, DottedBorder, DoubleBorder, RoundDotsBorder, dll. dengan berbagai warna menggunakan setBorder() metode dari Cell kelas.

Berikut adalah langkah-langkah untuk memformat batas sel dalam tabel.

Langkah 1: Membuat objek PdfWriter

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

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

// Creating a PdfWriter 
String dest = "C:/itextExamples/coloredBorders.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.

Instantiate PdfDocument kelas dengan melewatkan di atas dibuat PdfWriter menolak 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, dan 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 dari kelas PdfDocument.

Instantiate Document kelas dengan melewatkan 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 Tabel

Itu Tableclass mewakili kisi dua dimensi yang diisi dengan sel yang diurutkan dalam baris dan kolom. Itu milik paketcom.itextpdf.layout.element.

Instantiate Table kelas seperti yang ditunjukkan di bawah ini.

// Creating a table 
float [] pointColumnWidths = {200F, 200F}; 
Table table = new Table(pointColumnWidths);

Langkah 5: Membuat sel

Buat objek sel dengan membuat instance Cell kelas paket com.itextpdf.layout.element tambahkan konten sel menggunakan add() metode dari Cell kelas, seperti yang ditunjukkan di bawah ini.

// Adding cell 1 to the table 
Cell cell1 = new Cell(); // Creating a cell 
cell1.add("Name");       // Adding content to the cell

Langkah 6: Memformat batas sel

Perpustakaan iText menyediakan berbagai kelas yang mewakili perbatasan seperti DashedBorder, SolidBorder, DottedBorder, DoubleBorder, RoundDotsBorder, dll.

Konstruktor kelas ini menerima dua parameter: a color objek yang mewakili warna perbatasan dan integer mewakili lebar perbatasan.

Pilih salah satu dari jenis perbatasan ini dan buat contoh perbatasan masing-masing dengan melewatkan color objek dan integer mewakili lebar, seperti yang ditunjukkan di bawah ini.

Border b1 = new DashedBorder(Color.RED, 3);

Sekarang, atur batas sel menggunakan setBorder() metode dari cellkelas. Metode ini menerima objek berjenisBorder sebagai parameter.

Atur perbatasan sel dengan melewatkan yang dibuat di atas Border objek sebagai parameter ke setBorder() metode seperti yang ditunjukkan di bawah ini.

c1.setBorder(b1)

Terakhir, untuk menambahkan sel ini ke tabel, panggil addCell() metode dari Table kelas dan lulus cell objek sebagai parameter untuk metode ini, seperti yang ditunjukkan di bawah ini.

table.addCell(c1);

Langkah 7: Menambahkan tabel ke dokumen

Tambahkan table objek yang dibuat pada langkah sebelumnya menggunakan add() metode dari Document kelas, seperti yang ditunjukkan di bawah ini.

// Adding list to the document 
document.add(table);

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 memformat batas sel dalam tabel menggunakan pustaka iText. Ini membuat dokumen PDF dengan namacoloredBorders.pdf, menambahkan tabel ke dalamnya, memformat konten selnya, dan menyimpannya di jalur C:/itextExamples/

Simpan kode ini dalam file dengan nama FormatedBorders.java.

import com.itextpdf.kernel.color.Color; 
import com.itextpdf.kernel.pdf.PdfDocument; 
import com.itextpdf.kernel.pdf.PdfWriter; 

import com.itextpdf.layout.Document; 
import com.itextpdf.layout.border.Border; 
import com.itextpdf.layout.border.DashedBorder; 
import com.itextpdf.layout.border.DottedBorder; 
import com.itextpdf.layout.border.DoubleBorder; 
import com.itextpdf.layout.border.RoundDotsBorder; 
import com.itextpdf.layout.border.SolidBorder; 

import com.itextpdf.layout.element.Cell; 
import com.itextpdf.layout.element.Table; 
import com.itextpdf.layout.property.TextAlignment;  

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

      // Creating a PdfDocument object       
      PdfDocument pdfDoc = new PdfDocument(writer);                      
   
      // Creating a Document object      
      Document doc = new Document(pdfDoc);                            
   
      // Creating a table       
      float [] pointColumnWidths = {200F, 200F};       
      Table table = new Table(pointColumnWidths); 
   
      // Adding row 1 to the table
      Cell c1 = new Cell();
      
      // Adding the contents of the cell
      c1.add("Name");
   
      // Setting the back ground color of the cell
      c1.setBackgroundColor(Color.DARK_GRAY);    
   
      // Instantiating the Border class 
      Border b1 = new DashedBorder(Color.RED, 3);
   
      // Setting the border of the cell
      c1.setBorder(b1);
      
      // Setting the text alignment       
      c1.setTextAlignment(TextAlignment.CENTER);
   
      // Adding the cell to the table       
      table.addCell(c1);                          
      Cell c2 = new Cell();       
      c2.add("Raju");       
      c1.setBorder(new SolidBorder(Color.RED, 3));       
      c2.setTextAlignment(TextAlignment.CENTER);       
      table.addCell(c2);
   
      // Adding row 2 to the table                
      Cell c3 = new Cell();      
      c3.add("Id"); 
      c3.setBorder(new DottedBorder(Color.DARK_GRAY, 3));       
      c3.setTextAlignment(TextAlignment.CENTER);      
      table.addCell(c3);                          
      
      Cell c4 = new Cell();       
      c4.add("001");       
      c4.setBorder(new DoubleBorder(Color.DARK_GRAY, 3));       
      c4.setTextAlignment(TextAlignment.CENTER);       
      table.addCell(c4);                          
      
      // Adding row 3 to the table       
      Cell c5 = new Cell();       
      c5.add("Designation");       
      c5.setBorder(new RoundDotsBorder(Color.RED, 3));       
      c5.setTextAlignment(TextAlignment.CENTER);       
      table.addCell(c5);                 
      
      Cell c6 = new Cell();       
      c6.add("Programmer");       
      c6.setBorder(new RoundDotsBorder(Color.RED, 3)); 
      c6.setTextAlignment(TextAlignment.CENTER);      
      table.addCell(c6);                              
      
      // Adding Table to document        
      doc.add(table);                  
      
      // Closing the document       
      doc.close();  
      
      System.out.println("Borders added successfully..");     
   } 
}

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

javac FormatedBorders.java 
java FormatedBorders

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

Borders added successfully

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