package test;
import java.awt.Color;
import java.io.FileOutputStream;
import com.lowagie.text.Cell;
import com.lowagie.text.Chapter;
import com.lowagie.text.Document;
import com.lowagie.text.Font;
import com.lowagie.text.FontFactory;
import com.lowagie.text.List;
import com.lowagie.text.ListItem;
import com.lowagie.text.PageSize;
import com.lowagie.text.Paragraph;
import com.lowagie.text.Section;
import com.lowagie.text.Table;
import com.lowagie.text.pdf.PdfWriter;
public class ITextTest {
public static void main(String[] args) {
try {
/** */ /**
* 實例化文檔對象 第一個參數是頁面大小。接下來的參數分別是左、右、上和下頁邊距。但是還沒有定義該文檔的類型。
* 它取決於所創建的寫入器的類型。對於我們的示例,選擇了com.lowagie.text.pdf.PdfWriter。 其他寫入器爲
* HtmlWriter、RtfWriter、XmlWriter 等等。它們的名稱解釋了它們的實際用途。
*/
Document document = new Document(PageSize.A4, 50 , 50 , 50 , 50 );
/** */ /**
* 創建 PdfWriter 對象,第一個參數是對文檔對象的引用,第二個參數是文件的實際名稱,在該名稱中還會給出其輸出路徑。
*/
PdfWriter writer = PdfWriter.getInstance(document,
new FileOutputStream( " D:\\ITextTest.pdf " ));
/** */ /**
* 打開文檔以寫入內容
*/
document.open();
/** */ /**
* 現在,將在文檔的第一頁上添加一些文本。通過 com.lowagie.text.Paragraph
* 來添加文本。可以用文本及其默認的字體、顏色、大小等等設置來創建一個默認段落。
* 或者,也可以設置自己的字體。下面讓我們來看看這兩種做法。
*
* 創建段落對象
*
*/
document.add( new Paragraph( " First page of the document. " ));
document
.add( new Paragraph(
" Some more text on the first page with different color and font type. " ,
FontFactory.getFont(FontFactory.COURIER, 14 ,
Font.BOLD, new Color( 255 , 150 , 200 ))));
/** */ /**
* 您已經看到了如何向 PDF文檔中添加純文本。 接下來,需要向文檔中添加一些複雜的元素。我們開始創建一個新的章節。
* 章節是一個特殊的小節,默認情況下,章節從一個新的頁面開始,並顯示一個默認的編號。
*
* 創建章節對象
*/
Paragraph title1 = new Paragraph( " Chapter 1 " , FontFactory.getFont(
FontFactory.HELVETICA, 18 , Font.BOLDITALIC, new Color( 0 , 0 ,
255 )));
Chapter chapter1 = new Chapter(title1, 1 );
chapter1.setNumberDepth( 0 );
/** */ /**
* 在上面的代碼中,創建了一個新的章節對象,chapter1,其標題爲 “This is Chapter 1”,將編號級別設爲 0
* 就不會在頁面上顯示章節編號。
*
* 小節是章節的子元素。在下面的代碼中,創建了一個標題爲 “This is Section 1 in Chapter 1”
* 的小節。爲在該小節下添加一些文本,創建了另一個段落對象,someSectionText,並將其添加到小節對象中。
*
* 創建小節對象
*
*/
Paragraph title11 = new Paragraph( " This is Section 1 in Chapter 1 " ,
FontFactory.getFont(FontFactory.HELVETICA, 16 , Font.BOLD,
new Color( 255 , 0 , 0 )));
Section section1 = chapter1.addSection(title11);
Paragraph someSectionText = new Paragraph(
" This text comes as part of section 1 of chapter 1. " );
section1.add(someSectionText);
someSectionText = new Paragraph( " Following is a 3 X 2 table. " );
section1.add(someSectionText);
/** */ /**
* 在添加表格之前,我們先看一下文檔的樣子。添加下面兩行代碼以關閉文檔,然後編譯並執行程序以生成 PDF
* 文檔:document.add(chapter1);document.close();
*/
/** */ /**
* 接下來,創建一個表格對象。創建一個包含行列矩陣的表格。行中的單元格可以跨多個列。同樣地,列中的單元格也可以跨多個行。 因此,一個
* 3 x 2 的表格實際上不一定有 6 個單元格。
*
* 創建表格對象
*/
Table t = new Table( 3 , 2 );
t.setBorderColor( new Color( 220 , 255 , 100 ));
t.setPadding( 5 );
t.setSpacing( 5 );
t.setBorderWidth( 1 );
Cell c1 = new Cell( " header1 " );
t.addCell(c1);
c1 = new Cell( " Header2 " );
t.addCell(c1);
c1 = new Cell( " Header3 " );
t.addCell(c1);
t.addCell( " 1.1 " );
t.addCell( " 1.2 " );
t.addCell( " 1.3 " );
section1.add(t);
/** */ /**
* 在上面的代碼中,創建了一個表格對象,t,它有三列、兩行。然後設置表格的邊框顏色。填充用於設置單元格中文本間的間隔以及單元格的邊界。
* 間隔指的是相鄰單元格間的邊界。接下來,將創建三個單元格對象,每個單元格中的文本都各不相同。接下來,將它們添加到表格中。
* 將它們添加到第一行中,從第一列開始,移到同一行中的下一列。一旦該行創建完成,就將下一個單元格添加到下一行的第一列中。
* 也可以通過只提供單元格的文本將單元格添加到表格中,例如,t.addCell("1.1");。最後,將表格對象添加到小節對象中。
*
* 最後,我們來看一下如何將列表添加到 PDF 文檔中。列表包含一定數量的
* ListItem。可以對列表進行編號,也可以不編號。將第一個參數設置爲 true 表明想創建一個要進行編號的列表。
*
* 創建列表對象
*/
List l = new List( true , true , 10 );
l.add( new ListItem( " First item of list " ));
l.add( new ListItem( " Second item of list " ));
section1.add(l);
/** */ /**
* 我們已經向 chapter1 對象中添加了所需的對象。因此,已經沒有其他要添加到 chapter1 中的元素了,現在可以將
* chapter1 添加到主 document 中了。與在示例應用程序中所做的一樣,還要在這時關閉文檔對象。
*
* 向主文檔中添加章節
*/
document.add(chapter1);
document.close();
} catch (Exception e2) {
System.out.println(e2.getMessage());
}
/** */ /**
* 您已經看到了一些生成 PDF 的基本元素。iText的美妙之處是相同元素的語法可以供不同類型的寫入器使用。
* 而且,寫入器的輸出可以重定向到控制檯(當寫入器類型是 XML 和 HTML時)、
* servlet 的輸出流(在對 PDF 文檔的 Web 請求作出響應時)或者是其他類型的OutputStream。
* 當響應相同,但其類型隨所請求的是 PDF、RTF、HTML 或 XML 文檔而有所不同時,使用 iText是非常方便的。
* iText 允許用戶創建水印,對文檔進行加密以及設置其他輸出細節。
*/
}
}