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ドキュメントを見つけることができます。