iText-クイックガイド

Portable Document Format(PDF)は、アプリケーションソフトウェア、ハードウェア、およびオペレーティングシステムに依存しない方法でデータを表示するのに役立つファイル形式です。各PDFファイルには、テキスト、フォント、グラフィックス、およびそれを表示するために必要なその他の情報を含む、固定レイアウトのフラットドキュメントの説明が含まれています。

次のようなプログラムを介してPDFドキュメントを作成および操作するために使用できるライブラリがいくつかあります。

  • Adobe PDF Library−このライブラリは、C ++ 、. NET、Javaなどの言語でAPIを提供します。これを使用して、PDFドキュメントからテキストを編集、表示、印刷、および抽出できます。

  • Formatting Objects Processor− XSL FormattingObjectsによって駆動されるオープンソースの印刷フォーマッターと出力に依存しないフォーマッター。主な出力ターゲットはPDFです。

  • PDF Box− Apache PDFBoxは、PDFドキュメントの開発と変換をサポートするオープンソースのJavaライブラリです。このライブラリを使用すると、PDFドキュメントを作成、変換、操作するJavaプログラムを開発できます。

  • Jasper Reports −これは、Microsoft Excel、RTF、ODT、コンマ区切り値、XMLファイルを含むPDFドキュメントでレポートを生成するJavaレポートツールです。

iTextとは何ですか?

上記のソフトウェアと同様に、iTextはJava PDFライブラリであり、これを使用して、PDFドキュメントを作成、変換、および操作するJavaプログラムを開発できます。

iTextの機能

以下はiTextライブラリの注目すべき機能です-

  • Interactive− iTextは、インタラクティブなPDFドキュメントを生成するためのクラス(API)を提供します。これらを使用して、地図や本を作成できます。

  • Adding bookmarks, page numbers, etc − iTextを使用して、ブックマーク、ページ番号、透かしを追加できます。

  • Split & Merge − iTextを使用すると、既存のPDFを複数のPDFに分割したり、追加のページを追加/連結したりできます。

  • Fill Forms − iTextを使用すると、PDFドキュメントのインタラクティブフォームに入力できます。

  • Save as Image − iTextを使用すると、PDFをPNGやJPEGなどの画像ファイルとして保存できます。

  • Canvas − iTextライブラリは、円や線などのさまざまな幾何学的形状をPDFドキュメントに描画できるCanvasクラスを提供します。

  • Create PDFs− iTextを使用して、Javaプログラムから新しいPDFファイルを作成できます。画像やフォントを含めることもできます。

IText環境

以下の手順に従って、EclipseでiText環境を設定します。

Step 1 − Eclipseをインストールし、以下に示すようにEclipseで新しいプロジェクトを開きます。

Step 2 −作成する iTextSample 以下に示すようにプロジェクト。

Step 3−以下に示すように、プロジェクトを右クリックしてMavenプロジェクトに変換します。Mavenプロジェクトに変換すると、pom.xml必要な依存関係について言及する必要がある場合。その後、jar これらの依存関係のファイルは、プロジェクトに自動的にダウンロードされます。

Step 4 −さて、 pom.xml プロジェクトの内容をコピーして貼り付け(iTextアプリケーションの依存関係)、プロジェクトを更新します。

Using pom.xml

プロジェクトをMavenプロジェクトに変換し、次のコンテンツをそのプロジェクトに追加します pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">   
   
   <modelVersion>4.0.0</modelVersion>   
   <groupId>SanthoshExample</groupId>   
   <artifactId>SanthoshExample</artifactId>   
   <version>0.0.1-SNAPSHOT</version>   
   <build>     
      <sourceDirectory>src</sourceDirectory>     
      <plugins>       
         <plugin>         
            <artifactId>maven-compiler-plugin</artifactId>         
            <version>3.5.1</version>         
            <configuration>           
               <source>1.8</source>           
               <target>1.8</target>      
            </configuration>       
         </plugin>     
      </plugins>   
   </build>     
   
   <dependencies>     
      <!-- always needed -->     
      <dependency>         
         <groupId>com.itextpdf</groupId>         
         <artifactId>kernel</artifactId>         
         <version>7.0.2</version>     
      </dependency>  
      
      <dependency>         
         <groupId>com.itextpdf</groupId>         
         <artifactId>io</artifactId>         
         <version>7.0.2</version>     
      </dependency>  
      
      <dependency>         
         <groupId>com.itextpdf</groupId>         
         <artifactId>layout</artifactId>         
         <version>7.0.2</version>
      </dependency>  
      
      <dependency>         
         <groupId>com.itextpdf</groupId>         
         <artifactId>forms</artifactId>         
         <version>7.0.2</version>    
      </dependency>  
      
      <dependency>         
         <groupId>com.itextpdf</groupId>         
         <artifactId>pdfa</artifactId>         
         <version>7.0.2</version>     
      </dependency>  
      
      <dependency>         
         <groupId>com.itextpdf</groupId>         
         <artifactId>sign</artifactId>         
         <version>7.0.2</version>     
      </dependency>  
      
      <dependency>         
         <groupId>com.itextpdf</groupId>         
         <artifactId>barcodes</artifactId>         
         <version>7.0.2</version>     
      </dependency>  
      
      <dependency>         
         <groupId>com.itextpdf</groupId>         
         <artifactId>font-asian</artifactId>         
         <version>7.0.2</version>     
      </dependency>  
      
      <dependency>         
         <groupId>com.itextpdf</groupId>         
         <artifactId>hyph</artifactId>         
         <version>7.0.2</version>    
      </dependency> 
   </dependencies>
   
</project>

最後に、Mavenの依存関係を観察すると、必要なすべての依存関係を観察できます。 jar ファイルがダウンロードされました。

ここで、iTextライブラリを使用してPDFドキュメントを作成する方法を理解しましょう。

空のPDFドキュメントの作成

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

空のPDFドキュメントを作成する手順は次のとおりです。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterclassは、PDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、上記で作成したPdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:空のページを追加する

ザ・ addNewPage() の方法 PdfDocument クラスは、PDFドキュメントに空のページを作成するために使用されます。

以下に示すように、前の手順で作成したPDFドキュメントに空のページを追加します。

// Adding an empty page 
pdfDoc.addNewPage();

ステップ4:ドキュメントオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ5:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すクラス。

// Closing the document 
document.close();

以下は、PDFドキュメントの作成を示すJavaプログラムです。名前の付いたPDFドキュメントを作成しますsample.pdf、空のページを追加して、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します create_PDF.java

import com.itextpdf.kernel.pdf.PdfDocument; 
import com.itextpdf.kernel.pdf.PdfWriter; 
import com.itextpdf.layout.Document;  

