iText - 格式化單元格內容



在本章中,我們將瞭解如何使用 iText 庫建立 PDF 文件,新增表格以及格式化表格中單元格的內容。

格式化表格中的單元格

您可以透過例項化 Document 類來建立一個空的 PDF 文件。在例項化此類時,您需要將一個 PdfDocument 物件作為引數傳遞給它的建構函式。然後,要向文件新增表格,您需要例項化 Table 類並將此物件使用 add() 方法新增到文件中。您可以使用 Cell 類的不同方法來格式化表格中單元格的內容。

以下是格式化表格中單元格內容的步驟。

步驟 1:建立 PdfWriter 物件

PdfWriter 類表示 PDF 的 DocWriter。此類屬於 com.itextpdf.kernel.pdf 包。此類的建構函式接受一個字串,表示要建立 PDF 檔案的路徑。

透過將字串值(表示您需要建立 PDF 的路徑)傳遞給它的建構函式,例項化 PdfWriter 類,如下所示。

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

當此型別的物件傳遞給 PdfDocument(類)時,新增到此文件的每個元素都將寫入指定的檔案。

步驟 2:建立 PdfDocument 物件

PdfDocument 類是表示 iText 中 PDF 文件的類。此類屬於 com.itextpdf.kernel.pdf 包。要例項化此類(在寫入模式下),您需要將 PdfWriter 類的物件傳遞給它的建構函式。

透過將上面建立的 PdfWriter 物件傳遞給它的建構函式,例項化 PdfDocument 類,如下所示。

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

建立 PdfDocument 物件後,您可以使用其類提供的相應方法新增各種元素,例如頁面、字型、檔案附件和事件處理程式。

步驟 3:建立 Document 物件

com.itextpdf.layout 包的 Document 類是建立自包含 PDF 時的根元素。此類的一個建構函式接受 PdfDocument 類的物件。

透過將上一步中建立的 PdfDocument 類的物件傳遞給它,例項化 Document 類,如下所示。

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

步驟 4:建立 Table 物件

Table 類表示一個由單元格填充的二維網格,按行和列排序。它屬於 com.itextpdf.layout.element 包。

如下所示例項化 Table 類。

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

步驟 5:建立單元格

透過例項化 com.itextpdf.layout.element 包的 Cell 類來建立一個 cell 物件。使用 Cell 類的 add() 方法新增單元格的內容,如下所示。

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

// Adding cell 2 to the table 
Cell cell2 = new Cell();     // Creating a cell 
cell2.add("Raju");           // Adding content to the cell 

步驟 6:向單元格新增背景

建立單元格並向其中新增內容後,您可以格式化單元格。例如,您可以使用單元格類的不同方法(如 setBackgroundColor()、setBorder()、setTextAlignment())設定其背景、對齊單元格內的文字、更改文字顏色等。

您可以將背景顏色、邊框和文字對齊方式設定為上一步中建立的單元格,如下所示。

c1.setBackgroundColor(Color.DARK_GRAY);    // Setting background color to cell1 
c1.setBorder(Border.NO_BORDER);            // Setting border to cell1 
c1.setTextAlignment(TextAlignment.CENTER); // Setting text alignment to cell1 

步驟 7:將單元格新增到表格

最後,要將此單元格新增到表格,請呼叫 Table 類的 addCell() 方法並將 cell 物件作為引數傳遞給此方法,如下所示。

table.addCell(c1);

步驟 8:將表格新增到文件

使用 Document 類的 add() 方法新增上一步中建立的 table 物件,如下所示。

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

步驟 9:關閉文件

使用 Document 類的 close() 方法關閉文件,如下所示。

// Closing the document 
document.close();

示例

以下 Java 程式演示瞭如何使用 iText 庫格式化表格中單元格的內容。它建立一個名為 addingBackground.pdf 的 PDF 文件,向其中新增一個表格,格式化其單元格的內容,並將其儲存到 C:/itextExamples/ 路徑。

將此程式碼儲存在名為 BackgroundToTable.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.element.Cell; 
import com.itextpdf.layout.element.Table; 
import com.itextpdf.layout.property.TextAlignment;  

public class BackgroundToTable {      
   public static void main(String args[]) throws Exception {        
      // Creating a PdfWriter object   
      String dest = "C:/itextExamples/addingBackground.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);
      
      // Populating row 1 and adding it to the table               
      Cell c1 = new Cell();                        // Creating cell 1 
      c1.add("Name");                              // Adding name to cell 1   
      c1.setBackgroundColor(Color.DARK_GRAY);      // Setting background color
      c1.setBorder(Border.NO_BORDER);              // Setting border
      c1.setTextAlignment(TextAlignment.CENTER);   // Setting text alignment      
      table.addCell(c1);                           // Adding cell 1 to the table 
      
      Cell c2 = new 
      Cell();                               
      c2.add("Raju");       
      c2.setBackgroundColor(Color.GRAY);       
      c2.setBorder(Border.NO_BORDER);       
      c2.setTextAlignment(TextAlignment.CENTER);      
      table.addCell(c2);      
      
      // Populating row 2 and adding it to the table               
      Cell c3 = new Cell();       
      c3.add("Id");       
      c3.setBackgroundColor(Color.WHITE);       
      c3.setBorder(Border.NO_BORDER);       
      c3.setTextAlignment(TextAlignment.CENTER);      
      table.addCell(c3);                          
      
      Cell c4 = new Cell();       
      c4.add("001");       
      c4.setBackgroundColor(Color.WHITE);       
      c4.setBorder(Border.NO_BORDER);       
      c4.setTextAlignment(TextAlignment.CENTER);      
      table.addCell(c4);                          
      
      // Populating row 3 and adding it to the table        
      Cell c5 = new Cell();       
      c5.add("Designation");       
      c5.setBackgroundColor(Color.DARK_GRAY);       
      c5.setBorder(Border.NO_BORDER);       
      c5.setTextAlignment(TextAlignment.CENTER);      
      table.addCell(c5);                 
      
      Cell c6 = new Cell(); 
      c6.add("Programmer");       
      c6.setBackgroundColor(Color.GRAY);       
      c6.setBorder(Border.NO_BORDER);       
      c6.setTextAlignment(TextAlignment.CENTER);       
      table.addCell(c6);                              
      
      // Adding Table to document        
      doc.add(table);                  
      
      // Closing the document       
      doc.close();  
      
      System.out.println("Background added successfully..");     
   } 
} 

使用以下命令從命令提示符編譯並執行儲存的 Java 檔案:

javac BackgroundToTable.java 
java BackgroundToTable 

執行後,上述程式將建立一個 PDF 文件,顯示以下訊息。

Background added successfully..

如果驗證指定的路徑,則可以找到建立的 PDF 文件,如下所示。

Adding Background
廣告

© . All rights reserved.