public class create_PDF {    
   public static void main(String args[]) throws Exception {              
      // Creating a PdfWriter       
      String dest = "C:/itextExamples/sample.pdf";       
      PdfWriter writer = new PdfWriter(dest); 
   
      // Creating a PdfDocument       
      PdfDocument pdfDoc = new PdfDocument(writer);              
   
      // Adding a new page 
      pdfDoc.addNewPage();               
   
      // Creating a Document        
      Document document = new Document(pdfDoc);               
   
      // Closing the document    
      document.close();              
      System.out.println("PDF Created");    
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac create_PDF.java 
java create_PDF

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

PDF created

指定したパスを確認すると、作成したPDFドキュメントが以下のように表示されます。

これは空のドキュメントであるため、このドキュメントを開こうとすると、次のスクリーンショットに示すようにエラーメッセージが表示されます。

この章では、iTextライブラリを使用してAreaBreakでPDFドキュメントを作成する方法を説明します。

AreaBreakの作成

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocumentコンストラクターへのパラメーターとしてのオブジェクト。次に、ドキュメントにエリアブレイクを追加するには、インスタンス化する必要がありますAreaBreak クラスと add このオブジェクトを使用して文書化する add() 方法。

以下は、AreaBreakを使用して空のPDFドキュメントを作成する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriter クラスはPDFのDocWriterを表し、このクラスはパッケージに属します com.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、PDFを作成する必要があるパスを表す文字列値をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocument classは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属しています。 com.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、上記で作成したPdfWriterオブジェクトをコンストラクターに渡すことにより、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:ドキュメントオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:エリアブレークオブジェクトを作成する

ザ・ AreaBreak クラスはパッケージに属しています com.itextpdf.layout.element。このクラスをインスタンス化すると、現在のコンテキスト領域が終了し、同じサイズで新しいコンテキスト領域が作成されます(デフォルトのコンストラクターを使用する場合)。

インスタンス化する AreaBreak 以下に示すクラス。

// Creating an Area Break    
AreaBreak aB = new AreaBreak();

ステップ5:AreaBreakを追加する

追加します areabreak 前の手順で作成されたオブジェクト add() 以下に示すように、Documentクラスのメソッド。

// Adding area break to the PDF 
document.add(aB);

ステップ6:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すクラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してAreaBreakでPDFドキュメントを作成する方法を示しています。名前の付いたPDFドキュメントを作成しますaddingAreaBreak.pdf、追加します areabreak それに、そしてそれをパスに保存します C:/itextExamples/

このコードを名前のファイルに保存します AddingAreaBreak.java

import com.itextpdf.kernel.pdf.PdfDocument; 
import com.itextpdf.kernel.pdf.PdfWriter; 
import com.itextpdf.layout.Document; 
import com.itextpdf.layout.element.AreaBreak;  

public class AddingAreaBreak {    
   public static void main(String args[]) throws Exception {       
      // Creating a PdfWriter       
      String dest = "C:/itextExamples/addingAreaBreak.pdf";       
      PdfWriter writer = new PdfWriter(dest);
   
      // Creating a PdfDocument       
      PdfDocument pdf = new PdfDocument(writer);             
   
      // Creating a Document by passing PdfDocument object to its constructor       
      Document document = new Document(pdf);  
   
      // Creating an Area Break          
      AreaBreak aB = new AreaBreak();           
   
      // Adding area break to the PDF       
      document.add(aB);              
   
      // Closing the document       
      document.close();           
      System.out.println("Pdf created");       
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac AddingAreaBreak.java 
java AddingAreaBreak

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

Pdf Created

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントを作成し、それに段落を追加する方法を説明します。

段落の作成

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocumentコンストラクターへのパラメーターとしてのオブジェクト。次に、ドキュメントに段落を追加するには、インスタンス化する必要がありますParagraph クラスを作成し、を使用してこのオブジェクトをドキュメントに追加します add() 方法。

以下は、段落を含むPDFドキュメントを作成する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterclassは、PDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、上記で作成したPdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentクラスを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutルート要素です。自給自足のPDFを作成している間。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

クラスのオブジェクトを渡すことにより、Documentクラスをインスタンス化します PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:段落オブジェクトを作成する

ザ・ Paragraphクラスは、テキストおよびグラフィック情報の自己完結型ブロックを表します。パッケージに属していますcom.itextpdf.layout.element

インスタンス化する Paragraph 以下に示すように、テキストコンテンツを文字列としてコンストラクタに渡すことによってクラスを作成します。

String para = "Welcome to Tutorialspoint."; 
// Creating an Area Break    
Paragraph para = new Paragraph (para);

ステップ5:段落を追加する

追加します Paragraph 前の手順で作成されたオブジェクト add() の方法 Document 以下に示すように、クラス。

// Adding area break to the PDF 
document.add(para);

ステップ6:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントを作成し、それに段落を追加する方法を示しています。名前の付いたPDFドキュメントを作成しますaddingParagraph.pdf、それに段落を追加し、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します AddingParagraph.java

import com.itextpdf.kernel.pdf.PdfDocument; 
import com.itextpdf.kernel.pdf.PdfWriter; 
import com.itextpdf.layout.Document; 
import com.itextpdf.layout.element.Paragraph;  

public class AddingParagraph {    
   public static void main(String args[]) throws Exception {
      // Creating a PdfWriter       
      String dest = "C:/itextExamples/addingParagraph.pdf";       
      PdfWriter writer = new PdfWriter(dest);           
      
      // Creating a PdfDocument       
      PdfDocument pdf = new PdfDocument(writer);              
      
      // Creating a Document        
      Document document = new Document(pdf);              
      String para1 = "Tutorials Point originated from the idea that there exists 
      a class of readers who respond better to online content and prefer to learn 
      new skills at their own pace from the comforts of their drawing rooms.";  
      
      String para2 = "The journey commenced with a single tutorial on HTML in 2006 
      and elated by the response it generated, we worked our way to adding fresh 
      tutorials to our repository which now proudly flaunts a wealth of tutorials 
      and allied articles on topics ranging from programming languages to web designing 
      to academics and much more.";              
      
      // Creating Paragraphs       
      Paragraph paragraph1 = new Paragraph(para1);             
      Paragraph paragraph2 = new Paragraph(para2);              
      
      // Adding paragraphs to document       
      document.add(paragraph1);       
      document.add(paragraph2);           
      
      // Closing the document       
      document.close();             
      System.out.println("Paragraph added");    
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac AddingParagraph.java 
java AddingParagraph

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

Paragraph added

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントを作成し、それにリストを追加する方法を説明します。

リストの作成

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocumentコンストラクターへのパラメーターとしてのオブジェクト。次に、ドキュメントにリストを追加するには、インスタンス化する必要がありますList クラスを作成し、を使用してこのオブジェクトをドキュメントに追加します add() 方法。

PDFドキュメントを作成し、その中にリストを追加する手順は次のとおりです。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocument classは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属しています。 com.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、上記で作成したPdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:リストオブジェクトを作成する

ザ・ Listクラスは、垂直方向に輪郭が描かれた一連のオブジェクトを表します。パッケージに属していますcom.itextpdf.layout.element

インスタンス化する List 以下に示すクラス。

// Creating a list  
List list = new List();

ステップ5:リストに要素を追加する

にコンテンツを追加します list を使用するオブジェクト add() の方法 List 以下に示すように、文字列値を渡すことによってクラスを作成します。

//  Add elements to the list 
list.add("Java"); 
list.add("JavaFX"); 
list.add("Apache Tika"); 
list.add("OpenCV");

ステップ6:ドキュメントにリストを追加する

追加します list 前の手順で作成されたオブジェクト add() の方法 Document 以下に示すように、クラス。

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

ステップ7:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すクラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントを作成し、それにリストを追加する方法を示しています。名前の付いたPDFドキュメントを作成しますaddingList.pdf、リストを追加し、パスに保存します C:/itextExamples/

このコードを名前の付いたファイルに保存します AddingList.java

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

import com.itextpdf.layout.Document; 
import com.itextpdf.layout.element.List; 
import com.itextpdf.layout.element.Paragraph;  

public class AddingList {      
   public static void main(String args[]) throws Exception {               
      // Creating a PdfWriter
      String dest = "C:/itextExamples/addngList.pdf";       
      PdfWriter writer = new PdfWriter(dest);              
   
      // Creating a PdfDocument       
      PdfDocument pdf = new PdfDocument(writer);              
   
      // Creating a Document        
      Document document = new Document(pdf);              
   
      // Creating a Paragraph       
      Paragraph paragraph = new Paragraph("Tutorials Point provides the following tutorials");
      
      // Creating a list
      List list = new List();  
      
      // Add elements to the list       
      list.add("Java");       
      list.add("JavaFX");      
      list.add("Apache Tika");       
      list.add("OpenCV");       
      list.add("WebGL");       
      list.add("Coffee Script");       
      list.add("Java RMI");       
      list.add("Apache Pig");              
      
      // Adding paragraph to the document       
      document.add(paragraph);                    
     
      // Adding list to the document       
      document.add(list);
      
      // Closing the document       
      document.close();              
      System.out.println("List added");    
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac AddingList.java 
java AddingList

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

List added

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントを作成し、それにテーブルを追加する方法を説明します。

PDFへのテーブルの追加

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocumentコンストラクターへのパラメーターとしてのオブジェクト。次に、ドキュメントにテーブルを追加するには、インスタンス化する必要がありますTable クラスを作成し、を使用してこのオブジェクトをドキュメントに追加します add() 方法。

以下は、テーブルを含むPDFドキュメントを作成する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

インスタンス化する PdfWriter 以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことによってクラスを作成します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、上記で作成したPdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスのオブジェクトを受け入れますPdfDocument

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:テーブルオブジェクトを作成する

ザ・ Tableクラスは、行と列に並べられたセルで満たされた2次元グリッドを表します。パッケージに属していますcom.itextpdf.layout.element

インスタンス化する Table 以下に示すクラス。

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

ステップ5:テーブルにセルを追加する

作成する cell オブジェクトをインスタンス化して Cell パッケージのクラス com.itextpdf.layout.element。を使用してセルの内容を追加しますadd() このクラスのメソッド。

最後に、このセルをテーブルに追加するには、 addCell() の方法 Table クラスと合格 cell 以下に示すように、このメソッドのパラメーターとしてのオブジェクト。

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

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

ステップ6:ドキュメントにテーブルを追加する

追加します table 前の手順で作成されたオブジェクト add() の方法 Document 以下に示すクラス。

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

ステップ7:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントを作成し、それにテーブルを追加する方法を示しています。名前の付いたPDFドキュメントを作成しますaddingTable.pdf、それにテーブルを追加し、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します AddingTable.java

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

import com.itextpdf.layout.Document; 
import com.itextpdf.layout.element.Cell; 
import com.itextpdf.layout.element.Table;  

public class AddingTable {      
   public static void main(String args[]) throws Exception {           
      // Creating a PdfDocument object   
      String dest = "C:/itextExamples/addingTable.pdf";   
      PdfWriter writer = new PdfWriter(dest);       
         
      // Creating a PdfDocument object      
      PdfDocument pdf = new PdfDocument(writer);                  
      
      // Creating a Document object       
      Document doc = new Document(pdf);                       
         
      // Creating a table       
      float [] pointColumnWidths = {150F, 150F, 150F};   
      Table table = new Table(pointColumnWidths);    
      
      // Adding cells to the table       
      table.addCell(new Cell().add("Name"));       
      table.addCell(new Cell().add("Raju"));       
      table.addCell(new Cell().add("Id"));       
      table.addCell(new Cell().add("1001"));       
      table.addCell(new Cell().add("Designation"));       
      table.addCell(new Cell().add("Programmer"));                 
         
      // Adding Table to document        
      doc.add(table);                  
         
      // Closing the document       
      doc.close();
      System.out.println("Table created successfully..");   
   }     
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac AddingTable.java 
java AddingTable

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

Table created successfully..

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用して、PDFドキュメントを作成し、テーブルを追加し、テーブル内のセルの内容をフォーマットする方法を説明します。

テーブル内のセルのフォーマット

空のPDFを作成できます DocumentDocumentクラスをインスタンス化する。このクラスをインスタンス化するときに、合格する必要があります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オブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFDocumentを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

インスタンス化する PdfDocument 上記で作成したクラスを渡すことによってクラス PdfWriter 以下に示すように、コンストラクターに対するオブジェクト。

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

一度 PdfDocument オブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:テーブルオブジェクトを作成する

ザ・ Tableクラスは、行と列で順序付けられた、セルで満たされた2次元グリッドを表します。パッケージに属していますcom.itextpdf.layout.element

以下に示すように、Tableクラスをインスタンス化します。

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

ステップ5:セルを作成する

作成する cell オブジェクトをインスタンス化して Cell パッケージのクラス com.itextpdf.layout.element。を使用してセルの内容を追加しますadd() の方法 Cell 以下に示すように、クラス。

// 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:テーブルにセルを追加する

最後に、このセルをテーブルに追加するには、 addCell() の方法 Table クラスと合格 cell 以下に示すように、このメソッドのパラメーターとしてのオブジェクト。

table.addCell(c1);

ステップ8:ドキュメントにテーブルを追加する

追加します table 前の手順で作成されたオブジェクト add() の方法 Document 以下に示すクラス。

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

ステップ9:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してテーブル内のセルの内容をフォーマットする方法を示しています。名前の付いたPDFドキュメントを作成しますaddingBackground.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ドキュメントを見つけることができます。

この章では、iTextライブラリを使用してテーブル内のセルの境界線をフォーマットする方法を説明します。

セルの境界線のフォーマット

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

次に、ドキュメントにテーブルを追加するには、インスタンス化する必要があります Table クラスを作成し、を使用してこのオブジェクトをドキュメントに追加します add() 方法。

次のようなさまざまな種類の境界線を追加できます DashedBorder, SolidBorder, DottedBorder, DoubleBorder, RoundDotsBorder、を使用してさまざまな色でなど setBorder() の方法 Cell クラス。

以下は、テーブル内のセルの境界線をフォーマットする手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFDocumentを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

インスタンス化する PdfDocument 上記で作成したクラスを渡すことによってクラス PdfWriter 以下に示すように、コンストラクターに対するオブジェクト。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:テーブルオブジェクトを作成する

ザ・ Tableクラスは、行と列に並べられたセルで満たされた2次元グリッドを表します。パッケージに属していますcom.itextpdf.layout.element

インスタンス化する Table 以下に示すクラス。

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

ステップ5:セルを作成する

をインスタンス化してセルオブジェクトを作成します Cell パッケージのクラス com.itextpdf.layout.element を使用してセルの内容を追加します add() の方法 Cell 以下に示すように、クラス。

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

ステップ6:セルの境界線をフォーマットする

iTextライブラリは、次のような境界を表すさまざまなクラスを提供します。 DashedBorder, SolidBorder, DottedBorder, DoubleBorder, RoundDotsBorder、など。

これらのクラスのコンストラクターは、次の2つのパラメーターを受け入れます。 color 境界線の色を表すオブジェクトと integer 境界線の幅を表します。

この境界線タイプの1つを選択し、を渡すことによってそれぞれの境界線をインスタンス化します color オブジェクトと integer 以下に示すように、幅を表します。

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

次に、を使用してセルの境界を設定します setBorder() の方法 cellクラス。このメソッドは、次のタイプのオブジェクトを受け入れますBorder パラメータとして。

上記で作成したものを渡すことにより、セルの境界を設定します Border のパラメータとしてのオブジェクト setBorder() 以下に示す方法。

c1.setBorder(b1)

最後に、このセルをテーブルに追加するには、 addCell() の方法 Table クラスと合格 cell 以下に示すように、このメソッドのパラメーターとしてのオブジェクト。

table.addCell(c1);

ステップ7:ドキュメントにテーブルを追加する

追加します table 前の手順で作成されたオブジェクト add() の方法 Document 以下に示すように、クラス。

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

ステップ8:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してテーブル内のセルの境界線をフォーマットする方法を示しています。名前の付いたPDFドキュメントを作成しますcoloredBorders.pdf、テーブルを追加し、セルの内容をフォーマットして、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します 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..");     
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac FormatedBorders.java 
java FormatedBorders

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

Borders added successfully

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントのテーブルに画像を追加する方法を説明します。

テーブルへの画像の追加

をインスタンス化することにより、空のPDFドキュメントを作成できます Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocumentコンストラクターへのパラメーターとしてのオブジェクト。次に、ドキュメントにテーブルを追加するには、インスタンス化する必要がありますTable クラスを作成し、を使用してこのオブジェクトをドキュメントに追加します add() 方法。

このテーブルに画像を追加するには、インスタンス化する必要があります Cell クラス、作成、および追加する必要のある画像のオブジェクト、画像をに追加します cell を使用するオブジェクト add() の方法 Cell クラス。

以下は、テーブルのセルに画像を挿入する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriter クラスはPDFのDocWriterを表し、このクラスはパッケージに属します com.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、PDFを作成する必要があるパスを表す文字列値をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

インスタンス化する PdfDocument 以下に示すように、上記で作成したPdfWriterオブジェクトをコンストラクターに渡すことによってクラスを作成します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスのオブジェクトを受け入れますPdfDocument

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:テーブルオブジェクトを作成する

ザ・ Tableクラスは、行と列で順序付けられた、セルで満たされた2次元グリッドを表します。パッケージに属していますcom.itextpdf.layout.element

インスタンス化する Table 以下に示すクラス。

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

ステップ5:セルを作成する

作成する cell オブジェクトをインスタンス化して Cell パッケージのクラス com.itextpdf.layout、以下に示すように。

// Adding cell to the table
Cell cell = new Cell();  // Creating a cell

ステップ6:画像を作成する

を作成するには image オブジェクトは、まず第一に、作成します ImageData を使用するオブジェクト create() の方法 ImageDataFactoryクラス。このメソッドのパラメーターとして、以下に示すように、画像のパスを表す文字列パラメーターを渡します。

// Creating an ImageData object 
String imageFile = "C:/itextExamples/javafxLogo.jpg"; 
ImageData data = ImageDataFactory.create(imageFile);

今、インスタンス化します Image のクラス com.itextpdf.layout.elementパッケージ。インスタンス化中に、ImageData 以下に示すように、コンストラクターへのパラメーターとして、上で作成されたオブジェクト。

// Creating an Image object 
Image img = new Image(data);

追加します image を使用してセルにオブジェクト add() 以下に示すように、セルクラスのメソッド。

// Adding image to the cell  
cell.add(img.setAutoScale(true));

ステップ7:テーブルにセルを追加する

最後に、このセルをテーブルに追加するには、 addCell() の方法 Table クラスと合格 cell 以下に示すように、このメソッドのパラメーターとしてのオブジェクト。

table.addCell(cell);

ステップ8:ドキュメントにテーブルを追加する

追加します table 前の手順で作成されたオブジェクト add() の方法 Document 以下に示すように、クラス。

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

ステップ9:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントのテーブルのセルに画像を追加する方法を示しています。名前の付いたPDFドキュメントを作成しますaddingImage.pdf、それにテーブルを追加し、そのセルの1つに画像(javafxLogo.jpg)を挿入して、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します AddingImageToTable.java

import com.itextpdf.io.image.ImageData; 
import com.itextpdf.io.image.ImageDataFactory; 

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

import com.itextpdf.layout.Document;
import com.itextpdf.layout.element.Cell; 
import com.itextpdf.layout.element.Image; 
import com.itextpdf.layout.element.Table;  

public class a3AddingImageToTable {
   public static void main(String args[]) throws Exception {
      // Creating a PdfWriter object 
      String dest = "C:/itextExamples/addingImage.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 = {150f, 150f};
      Table table = new Table(pointColumnWidths);
      
      // Populating row 1 and adding it to the table
      Cell cell1 = new Cell();
      cell1.add("Tutorial ID");
      table.addCell(cell1);
      
      Cell cell2 = new Cell();
      cell2.add("1");
      table.addCell(cell2);
      
      // Populating row 2 and adding it to the table
      Cell cell3 = new Cell();
      cell3.add("Tutorial Title");
      table.addCell(cell3);             
      
      Cell cell4 = new Cell(); 
      cell4.add("JavaFX");  
      table.addCell(cell4);
      
      // Populating row 3 and adding it to the table
      Cell cell5 = new Cell();
      cell5.add("Tutorial Author");
      table.addCell(cell5);            
      
      Cell cell6 = new Cell();
      cell6.add("Krishna Kasyap");
      table.addCell(cell6);
      
      // Populating row 4 and adding it to the table
      Cell cell7 = new Cell();
      cell7.add("Submission date");
      table.addCell(cell7);
      
      Cell cell8 = new Cell();
      cell8.add("2016-07-06");
      table.addCell(cell8);              
      
      // Populating row 5 and adding it to the table
      Cell cell9 = new Cell();
      cell9.add("Tutorial Icon");
      table.addCell(cell9);              
      
      // Creating the cell10       
      Cell cell10 = new Cell();              
      
      // Creating an ImageData object       
      String imageFile = "C:/itextExamples/javafxLogo.jpg";       
      ImageData data = ImageDataFactory.create(imageFile);        

      // Creating the image       
      Image img = new Image(data);              

      // Adding image to the cell10       
      cell10.add(img.setAutoScale(true));        

      // Adding cell110 to the table       
      table.addCell(cell10);                         
      
      // Adding Table to document        
      doc.add(table);                  
      
      // Closing the document       
      doc.close();  
      
      System.out.println("Image added to table successfully..");     
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac AddingImageToTable.java 
java AddingImageToTable

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

Image added to table successfully..

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してネストされたテーブルをPDFドキュメントのテーブルに追加する方法を説明します。

PDFにネストされたテーブルを追加する

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocumentコンストラクターへのパラメーターとしてのオブジェクト。次に、ドキュメントにテーブルを追加するには、インスタンス化する必要がありますTable クラスを作成し、を使用してこのオブジェクトをドキュメントに追加します add() 方法。

このテーブルにテーブルを追加するには、別のテーブル(ネストされたテーブル)を作成し、それを使用してセルオブジェクトに渡す必要があります。 add() の方法 Cell クラス。

以下は、テーブルをテーブルのセルに挿入する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf. このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要があります PdfWriter そのコンストラクタに。

以下に示すように、上記で作成したPdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:テーブルオブジェクトを作成する

ザ・ Tableクラスは、行と列で順序付けられた、セルで満たされた2次元グリッドを表します。パッケージに属していますcom.itextpdf.layout.element

インスタンス化する Table 以下に示すクラス。

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

ステップ5:セルを作成する

作成する cell オブジェクトをインスタンス化して Cell パッケージのクラス com.itextpdf.layout、以下に示すように。

// Adding cell to the table 
Cell contact = new Cell();    // Creating a cell

手順6:ネストされたテーブルを作成する

作成後 cell、ネストされたテーブルを作成し、以下に示すようにそのセルにデータを入力します。

// Creating nested table for contact   
float [] pointColumnWidths2 = {150f, 150f}; 
Table nestedTable = new Table(pointColumnWidths2);    

// Populating row 1 and adding it to the nested table  
Cell nested1 = new Cell(); 
nested1.add("Phone"); 
nestedTable.addCell(nested1);       

Cell nested2 = new Cell(); 
nested2.add("9848022338"); 
nestedTable.addCell(nested2);  

// Populating row 2 and adding it to the nested table  
Cell nested3 = new Cell(); 
nested3.add("email"); 
nestedTable.addCell(nested3);

Cell nested4 = new Cell(); 
nested4.add("[email protected]"); 
nestedTable.addCell(nested4);     

// Populating row 3 and adding it to the nested table  
Cell nested5 = new Cell(); 
nested5.add("Address"); 
nestedTable.addCell(nested5);  

Cell nested6 = new Cell(); 
nested6.add("Hyderabad"); 
nestedTable.addCell(nested6);

ステップ7:ネストされたテーブルをセルに追加する

次に、上記で作成したネストされたテーブルを、を使用して親(コンテナ)テーブルのセルに追加します。 add() の方法 Cellクラス。そして、を使用してこのセルを親テーブルに追加しますaddCell() の方法 Table 以下に示すように、クラス。

contact.add(nestedTable); 
table.addCell(contact);

ステップ8:ドキュメントにテーブルを追加する

追加します table 前の手順で作成されたオブジェクト add() の方法 Document 以下に示すように、クラス。

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

ステップ9:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメント内のテーブル(ネストされたテーブル)のセルにテーブルを追加する方法を示しています。名前の付いたPDFドキュメントを作成しますaddingNestedTable.pdf、テーブルを追加し、そのセルの1つに別のテーブルを挿入して、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します AddNestedTable.java

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

import com.itextpdf.layout.Document; 
import com.itextpdf.layout.element.Cell; 
import com.itextpdf.layout.element.Table;  

public class a4AddNestedTablesPdf {  
   public static void main(String args[]) throws Exception {                        
      // Creating a PdfWriter object   
      String dest = "C:/itextExamples/addingNestedTable.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 [] pointColumnWidths1 = {150f, 150f};       
      Table table = new Table(pointColumnWidths1);                             
      
      // Populating row 1 and adding it to the table          
      Cell cell1 = new Cell();       
      cell1.add("Name");       
      table.addCell(cell1);             
      
      Cell cell2 = new Cell();       
      cell2.add("Raju");       
      table.addCell(cell2);                          
   
      // Populating row 2 and adding it to the table        
      Cell cell3 = new Cell();       
      cell3.add("Id");       
      table.addCell(cell3);             
      
      Cell cell4 = new Cell();       
      cell4.add("1001");       
      table.addCell(cell4);                    
   
      // Populating row 3 and adding it to the table        
      Cell cell5 = new Cell();       
      cell5.add("Designation");       
      table.addCell(cell5); 
      
      Cell cell6 = new Cell();       
      cell6.add("Programmer");       
      table.addCell(cell6);              
   
      // Creating nested table for contact         
      float [] pointColumnWidths2 = {150f, 150f};       
      Table nestedTable = new Table(pointColumnWidths2);                
      
      // Populating row 1 and adding it to the nested table        
      Cell nested1 = new Cell();       
      nested1.add("Phone");       
      nestedTable.addCell(nested1);                   
      
      Cell nested2 = new Cell();       
      nested2.add("9848022338");       
      nestedTable.addCell(nested2);                   
      
      // Populating row 2 and adding it to the nested table        
      Cell nested3 = new Cell();       
      nested3.add("email");       
      nestedTable.addCell(nested3);                    
      
      Cell nested4 = new Cell();       
      nested4.add("[email protected]");       
      nestedTable.addCell(nested4);                       
      
      // Populating row 3 and adding it to the nested table        
      Cell nested5 = new Cell();       
      nested5.add("Address");       
      nestedTable.addCell(nested5);                    
      
      Cell nested6 = new Cell();       
      nested6.add("Hyderabad");       
      nestedTable.addCell(nested6);              
      
      // Adding table to the cell       
      Cell cell7 = new Cell();       
      cell7.add("Contact");       
      table.addCell(cell7);              
      
      Cell cell8 = new Cell();       
      cell8.add(nestedTable);       
      table.addCell(cell8);
      
      // Adding table to the document       
      doc.add(table);                   
      
      // Closing the document               
      doc.close();  
      System.out.println("Nested Table Added successfully..");     
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac AddNestedTable.java 
java AddNestedTable

上記のプログラムを実行すると、次のメッセージを表示するPDFドキュメントが作成されます。

Nested Table Added successfully..

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントのテーブルにリストを追加する方法を説明します。

PDFのテーブルへのリストの追加

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocumentコンストラクターへのパラメーターとしてのオブジェクト。次に、ドキュメントにテーブルを追加するには、インスタンス化する必要がありますTable クラスを作成し、を使用してこのオブジェクトをドキュメントに追加します add() 方法。

追加するには list テーブルに、インスタンス化する必要があります List のクラス com.itextpdf.layout.element パッケージ化して、 cell を使用するオブジェクト add() の方法 Cell クラス。

以下は、テーブルのセルにリストを追加する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterclassは、PDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージcに属していますom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

インスタンス化する PdfDocument 以下に示すように、上記で作成したPdfWriterオブジェクトをコンストラクターに渡すことによってクラスを作成します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:テーブルオブジェクトを作成する

ザ・ Tableクラスは、行と列で順序付けられた、セルで満たされた2次元グリッドを表します。パッケージに属していますcom.itextpdf.layout.element

インスタンス化する Table 以下に示すクラス。

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

ステップ5:セルを作成する

作成する cell オブジェクトをインスタンス化して Cell パッケージのクラス com.itextpdf.layout、以下に示すように。

// Adding cell to the table 
Cell listCell = new Cell(); // Creating a cell

ステップ6:リストオブジェクトを作成する

セルを作成したら、 list オブジェクトをインスタンス化して List パッケージのクラス com.itextpdf.layout.element。をインスタンス化してリストアイテムを作成しますListItem クラスを作成し、を使用して作成したアイテムを追加します add() の方法 List 以下に示すように、クラス。

List list = new List(); 
ListItem item1 = new ListItem("JavaFX"); 
ListItem item2 = new ListItem("Java"); 
ListItem item3 = new ListItem("Java Servlets");        
list.add(item1); 
list.add(item2); 
list.add(item3);

ステップ7:テーブルのセルにリストを追加する

次に、上記で作成したリストを、を使用してテーブルのセルに追加します。 add()Cellクラスのメソッド。そして、を使用してこのセルをテーブルに追加しますaddCell() の方法 Table 以下に示すように、クラス。

listCell.add(list); 
table.addCell(listCell);

ステップ8:ドキュメントにテーブルを追加する

追加します table 前の手順で作成されたオブジェクト add() の方法 Document 以下に示すように、クラス。

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

ステップ9:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントのテーブルのセルにリストを追加する方法を示しています。名前の付いたPDFドキュメントを作成しますaddingObjects.pdf、それにテーブルを追加し、そのセルの1つにリストを挿入して、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します AddingListsToTable.java

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

import com.itextpdf.layout.Document; 
import com.itextpdf.layout.element.Cell; 
import com.itextpdf.layout.element.List; 
import com.itextpdf.layout.element.ListItem; 
import com.itextpdf.layout.element.Table; 
import com.itextpdf.layout.property.TextAlignment;  

public class AddingListsToTable {      
   public static void main(String args[]) throws Exception {              
      // Creating a PdfWriter object
      String file = "C:/itextExamples/addingObjects.pdf";       
      PdfDocument pdfDoc = new PdfDocument(new PdfWriter(file));                   
      
      // Creating a Document object       
      Document doc = new Document(pdfDoc);               
      
      // Creating a table       
      float [] pointColumnWidths = {300F, 300F};       
      Table table = new Table(pointColumnWidths);                            
      
      // Adding row 1 to the table                
      Cell c1 = new Cell();       
      c1.add("Java Related Tutorials");       
      c1.setTextAlignment(TextAlignment.LEFT);       
      table.addCell(c1);                      
      
      List list1 = new List();       
      ListItem item1 = new ListItem("JavaFX");
      ListItem item2 = new ListItem("Java");       
      ListItem item3 = new ListItem("Java Servlets");              
      list1.add(item1);       
      list1.add(item2);       
      list1.add(item3);                 
      
      Cell c2 = new Cell();       
      c2.add(list1);       
      c2.setTextAlignment(TextAlignment.LEFT);       
      table.addCell(c2);                 
      
      // Adding row 2 to the table                
      Cell c3 = new Cell();       
      c3.add("No SQL Databases");       
      c3.setTextAlignment(TextAlignment.LEFT);       
      table.addCell(c3);                     
      
      List list2 = new List();       
      list2.add(new ListItem("HBase"));       
      list2.add(new ListItem("Neo4j"));       
      list2.add(new ListItem("MongoDB"));                 
      
      Cell c4 = new Cell();       
      c4.add(list2); 
      c4.setTextAlignment(TextAlignment.LEFT);       
      table.addCell(c4);                       
      
      // Adding Table to document        
      doc.add(table);                  
      
      // Closing the document       
      doc.close();  
      System.out.println("Lists added to table successfully..");     
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac AddingListsToTable.java 
java AddingListsToTable

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

Lists added to table successfully..

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントに画像を追加する方法を説明します。

PDFへの画像の追加

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocumentコンストラクターへのパラメーターとしてのオブジェクト。PDFに画像を追加するには、追加する必要のある画像のオブジェクトを作成し、を使用して追加します。add() の方法 Document クラス。

PDFドキュメントに画像を追加する手順は次のとおりです。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、上記で作成したPdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:画像オブジェクトを作成する

を作成するには image オブジェクトは、まず第一に、作成します ImageData を使用するオブジェクト create() の方法 ImageDataFactoryクラス。このメソッドのパラメーターとして、以下に示すように、画像のパスを表す文字列パラメーターを渡します。

// Creating an ImageData object 
String imageFile = "C:/itextExamples/javafxLogo.jpg"; 
ImageData data = ImageDataFactory.create(imageFile);

今、インスタンス化します Image のクラス com.itextpdf.layout.elementパッケージ。インスタンス化中に、上記で作成したものを渡しますImageData 以下に示すように、コンストラクターへのパラメーターとしてのオブジェクト。

// Creating an Image object 
Image img = new Image(data);

ステップ5:ドキュメントに画像を追加する

前の手順で作成した画像オブジェクトを、 add() の方法 Document 以下に示すように、クラス。

// Adding image to the document 
document.add(img);

ステップ6:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントに画像を追加する方法を示しています。名前の付いたPDFドキュメントを作成しますaddingImage.pdf、それに画像を追加し、パスに保存します C:/itextExamples/

このコードを名前の付いたファイルに保存します AddingImage.java

import com.itextpdf.io.image.ImageData; 
import com.itextpdf.io.image.ImageDataFactory; 

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

import com.itextpdf.layout.Document; 
import com.itextpdf.layout.element.Image;  

public class AddingImage {      
   public static void main(String args[]) throws Exception {              
      
      // Creating a PdfWriter       
      String dest = "C:/itextExamples/addingImage.pdf";       
      PdfWriter writer = new PdfWriter(dest);        
      
      // Creating a PdfDocument       
      PdfDocument pdf = new PdfDocument(writer);              
      
      // Creating a Document        
      Document document = new Document(pdf);              
      
      // Creating an ImageData object       
      String imFile = "C:/itextExamples/logo.jpg";       
      ImageData data = ImageDataFactory.create(imFile);              
      
      // Creating an Image object        
      Image image = new Image(data);                        
      
      // Adding image to the document       
      document.add(image);              
      
      // Closing the document       
      document.close();              
      
      System.out.println("Image added");    
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac AddingImage.java 
java AddingImage

上記のプログラムを実行すると、次のメッセージを表示するPDFドキュメントが作成されます。

Image added

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメント内の画像の位置を設定する方法を説明します。

画像の位置を設定する

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

PDFに画像を追加するには、追加する必要のある画像のオブジェクトを作成し、を使用して追加します。 add() の方法 Documentクラス。この方法を使用して、ドキュメントの目的の位置に画像を挿入できますsetFixedPosition()Image クラス。

以下は、PDFドキュメント内の画像の位置を設定する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、上記で作成したPdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:画像オブジェクトを作成する

画像オブジェクトを作成するには、まず、 ImageData を使用するオブジェクト create() の方法 ImageDataFactoryクラス。このメソッドのパラメーターとして、以下に示すように、画像のパスを表す文字列パラメーターを渡します。

// Creating an ImageData object 
String imageFile = "C:/itextExamples/javafxLogo.jpg"; 
ImageData data = ImageDataFactory.create(imageFile);

今、インスタンス化します Image のクラス com.itextpdf.layout.elementパッケージ。インスタンス化中に、ImageData 以下に示すように、コンストラクターへのパラメーターとしてのオブジェクト。

// Creating an Image object 
Image img = new Image(data);

ステップ5:画像の位置を設定する

PDFドキュメント内の画像の位置は、 setFixedPosition()画像の方法。以下に示すように、この方法を使用して、画像の位置をドキュメント上の座標(100、250)に設定します。

// Setting the position of the image to the center of the page 
image.setFixedPosition(100, 250);

ステップ6:ドキュメントに画像を追加する

次に、前の手順で作成した画像オブジェクトを、 add() の方法 Document 以下に示すように、クラス。

// Adding image to the document 
document.add(img);

ステップ7:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントの目的の位置に画像を設定する方法を示しています。名前の付いたPDFドキュメントを作成しますpositionOfImage.pdf、画像を追加し、ページの中央に近づけて、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します SettingPosition.java

import com.itextpdf.io.image.ImageData; 
import com.itextpdf.io.image.ImageDataFactory; 

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

import com.itextpdf.layout.Document; 
import com.itextpdf.layout.element.Image;  

public class SettingPosition {      
   public static void main(String args[]) throws Exception {              
      // Creating a PdfWriter       
      String dest = "C:/EXAMPLES/itextExamples/3images/positionOfImage.pdf";       
      PdfWriter writer = new PdfWriter(dest);               
      
      // Creating a PdfDocument       
      PdfDocument pdfDoc = new PdfDocument(writer);              
      
      // Creating a Document        
      Document document = new Document(pdfDoc);              
      
      // Creating an ImageData object       
      String imFile = "C:/EXAMPLES/itextExamples/3images/logo.jpg";       
      ImageData data = ImageDataFactory.create(imFile);             

      // Creating an Image object        
      Image image = new Image(data);                
      
      // Setting the position of the image to the center of the page       
      image.setFixedPosition(100, 250);                  
      
      // Adding image to the document       
      document.add(image);              
      
      // Closing the document       
      document.close();
      
      System.out.println("Image added");    
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します。

javac SettingPosition.java 
java SettingPosition

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

Image added

指定したパスを確認すると、作成したPDFドキュメントが以下のように表示されます。

この章では、iTextライブラリを使用してPDFドキュメント内の画像を拡大縮小する方法を説明します。

PDF内の画像のスケーリング

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

PDFに画像を追加するには、追加する必要のある画像のオブジェクトを作成し、を使用して追加します。 add() の方法 Documentクラス。を使用して画像を拡大縮小できますsetAutoScale() 方法。

以下は、PDFドキュメントに存在する画像を拡大縮小する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

インスタンス化する PdfDocument 以下に示すように、上記で作成したPdfWriterオブジェクトをコンストラクターに渡すことによってクラスを作成します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:画像オブジェクトを作成する

画像オブジェクトを作成するには、まず、 ImageData を使用するオブジェクト create() の方法 ImageDataFactoryクラス。このメソッドのパラメーターとして、以下に示すように、画像のパスを表す文字列パラメーターを渡します。

// Creating an ImageData object 
String imageFile = "C:/itextExamples/javafxLogo.jpg"; 
ImageData data = ImageDataFactory.create(imageFile);

今、インスタンス化します Image のクラス com.itextpdf.layout.elementパッケージ。インスタンス化中に、ImageData 以下に示すように、コンストラクターへのパラメーターとしてのオブジェクト。

// Creating an Image object 
Image img = new Image(data);

ステップ5:画像のスケーリング

を使用して画像を拡大縮小できます setAutoScale() 方法。

// Setting the position of the image to the center of the page 
image.setFixedPosition(100, 250);

ステップ6:ドキュメントに画像を追加する

ここで、 image 前の手順で作成されたオブジェクト add() の方法 Document 以下に示すように、クラス。

// Adding image to the document 
document.add(img);

ステップ7:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントのドキュメントサイズに応じて画像を拡大縮小する方法を示しています。名前の付いたPDFドキュメントを作成しますautoScale.pdf、画像を追加し、ページのサイズに応じて拡大縮小し、パスに保存します C:/itextExamples/

このコードを名前の付いたファイルに保存します SettingAutoScale.java

import com.itextpdf.io.image.ImageData; 
import com.itextpdf.io.image.ImageDataFactory; 

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

import com.itextpdf.layout.Document; 
import com.itextpdf.layout.element.Image;  

public class SettingAutoScale {      
   public static void main(String args[]) throws Exception{              
      // Creating a PdfWriter       
      String dest = "C:/itextExamples/positionOfImage.pdf";       
      PdfWriter writer = new PdfWriter(dest);               
      
      // Creating a PdfDocument       
      PdfDocument pdfDoc = new PdfDocument(writer);              
      
      // Creating a Document        
      Document document = new Document(pdfDoc);              
      
      // Creating an ImageData object       
      String imFile = "C:/itextExamples/logo.jpg";       
      ImageData data = ImageDataFactory.create(imFile);              
      
      // Creating an Image object        
      Image image = new Image(data);                
      
      // Setting the position of the image to the center of the page       
      image.setFixedPosition(100,250); 
      
      // Adding image to the document       
      document.add(image);              
      
      // Closing the document       
      document.close();
      System.out.println("Image Scaled");    
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します。

javac SettingAutoScale.java 
java SettingAutoScale

上記のプログラムを実行すると、次のメッセージを表示するPDFドキュメントが作成されます。

Image Scaled

指定したパスを確認すると、作成したPDFドキュメントが以下のように表示されます。

この章では、iTextライブラリで使用可能な関数を使用して、PDFドキュメントに画像を挿入する方法とその画像を回転させる方法について説明します。

PDF内の画像の回転

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

PDFに画像を追加するには、追加する必要のある画像のオブジェクトを作成し、を使用して追加します。 add() の方法 Documentクラス。を使用して画像を回転させることができますsetRotationAngle() 方法。

以下は、PDFドキュメント内の画像を回転させる手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、PdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:画像オブジェクトを作成する

画像オブジェクトを作成するには、まず、 ImageData を使用するオブジェクト create()の方法 ImageDataFactoryクラス。このメソッドのパラメーターとして、以下に示すように、画像のパスを表す文字列パラメーターを渡します。

// Creating an ImageData object 
String imageFile = "C:/itextExamples/javafxLogo.jpg"; 
ImageData data = ImageDataFactory.create(imageFile);

今、インスタンス化します Image のクラス com.itextpdf.layout.elementパッケージ。インスタンス化中に、ImageData object、以下に示すように、コンストラクターへのパラメーターとして。

// Creating an Image object 
Image img = new Image(data);

ステップ5:画像を回転させる

を使用して画像を回転させることができます setRotationAngle()方法。この方法では、画像を回転させる回転角を表す整数を渡す必要があります。

// Rotating the image 
image.setRotationAngle(45);

ステップ6:ドキュメントに画像を追加する

ここで、前の手順で作成した画像オブジェクトを、 add() の方法 Document 以下に示すように、クラス。

// Adding image to the document 
document.add(img);

ステップ7:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメント上で画像を特定の角度で回転させる方法を示しています。

名前の付いたPDFドキュメントを作成します rotatingImage.pdf、画像を追加し、回転させて、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します RotatingImage.java

import com.itextpdf.io.image.ImageData; 
import com.itextpdf.io.image.ImageDataFactory; 

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

import com.itextpdf.layout.Document; 
import com.itextpdf.layout.element.Image;  

public class RotatingImage {    
   public static void main(String args[]) throws Exception {              
      // Creating a PdfWriter       
      String dest = "C:/itextExamples/rotatingImage.pdf";       
      PdfWriter writer = new PdfWriter(dest);               
      
      // Creating a PdfDocument       
      PdfDocument pdfDoc = new PdfDocument(writer);              
      
      // Creating a Document        
      Document document = new Document(pdfDoc);              
      
      // Creating an ImageData object       
      String imFile = "C:/itextExamples/logo.jpg";       
      ImageData data = ImageDataFactory.create(imFile);              
      
      // Creating an Image object        
      Image image = new Image(data);                
      
      // Rotating the image       
      image.setRotationAngle(45);                       
      
      // Adding image to the document       
      document.add(image);              
      
      // Closing the document       
      document.close(); 
      
      System.out.println("Image rotated");    
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac RotatingImage.java 
java RotatingImage

上記のプログラムを実行すると、次のメッセージを表示するPDFドキュメントが作成されます。

Image Rotated

指定したパスを確認すると、作成したPDFドキュメントが以下のように表示されます。

この章では、iTextライブラリを使用してPDFドキュメントにテキスト注釈を追加する方法を説明します。

PDFでのテキスト注釈の作成

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

PDFドキュメントでテキスト注釈を使用するには、次のオブジェクトを作成する必要があります。 PdfTextAnnotation クラスにこれを追加します PdfPage

以下は、PDFドキュメントでテキスト注釈を使用する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

インスタンス化する PdfDocument を渡すことによってクラス PdfWriter 以下に示すように、コンストラクターに対するオブジェクト。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスのオブジェクトを受け入れますPdfDocument

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:PdfAnnotationオブジェクトを作成する

ザ・ PdfAnnotation パッケージのクラス com.itextpdf.kernel.pdf.annot すべての注釈のスーパークラスを表します。

その派生クラスの中で、 PdfTextAnnotationクラスはテキスト注釈を表します。以下に示すように、このクラスのオブジェクトを作成します。

// Creating PdfAnnotation 
Rectangle rect = new Rectangle(20, 800, 0, 0); 
PdfAnnotation ann = new PdfTextAnnotation(rect);

ステップ5:注釈の色を設定する

を使用して注釈に色を設定します setColor() の方法 PdfAnnotationクラス。このメソッドに、color 注釈の色をパラメータとして表すオブジェクト。

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

ステップ6:注釈のタイトルと内容を設定する

を使用して注釈のタイトルと内容を設定します setTitle() そして setContents() の方法 PdfAnnotation 以下に示すように、それぞれクラス。

// Setting title to the annotation 
ann.setTitle(new PdfString("Hello"));        

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

ステップ7:ページに注釈を追加する

新しいを作成します PdfPage を使用するクラス addNewPage() PdfDocumentクラスのメソッドを使用し、 addAnnotation() の方法 PdfPage 以下に示すように、クラス。

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

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

ステップ8:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントにテキスト注釈を追加する方法を示しています。名前の付いたPDFドキュメントを作成しますtextAnnotation.pdf、それにテキスト注釈を追加し、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します TextAnnotation.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.PdfTextAnnotation; 
import com.itextpdf.layout.Document;  

public class TextAnnotation {    
   public static void main(String args[]) throws Exception {        
      // Creating a PdfWriter       
      String dest = "C:/itextExamples/textAnnotation.pdf";       
      PdfWriter writer = new PdfWriter(dest);               
      
      // Creating a PdfDocument       
      PdfDocument pdf = new PdfDocument(writer);               
      
      // Creating a Document        
      Document document = new Document(pdf);             
      
      // Creating PdfTextAnnotation object
      Rectangle rect = new Rectangle(20, 800, 0, 0);       
      PdfAnnotation ann = new PdfTextAnnotation(rect);              
      
      // Setting color to the annotation
      ann.setColor(Color.GREEN);              
      
      // Setting title to the annotation 
      ann.setTitle(new PdfString("Hello"));              
      
      // Setting contents of the annotation       
      ann.setContents("Hi welcome to Tutorialspoint.");              
      
      // Creating a new page       
      PdfPage page =  pdf.addNewPage();              
      
      // Adding annotation to a page in a PDF
      page.addAnnotation(ann);

      // Closing the document       
      document.close();       
      
      System.out.println("Annotation added successfully");    
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します。

javac TextAnnotation.java 
java TextAnnotation

上記のプログラムを実行すると、次のメッセージを表示するPDFドキュメントが作成されます。

Annotation added successfully

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントにリンク注釈を追加する方法を説明します。

PDFでのリンク注釈の作成

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

PDFドキュメントでテキスト注釈を使用するには、PdfTextAnnotationクラスのオブジェクトを作成し、これをPdfPageに追加する必要があります。

PDFドキュメントでテキスト注釈を使用する手順は次のとおりです。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

インスタンス化する PdfWriter 以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことによってクラスを作成します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

を渡すことにより、PdfDocumentクラスをインスタンス化します PdfWriter 以下に示すように、コンストラクターに対するオブジェクト。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスのオブジェクトを受け入れますPdfDocument

インスタンス化する Document 以下に示すように、前の手順で作成したクラスPdfDocumentのオブジェクトを渡すことによってクラスを作成します。

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

ステップ4:PdfAnnotationオブジェクトを作成する

ザ・ PdfAnnotation パッケージのクラス com.itextpdf.kernel.pdf.annot すべての注釈のスーパークラスを表します。

その派生クラスの中で、 PdfLinkAnnotationクラスはリンク注釈を表します。以下に示すように、このクラスのオブジェクトを作成します。

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

ステップ5:アノテーションのアクションを設定する

を使用してアノテーションにアクションを設定します setAction() の方法 PdfLinkAnnotation 以下に示すように、クラス。

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

ステップ6:リンクを作成する

をインスタンス化してリンクを作成します Link パッケージのクラス com.itextpdf.layout.element、以下に示すように。

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

ステップ7:段落にリンク注釈を追加する

をインスタンス化して新しい段落を作成します Paragraph クラスを作成し、前の手順で作成したリンクを add() 以下に示すように、このクラスのメソッド。

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

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

ステップ8:ドキュメントに段落を追加する

を使用して段落をドキュメントに追加します add() の方法 Document 以下に示すように、クラス。

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

ステップ9:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントにリンク注釈を追加する方法を示しています。

名前の付いたPDFドキュメントを作成します linkAnnotation.pdf、それにリンク注釈を追加し、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します 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");    
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac LinkAnnotation.java 
java LinkAnnotation

上記のプログラムを実行すると、次のメッセージを表示するPDFドキュメントが作成されます。

Annotation added successfully

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントに行注釈を追加する方法を説明します。

PDFでのライン注釈の作成

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

PDFドキュメントでテキスト注釈を使用するには、次のオブジェクトを作成する必要があります。 PdfTextAnnotation クラスにこれを追加します PdfPage

以下は、PDFドキュメントでテキスト注釈を使用する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、PDFを作成する必要があるパスを表す文字列値をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFDocumentを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、PdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスのオブジェクトを受け入れますPdfDocument

クラスのオブジェクトを渡すことにより、Documentクラスをインスタンス化します PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:PdfAnnotationオブジェクトを作成する

ザ・ PdfAnnotation パッケージのクラス com.itextpdf.kernel.pdf.annot は、すべての注釈のスーパークラスです。

その派生クラスの中で、 PdfLineAnnotationクラスは行の注釈を表します。以下に示すように、このクラスのオブジェクトを作成します。

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

ステップ5:注釈の色を設定する

を使用して注釈に色を設定します setColor() の方法 PdfAnnotationクラス。このメソッドに、注釈の色を表す色オブジェクトをパラメーターとして渡します。

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

ステップ6:注釈のタイトルと内容を設定する

を使用して注釈のタイトルと内容を設定します setTitle() そして setContents() の方法 PdfAnnotation 以下に示すように、それぞれクラス。

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

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

ステップ7:ページに注釈を追加する

新しいを作成します PdfPage を使用するクラス addNewPage() の方法 PdfDocument 以下に示すように、クラスを作成し、PdfPageクラスのaddAnnotation()メソッドを使用して上記で作成したアノテーションを追加します。

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

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

ステップ8:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントに行注釈を追加する方法を示しています。名前の付いたPDFドキュメントを作成しますlineAnnotation.pdf、それに行注釈を追加し、パスに保存します C:/itextExamples/

このコードを名前の付いたファイルに保存します 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");   
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac LineAnnotation.java 
java LineAnnotation

上記のプログラムを実行すると、次のメッセージを表示するPDFドキュメントが作成されます。

Annotation added successfully

指定したパスを確認すると、作成したPDFドキュメントが以下のように表示されます。

この章では、iTextライブラリを使用してPDFドキュメントにテキストマークアップ注釈を追加する方法を説明します。

PDFでのマークアップ注釈の作成

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocumentコンストラクターへのパラメーターとしてのオブジェクト。PDFドキュメントでテキスト注釈を使用するには、次のオブジェクトを作成する必要があります。PdfTextAnnotation クラスにこれを追加します PdfPage

以下は、PDFドキュメントでテキスト注釈を使用する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、PdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスのオブジェクトを受け入れますPdfDocument

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:PdfAnnotationオブジェクトを作成する

ザ・ PdfAnnotation パッケージのクラス com.itextpdf.kernel.pdf.annot すべての注釈のスーパークラスを表します。

その派生クラスの中で、 PdfTextMarkupAnnotationクラスは、テキストマークアップ注釈を表します。以下に示すように、このクラスのオブジェクトを作成します。

// Creating a PdfTextMarkupAnnotation object 
Rectangle rect = new Rectangle(105, 790, 64, 10); 
float[] floatArray = new float[]{169, 790, 105, 790, 169, 800, 105, 800};
PdfAnnotation annotation = PdfTextMarkupAnnotation.createHighLight(rect,floatArray);

ステップ5:注釈の色を設定する

を使用して注釈に色を設定します setColor() の方法 PdfAnnotationクラス。このメソッドに、を表すカラーオブジェクトを渡しますcolor パラメータとしての注釈の。

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

ステップ6:注釈のタイトルと内容を設定する

を使用して注釈のタイトルと内容を設定します setTitle() そして setContents() の方法 PdfAnnotation それぞれクラス。

// Setting title to the annotation 
annotation.setTitle(new PdfString("Hello!"));        

// Setting contents to the annotation 
annotation.setContents(new PdfString("Hi welcome to Tutorialspoint"));

ステップ7:ページに注釈を追加する

新しいを作成します PdfPage を使用するクラス addNewPage() の方法 PdfDocument クラスを作成し、上記で作成したアノテーションを使用して追加します addAnnotation() 以下に示すように、PdfPageクラスのメソッド。

// Creating a new Pdfpage 
PdfPage pdfPage = pdfDoc.addNewPage();        

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

ステップ8:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントにテキストマークアップ注釈を追加する方法を示しています。名前の付いたPDFドキュメントを作成しますmarkupAnnotation.pdf、テキストマークアップ注釈を追加し、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します MarkupAnnotation.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.PdfTextMarkupAnnotation;
import com.itextpdf.layout.Document;  

public class MarkupAnnotation {    
   public static void main(String args[]) throws Exception {   
      // Creating a PdfDocument object       
      String file = "C:/itextExamples/markupAnnotation.pdf";        
      PdfDocument pdfDoc = new PdfDocument(new PdfWriter(file));                   
   
      // Creating a Document object       
      Document doc = new Document(pdfDoc);                      
      
      // Creating a PdfTextMarkupAnnotation object       
      Rectangle rect = new Rectangle(105, 790, 64, 10);       
      float[] floatArray = new float[]{169, 790, 105, 790, 169, 800, 105, 800};
      PdfAnnotation annotation = 
         PdfTextMarkupAnnotation.createHighLight(rect,floatArray);
      
      // Setting color to the annotation       
      annotation.setColor(Color.YELLOW);              
      
      // Setting title to the annotation       
      annotation.setTitle(new PdfString("Hello!"));
      
      // Setting contents to the annotation       
      annotation.setContents(new PdfString("Hi welcome to Tutorialspoint"));
      
      // Creating a new Pdfpage
      PdfPage pdfPage = pdfDoc.addNewPage();
      
      // Adding annotation to a page in a PDF       
      pdfPage.addAnnotation(annotation);
      
      // Closing the document
      doc.close();  
      
      System.out.println("Annotation added successfully");       
   }     
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac MarkupAnnotation.java 
java MarkupAnnotation

上記のプログラムを実行すると、次のメッセージを表示するPDFドキュメントが作成されます。

Annotation added successfully

指定したパスを確認すると、作成したPDFドキュメントが以下のように表示されます。

この章では、iTextライブラリを使用してPDFドキュメントに円の注釈を追加する方法を説明します。

PDFでの円注釈の作成

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

PDFドキュメントでテキスト注釈を使用するには、PdfTextAnnotationクラスのオブジェクトを作成し、これをに追加する必要があります。 Pdfpage

以下は、PDFドキュメントでテキスト注釈を使用する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

インスタンス化する PdfWriter 以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことによってクラスを作成します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、PdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:PdfAnnotationオブジェクトを作成する

ザ・ PdfAnnotation パッケージのクラス com.itextpdf.kernel.pdf.annot すべての注釈のスーパークラスを表します。

その派生クラスの中で、 PdfCircleAnnotationクラスは円の注釈を表します。以下に示すように、このクラスのオブジェクトを作成します。

// Creating a PdfCircleAnnotation object Rectangle 
rect = new Rectangle(150, 770, 50, 50); 
PdfAnnotation annotation = new PdfCircleAnnotation(rect);

ステップ5:注釈の色を設定する

を使用して注釈に色を設定します setColor() の方法 PdfAnnotationクラス。このメソッドに、注釈の色を表す色オブジェクトをパラメーターとして渡します。

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

ステップ6:注釈のタイトルと内容を設定する

を使用して注釈のタイトルと内容を設定します setTitle() そして setContents() の方法 PdfAnnotation それぞれクラス。

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

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

ステップ7:ページに注釈を追加する

新しいを作成します PdfPage を使用するクラス addNewPage() の方法 PdfDocument クラスを作成し、上記で作成したアノテーションを使用して追加します addAnnotation() 以下に示すように、PdfPageクラスのメソッド。

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

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

ステップ8:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントに円の注釈を追加する方法を示しています。名前の付いたPDFドキュメントを作成しますcircleAnnotation.pdf、それに円の注釈を追加し、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します PdfCircleAnnotation.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.PdfCircleAnnotation; 
import com.itextpdf.layout.Document;  

public class CircleAnnotation {    
   public static void main(String args[]) throws Exception {   
      // Creating a PdfDocument object       
      String file = "C:/itextExamples// circleAnnotation.pdf";             
      PdfDocument pdf = new PdfDocument(new PdfWriter(file));                   
   
      // Creating a Document object       
      Document doc = new Document(pdf);                      
   
      // Creating a PdfCircleAnnotation object       
      Rectangle rect = new Rectangle(150, 770, 50, 50);       
      PdfAnnotation annotation = new PdfCircleAnnotation(rect);              
   
      // Setting color to the annotation       
      annotation.setColor(Color.YELLOW);              
   
      // Setting title to the annotation       
      annotation.setTitle(new PdfString("circle annotation"));              
   
      // Setting contents of the annotation 
      annotation.setContents(new PdfString("Hi welcome to Tutorialspoint"));             
      
      // Creating a new page        
      PdfPage page = pdf.addNewPage();              
      
      // Adding annotation to a page in a PDF       
      page.addAnnotation(annotation);                       
      
      // Closing the document       
      doc.close();  
      
      System.out.println("Annotation added successfully");       
   }   
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac PdfCircleAnnotation.java 
java PdfCircleAnnotation

上記のプログラムを実行すると、次のメッセージを表示するPDFドキュメントが作成されます。

Annotation added successfully

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントに円弧を描く方法を説明します。

PDFに円弧を描く

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

PdfDocumentに円弧を描くには、 PdfCanvas パッケージのクラス com.itextpdf.kernel.pdf.canvasとを使用して円弧を作成します arc() このクラスのメソッド。

以下は、PDFドキュメントに円弧を描く手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、PdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:PdfCanvasオブジェクトを作成する

新しいを作成します PdfPage を使用するクラス addNewPage() の方法 PdfDocument クラス。

インスタンス化する PdfCanvas パッケージのオブジェクト com.itextpdf.kernel.pdf.canvas 上記で作成したものを渡すことによって PdfPage 以下に示すように、このクラスのコンストラクターに対するオブジェクト。

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

// Creating a PdfCanvas object 
PdfCanvas canvas = new PdfCanvas(pdfPage);

ステップ5:円弧を描く

を使用して円弧を描きます arc() の方法 Canvas クラスを使用して、 fill() 以下に示すように、メソッド。

// Drawing an arc 
canvas.arc(50, 50, 300, 545, 0, 360);   

// Filling the arc 
canvas.fill();

ステップ6:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントに円弧を描画する方法を示しています。

名前の付いたPDFドキュメントを作成します drawingArc.pdf、その中に円弧を描き、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します DrawingArc.java

import com.itextpdf.kernel.color.Color; 
import com.itextpdf.kernel.pdf.PdfDocument; 
import com.itextpdf.kernel.pdf.PdfPage; 
import com.itextpdf.kernel.pdf.PdfWriter; 
import com.itextpdf.kernel.pdf.canvas.PdfCanvas; 
import com.itextpdf.layout.Document;  

public class DrawingArc {
   public static void main(String args[]) throws Exception {
      // Creating a PdfWriter
      String dest = "C:/itextExamples/drawingArc.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 new page
      PdfPage pdfPage = pdfDoc.addNewPage();

      // Creating a PdfCanvas object
      PdfCanvas canvas = new PdfCanvas(pdfPage);

      // Drawing an arc
      canvas.arc(50, 50, 300, 545, 0, 360);

      // Filling the arc
      canvas.fill();              

      // Closing the document
      doc.close();
      
      System.out.println("Object drawn on pdf successfully");       
   }     
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac DrawingArc.java 
java DrawingArc

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

Object drawn on pdf successfully

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントに線を引く方法を説明します。

PDFに線を引く

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

PdfDocumentに線を引くには、 PdfCanvas パッケージのクラス com.itextpdf.kernel.pdf.canvas を使用して線を作成します moveTo() そして lineTO() このクラスのメソッド。

以下は、PDFドキュメントに線を引く手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、上記で作成したPdfWriterオブジェクトをコンストラクターに渡すことにより、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:PdfCanvasオブジェクトを作成する

新しいを作成します PdfPage を使用するクラス addNewPage() の方法 PdfDocument クラス。

インスタンス化する PdfCanvas パッケージのオブジェクト com.itextpdf.kernel.pdf.canvas 上記で作成したものを渡すことによって PdfPage 以下に示すように、このクラスのコンストラクターに対するオブジェクト。

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

// Creating a PdfCanvas object 
PdfCanvas canvas = new PdfCanvas(pdfPage);

ステップ5:線を引く

を使用して線の始点を設定します moveTO() の方法 Canvas 以下に示すように、クラス。

// Initial point of the line 
canvas.moveTo(100, 300);

次に、このポイントから別のポイントに線を引きます。 lineTo() 以下に示すように、メソッド。

// Drawing the line 
canvas.lineTo(500, 300);

ステップ6:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントに線を引く方法を示しています。名前の付いたPDFドキュメントを作成しますdrawingLine.pdf、その中に円弧を描き、パスに保存します C:/itextExamples/

このコードを名前の付いたファイルに保存します DrawingLine.java

import com.itextpdf.kernel.pdf.PdfDocument; 
import com.itextpdf.kernel.pdf.PdfPage; 
import com.itextpdf.kernel.pdf.PdfWriter; 
import com.itextpdf.kernel.pdf.canvas.PdfCanvas; 
import com.itextpdf.layout.Document;  

public class DrawingLine {     
   public static void main(String args[]) throws Exception {            
      // Creating a PdfWriter       
      String dest = "C:/itextExamples/drawingLine.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 new page       
      PdfPage pdfPage = pdfDoc.addNewPage();               
      
      // Creating a PdfCanvas object       
      PdfCanvas canvas = new PdfCanvas(pdfPage);              
      
      // Initial point of the line       
      canvas.moveTo(100, 300);              
      
      // Drawing the line       
      canvas.lineTo(500, 300);           
      
      // Closing the path stroke       
      canvas.closePathStroke();              
      
      // Closing the document       
      doc.close();  
      
      System.out.println("Object drawn on pdf successfully");             
   }     
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac DrawingLine.java 
java DrawingLine

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

Object drawn on pdf successfully

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントに円を描く方法を説明します。

PDFに円を描く

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

PdfDocumentに円を描くには、 PdfCanvas パッケージのクラス com.itextpdf.kernel.pdf.canvasを呼び出して circle() このクラスのメソッド。

以下は、PDFドキュメントに円を描く手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、PdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:PdfCanvasオブジェクトを作成する

新しいを作成します PdfPage を使用するクラス addNewPage() の方法 PdfDocumentクラス。インスタンス化するPdfCanvas パッケージのオブジェクト com.itextpdf.kernel.pdf.canvas を渡すことによって PdfPage 以下に示すように、このクラスのコンストラクターに対するオブジェクト。

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

// Creating a PdfCanvas object 
PdfCanvas canvas = new PdfCanvas(pdfPage);

ステップ5色を設定する

を使用して円の色を設定します setColor() の方法 Canvas 以下に示すように、クラス。

// Setting color to the circle 
Color color = Color.GREEN; 
canvas.setColor(color, true);

ステップ6:円を描く

を呼び出して円を描く circle() の方法 Canvas、以下に示すように。

// creating a circle 
canvas.circle(300, 400, 200);

ステップ7:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFドキュメントに円を描く方法を示しています。名前の付いたPDFドキュメントを作成しますdrawingCircle.pdf、その中に円を描き、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します DrawingCircle.java

import com.itextpdf.kernel.color.Color; 
import com.itextpdf.kernel.pdf.PdfDocument; 
import com.itextpdf.kernel.pdf.PdfPage; 
import com.itextpdf.kernel.pdf.PdfWriter; 
import com.itextpdf.kernel.pdf.canvas.PdfCanvas; 
import com.itextpdf.layout.Document;  

public class DrawingCircle {      
   public static void main(String args[]) throws Exception {           
      // Creating a PdfWriter       
      String dest = "C:/itextExamples/drawingCircle.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 new page
      PdfPage pdfPage = pdfDoc.addNewPage();
      
      // Creating a PdfCanvas object
      PdfCanvas canvas = new PdfCanvas(pdfPage);  
      
      // Setting color to the circle
      Color color = Color.GREEN;       
      canvas.setColor(color, true);              
      
      // creating a circle
      canvas.circle(300, 400, 200);
      
      // Filling the circle       
      canvas.fill();             
      
      // Closing the document 
      doc.close();  
      
      System.out.println("Object drawn on pdf successfully");
   }     
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します。

javac DrawingCircle.java 
java DrawingCircle

上記のプログラムを実行すると、次のメッセージを表示するPDFドキュメントが作成されます。

Object drawn on pdf successfully

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントのテキストに色とフォントを設定する方法を説明します。

PDFでのテキストのフォントの設定

をインスタンス化することにより、空のPDFドキュメントを作成できます。 Documentクラス。このクラスをインスタンス化するときに、合格する必要がありますPdfDocument コンストラクターへのパラメーターとしてのオブジェクト。

ドキュメントに段落を追加するには、インスタンス化する必要があります Paragraph クラスを作成し、を使用してこのオブジェクトをドキュメントに追加します add()方法。メソッドを使用して、テキストに色とフォントを設定できますsetFontColor() そして setFont() それぞれ。

以下は、PDFドキュメントのテキストに色とフォントを設定する手順です。

ステップ1:PdfWriterオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

このタイプのオブジェクトがPdfDocument(クラス)に渡されると、このドキュメントに追加されたすべての要素が指定されたファイルに書き込まれます。

ステップ2:PdfDocumentを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

以下に示すように、PdfWriterオブジェクトをコンストラクターに渡して、PdfDocumentクラスをインスタンス化します。

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

PdfDocumentオブジェクトが作成されると、そのクラスによって提供されるそれぞれのメソッドを使用して、ページ、フォント、添付ファイル、イベントハンドラーなどのさまざまな要素を追加できます。

ステップ3:Documentクラスを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

クラスのオブジェクトを渡すことにより、Documentクラスをインスタンス化します PdfDocument 以下に示すように、前の手順で作成しました。

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

ステップ4:テキストを作成する

インスタンス化してテキストを作成します Text パッケージのクラス com.itextpdf.layout.element 以下に示すように。

// Creating text object 
Text text = new Text("Tutorialspoint");

ステップ5:フォントと色をテキストに設定する

を作成します PdfFont を使用するオブジェクト createFont() クラスのメソッド PdfFontFactory パッケージの com.itextpdf.kernel.font 以下に示すように

// Setting font of the text PdfFont 
font = PdfFontFactory.createFont(FontConstants.HELVETICA_BOLD);

次に、を使用してフォントをテキストに設定します setFont() の方法 Textこのメソッドのクラス。合格PdfFont 以下に示すように、パラメータとしてのオブジェクト。

text1.setFont(font);

テキストに色を設定するには、 setFontColor() 以下に示すように、Textクラスのメソッド。

// Setting font color 
text.setFontColor(Color.GREEN);

ステップ6:段落にテキストを追加する

作成する Paragraph クラスオブジェクトを使用して、上記で作成したテキストを追加します。 add() 以下に示すように、メソッド。

// Creating Paragraph 
Paragraph paragraph = new Paragraph();  

// Adding text to the paragraph 
paragraph.add(text);

ステップ7:ドキュメントに段落を追加する

を使用して段落をドキュメントに追加します add() の方法 Document 以下に示すように、クラス。

doc.add(paragraph1)

ステップ8:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFのテキストに色とフォントを設定する方法を示しています。名前の付いたPDFドキュメントを作成しますfonts.pdf、テキストをフォーマットし、パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します FormatingTheText.java

import com.itextpdf.io.font.FontConstants; 
import com.itextpdf.kernel.color.Color; 
import com.itextpdf.kernel.font.PdfFontFactory; 
import com.itextpdf.kernel.font.PdfFont; 
import com.itextpdf.kernel.pdf.PdfDocument; 
import com.itextpdf.kernel.pdf.PdfWriter; 

import com.itextpdf.layout.Document; 
import com.itextpdf.layout.element.Paragraph; 
import com.itextpdf.layout.element.Text;  

public class FormatingTheText {     
   public static void main(String args[]) throws Exception {        
      // Creating a PdfWriter object   
      String dest = "C:/itextExamples/fonts.pdf";   
      PdfWriter writer = new PdfWriter(dest);             
   
      // Creating a PdfDocument object      
      PdfDocument pdf = new PdfDocument(writer);                   
   
      // Creating a Document object       
      Document doc = new Document(pdf);
   
      // Creating text object       
      Text text1 = new Text("Tutorialspoint");              
   
      // Setting font of the text       
      PdfFont font = PdfFontFactory.createFont(FontConstants.HELVETICA_BOLD);       
      text1.setFont(font);                 
   
      // Setting font color
      text1.setFontColor(Color.GREEN);
   
      // Creating text object
      Text text2 = new Text("Simply Easy Learning");
      text2.setFont(PdfFontFactory.createFont(FontConstants.HELVETICA));         
      
      // Setting font color
      text2.setFontColor(Color.BLUE);
      
      // Creating Paragraph
      Paragraph paragraph1 = new Paragraph();
      
      // Adding text1 to the paragraph
      paragraph1.add(text1);
      paragraph1.add(text2);
      
      // Adding paragraphs to the document
      doc.add(paragraph1);
      doc.close();       
      
      System.out.println("Text added to pdf ..");   
   }     
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac FormatingTheText.java 
java FormatingTheText

上記のプログラムを実行すると、次のメッセージを表示するPDFドキュメントが作成されます。

Text added to pdf ..

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。

この章では、iTextライブラリを使用してPDFドキュメントの画像を拡大縮小する方法を説明します。

PDFのコンテンツを縮小する

以下は、iTextライブラリを使用してPDFページのコンテンツを縮小する手順です。

ステップ1:PdfWriterおよびPdfReaderオブジェクトを作成する

ザ・ PdfWriterクラスはPDFのDocWriterを表します。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスのコンストラクターは、PDFが作成されるファイルのパスを表す文字列を受け入れます。

以下に示すように、文字列値(PDFを作成する必要があるパスを表す)をコンストラクターに渡すことにより、PdfWriterクラスをインスタンス化します。

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

既存のPDFからデータを読み取るには、 PdfReader 以下に示すオブジェクト。

// Creating a PdfReader 
String src = "C:/itextExamples/pdfWithImage.pdf"; 
PdfReader reader = new PdfReader(src);

ステップ2:PdfDocumentオブジェクトを作成する

ザ・ PdfDocumentclassは、iTextでPDFドキュメントを表すクラスです。このクラスはパッケージに属していますcom.itextpdf.kernel.pdf。このクラスを(書き込みモードで)インスタンス化するには、クラスのオブジェクトを渡す必要がありますPdfWriter そのコンストラクタに。

を渡すことにより、ソースと宛先のPDFドキュメントを作成します PdfWriter そして PdfReader 以下に示すように、コンストラクターへのオブジェクト。

// Creating a PdfDocument objects 
PdfDocument destpdf = new PdfDocument(writer);         
PdfDocument srcPdf = new PdfDocument(reader);

ステップ3:既存のPDFからページを開く

を使用してソースPDFからページを取得します getPage() の方法 PdfPageクラス。このオブジェクトを使用して、以下に示すように、ソースドキュメントのページのサイズを取得します。

// Opening a page from the existing PDF 
PdfPage origPage = srcPdf.getPage(1);       

// Getting the page size 
Rectangle orig = origPage.getPageSizeWithRotation();

ステップ4:ソースPDFのコンテンツを縮小する

を使用して getScaleInstance() の方法 AffineTransform クラスでは、以下に示すように、ソースドキュメントのページのコンテンツを縮小します。

// Shrink original page content using transformation matrix 
AffineTransform transformationMatrix = AffineTransform.getScaleInstance(    
   page.getPageSize().getWidth()/ orig.getWidth()/2,    
   page.getPageSize().getHeight()/ orig.getHeight()/2);

ステップ5:ページをコピーする

連結する affine transform matrix、前のステップで作成された、 canvas 以下に示すように、宛先PDFドキュメントのオブジェクト。

// Concatenating the affine transform matrix to the current matrix 
PdfCanvas canvas = new PdfCanvas(page);       
canvas.concatMatrix(transformationMatrix);

次に、ページのコピーをに追加します canvas 以下に示すように、ソースドキュメントへの宛先PDFのオブジェクト。

// Add the object to the canvas 
PdfFormXObject pageCopy = origPage.copyAsFormXObject(destpdf); 
canvas.addXObject(pageCopy, 0, 0);

手順6:Documentオブジェクトを作成する

ザ・ Document パッケージのクラス com.itextpdf.layoutは、自給自足のPDFを作成する際のルート要素です。このクラスのコンストラクターの1つは、クラスPdfDocumentのオブジェクトを受け入れます。

インスタンス化する Document クラスのオブジェクトを渡すことによるクラス PdfDocument、以下に示すように。

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

ステップ7:ドキュメントを閉じる

を使用してドキュメントを閉じます close() の方法 Document 以下に示すように、クラス。

// Closing the document 
document.close();

次のJavaプログラムは、iTextライブラリを使用してPDFページのコンテンツを縮小する方法を示しています。名前の付いたPDFドキュメントを作成しますshrinkingPDF.pdf、PDF内の画像を縮小し、パスに保存します C:/itextExamples/

このコードを名前の付いたファイルに保存します ShrinkingPDF.java

import com.itextpdf.kernel.geom.AffineTransform; 
import com.itextpdf.kernel.geom.Rectangle; 

import com.itextpdf.kernel.pdf.PdfDocument;
import com.itextpdf.kernel.pdf.PdfPage; 
import com.itextpdf.kernel.pdf.PdfReader; 
import com.itextpdf.kernel.pdf.PdfWriter; 
import com.itextpdf.kernel.pdf.canvas.PdfCanvas; 

import com.itextpdf.kernel.pdf.xobject.PdfFormXObject; 
import com.itextpdf.layout.Document;  

public class ShrinkPDF {    
   public static void main(String args[]) throws Exception {
      // Creating a PdfWriter object
      String dest = "C:/itextExamples/shrinking.pdf";
      PdfWriter writer = new PdfWriter(dest);
      
      // Creating a PdfReader
      String src = "C:/itextExamples/pdfWithImage.pdf";
      PdfReader reader = new PdfReader(src);
      
      // Creating a PdfDocument objects
      PdfDocument destpdf = new PdfDocument(writer);
      PdfDocument srcPdf = new PdfDocument(reader);
         
      // Opening a page from the existing PDF 
      PdfPage origPage = srcPdf.getPage(1);
         
      // Getting the page size
      Rectangle orig = origPage.getPageSizeWithRotation();
         
      // Adding a page to destination Pdf
      PdfPage page = destpdf.addNewPage();
         
      // Scaling the image in a Pdf page     
      AffineTransform transformationMatrix = AffineTransform.getScaleInstance(
         page.getPageSize().getWidth()/orig.getWidth()/2,
         page.getPageSize().getHeight()/ orig.getHeight()/2);
      
      // Shrink original page content using transformation matrix
      PdfCanvas canvas = new PdfCanvas(page);
      canvas.concatMatrix(transformationMatrix);
      
      // Add the object to the canvas
      PdfFormXObject pageCopy = origPage.copyAsFormXObject(destpdf);
      canvas.addXObject(pageCopy, 0, 0);
      
      // Creating a Document object
      Document doc = new Document(destpdf);
      
      // Closing the document
      doc.close();
      
      System.out.println("Table created successfully..");
   }
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac ShrinkingPDF.java 
java ShrinkingPDF

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

Table created successfully..

指定したパスを確認すると、作成したPDFドキュメントが以下のように表示されます。

次のJavaプログラムは、iTextライブラリを使用してPDFページのコンテンツを別のページに並べて表示する方法を示しています。名前の付いたPDFドキュメントを作成しますtilingPdfPages.pdf パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します TilingPDFPages.java

import com.itextpdf.kernel.geom.AffineTransform; 
import com.itextpdf.kernel.geom.PageSize; 
import com.itextpdf.kernel.geom.Rectangle; 

import com.itextpdf.kernel.pdf.PdfDocument; 
import com.itextpdf.kernel.pdf.PdfPage; 
import com.itextpdf.kernel.pdf.PdfReader; 
import com.itextpdf.kernel.pdf.PdfWriter; 
import com.itextpdf.kernel.pdf.canvas.PdfCanvas; 
import com.itextpdf.kernel.pdf.xobject.PdfFormXObject;  

public class TilingPDFPages {      
   public static void main(String args[]) throws Exception {             
      // Creating a PdfWriter object       
      String dest = "C:/itextExamples/tilingPdfPages.pdf";       
      PdfWriter writer = new PdfWriter(dest);               
      
      // Creating a PdfReader       
      String src = "C:/itextExamples/pdfWithImage.pdf";       
      PdfReader reader = new PdfReader(src);        
      
      // Creating a PdfDocument objects       
      PdfDocument destpdf = new PdfDocument(writer);               
      PdfDocument srcPdf = new PdfDocument(reader);               
      
      // Opening a page from the existing PDF       
      PdfPage origPage = srcPdf.getPage(1);               
      
      // Getting the page size       
      Rectangle orig = origPage.getPageSizeWithRotation();    
      
      // Getting the size of the page       
      PdfFormXObject pageCopy = origPage.copyAsFormXObject(destpdf);  
      
      // Tile size 
      Rectangle tileSize = PageSize.A4.rotate();       
      AffineTransform transformationMatrix = 
         AffineTransform.getScaleInstance(tileSize.getWidth() / orig.getWidth() * 
         2f, tileSize.getHeight() / orig.getHeight() * 2f);              
      
      // The first tile       
      PdfPage page = 
      destpdf.addNewPage(PageSize.A4.rotate());       
      
      PdfCanvas canvas = new PdfCanvas(page);       
      canvas.concatMatrix(transformationMatrix);      
      canvas.addXObject(pageCopy, 0, -orig.getHeight() / 2f);              
      
      // The second tile       
      page = destpdf.addNewPage(PageSize.A4.rotate());       
      canvas = new PdfCanvas(page);       
      canvas.concatMatrix(transformationMatrix);        
      canvas.addXObject(pageCopy, -orig.getWidth() / 2f, -orig.getHeight() / 2f);
      
      // The third tile
      page = destpdf.addNewPage(PageSize.A4.rotate());
      canvas = new PdfCanvas(page);
      canvas.concatMatrix(transformationMatrix);
      canvas.addXObject(pageCopy, 0, 0);    
      
      // The fourth tile
      page = destpdf.addNewPage(PageSize.A4.rotate());
      canvas = new PdfCanvas(page);
      canvas.concatMatrix(transformationMatrix);
      canvas.addXObject(pageCopy, -orig.getWidth() / 2f, 0);
      
      // closing the documents
      destpdf.close();
      srcPdf.close();
      
      System.out.println("PDF created successfully..");
   }
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac TilingPDFPages.java 
java TilingPDFPages

上記のプログラムを実行すると、PDFドキュメントが作成され、次のメッセージが表示されます。

PDF created successfully..

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます-

次のJavaプログラムは、iTextライブラリを使用してPDFページでN-upを実行する方法を示しています。名前の付いたPDFドキュメントを作成しますnUppingPDF.pdf パスに保存します C:/itextExamples/

このコードを名前のファイルに保存します NUppingPDF.java

import com.itextpdf.kernel.geom.AffineTransform; 
import com.itextpdf.kernel.geom.PageSize; 
import com.itextpdf.kernel.geom.Rectangle; 

import com.itextpdf.kernel.pdf.PdfDocument; 
import com.itextpdf.kernel.pdf.PdfPage; 
import com.itextpdf.kernel.pdf.PdfReader; 
import com.itextpdf.kernel.pdf.PdfWriter; 
import com.itextpdf.kernel.pdf.canvas.PdfCanvas; 
import com.itextpdf.kernel.pdf.xobject.PdfFormXObject;  
   
public class NUppingPDF {    
   public static void main(String args[]) throws Exception {       
      // Creating a PdfWriter object       
      String dest = "C:/itextExamples/nUppingPDF.pdf";       
      PdfWriter writer = new PdfWriter(dest);                
      
      // Creating a PdfReader       
      String src = "C:/itextExamples/pdfWithImage.pdf";       
      PdfReader reader = new PdfReader(src);        
         
      // Creating a PdfDocument objects       
      PdfDocument destpdf = new PdfDocument(writer);               
      PdfDocument srcPdf = new PdfDocument(reader);                
      
      // Opening a page from the existing PDF       
      PdfPage origPage = srcPdf.getPage(1);       
      Rectangle orig = origPage.getPageSize();       
      PdfFormXObject pageCopy = origPage.copyAsFormXObject(destpdf);              
      
      // N-up page       
      PageSize nUpPageSize = PageSize.A4.rotate();       
      PdfPage page = destpdf.addNewPage(nUpPageSize);       
      PdfCanvas canvas = new PdfCanvas(page);              
      
      // Scale page       
      AffineTransform transformationMatrix = AffineTransform.getScaleInstance( 
         nUpPageSize.getWidth() / orig.getWidth() / 
         2f, nUpPageSize.getHeight() / orig.getHeight() / 2f);       
      canvas.concatMatrix(transformationMatrix);              
      
      // Add pages to N-up page       
      canvas.addXObject(pageCopy, 0, orig.getHeight());       
      canvas.addXObject(pageCopy, orig.getWidth(), orig.getHeight());       
      canvas.addXObject(pageCopy, 0, 0);       
      canvas.addXObject(pageCopy, orig.getWidth(), 0);              
      
      // closing the documents       
      destpdf.close();       
      srcPdf.close();              
      
      System.out.println("PDF created successfully..");   
   } 
}

次のコマンドを使用して、コマンドプロンプトから保存したJavaファイルをコンパイルして実行します-

javac NUppingPDF.java 
java NUppingPDF

上記のプログラムを実行すると、次のメッセージを表示するPDFドキュメントが作成されます。

PDF created successfully..

指定されたパスを確認すると、以下に示すように、作成されたPDFドキュメントを見つけることができます。