iText - Menyusut Konten
Pada bab ini, kita akan melihat bagaimana menskalakan gambar pada dokumen PDF menggunakan pustaka iText.
Menyusut Konten dalam PDF
Berikut adalah langkah-langkah untuk mengecilkan konten halaman PDF menggunakan perpustakaan iText.
Langkah 1: Membuat objek PdfWriter dan PdfReader
Itu PdfWriterkelas mewakili DocWriter untuk PDF. Kelas ini termasuk dalam paketcom.itextpdf.kernel.pdf. Konstruktor kelas ini menerima string, yang mewakili jalur file tempat PDF akan dibuat.
Buat instance kelas PdfWriter dengan meneruskan nilai string (mewakili jalur tempat Anda perlu membuat PDF) ke konstruktornya, seperti yang ditunjukkan di bawah ini.
// Creating a PdfWriter object
String dest = "C:/itextExamples/shrinking.pdf";
PdfWriter writer = new PdfWriter(dest);
Untuk membaca data dari pdf yang ada, buat file PdfReader objek seperti yang ditunjukkan di bawah ini.
// Creating a PdfReader
String src = "C:/itextExamples/pdfWithImage.pdf";
PdfReader reader = new PdfReader(src);
Langkah 2: Membuat objek PdfDocument
Itu PdfDocumentkelas adalah kelas yang mewakili Dokumen PDF di iText. Kelas ini termasuk dalam paketcom.itextpdf.kernel.pdf. Untuk membuat instance kelas ini (dalam mode menulis), Anda perlu meneruskan objek kelasPdfWriter ke konstruktornya.
Buat dokumen PDF sumber dan tujuan dengan meneruskan PdfWriter dan PdfReader objek ke konstruktor, seperti yang ditunjukkan di bawah ini.
// Creating a PdfDocument objects
PdfDocument destpdf = new PdfDocument(writer);
PdfDocument srcPdf = new PdfDocument(reader);
Langkah 3: Membuka halaman dari PDF yang ada
Dapatkan halaman dari PDF sumber menggunakan getPage() metode dari PdfPagekelas. Menggunakan objek ini, dapatkan ukuran halaman dokumen sumber, seperti yang ditunjukkan di bawah ini.
// Opening a page from the existing PDF
PdfPage origPage = srcPdf.getPage(1);
// Getting the page size
Rectangle orig = origPage.getPageSizeWithRotation();
Langkah 4: Menyusutkan konten pdf sumber
Menggunakan getScaleInstance() metode dari AffineTransform class, menyusutkan konten halaman dokumen sumber, seperti yang ditunjukkan di bawah ini.
// Shrink original page content using transformation matrix
AffineTransform transformationMatrix = AffineTransform.getScaleInstance(
page.getPageSize().getWidth()/ orig.getWidth()/2,
page.getPageSize().getHeight()/ orig.getHeight()/2);
Langkah 5: Menyalin halaman
Gabungkan affine transform matrix, dibuat pada langkah sebelumnya, ke matriks file canvas objek dari dokumen PDF tujuan, seperti yang ditunjukkan di bawah ini.
// Concatenating the affine transform matrix to the current matrix
PdfCanvas canvas = new PdfCanvas(page);
canvas.concatMatrix(transformationMatrix);
Sekarang, tambahkan salinan halaman ke canvas objek PDF tujuan ke dokumen sumber, seperti yang ditunjukkan di bawah ini.
// Add the object to the canvas
PdfFormXObject pageCopy = origPage.copyAsFormXObject(destpdf);
canvas.addXObject(pageCopy, 0, 0);
Langkah 6: Membuat objek Dokumen
Itu Document kelas paket com.itextpdf.layoutadalah elemen root saat membuat PDF mandiri. Salah satu konstruktor kelas ini menerima objek dari kelas PdfDocument.
Instantiate Document kelas dengan melewatkan objek kelas PdfDocument, seperti yang ditunjukkan di bawah ini.
// Creating a Document
Document document = new Document(destpdf);
Langkah 7: Menutup Dokumen
Tutup dokumen menggunakan close() metode dari Document kelas, seperti yang ditunjukkan di bawah ini.
// Closing the document
document.close();
Contoh
Program Java berikut mendemonstrasikan cara mengecilkan konten halaman PDF menggunakan pustaka iText. Ini membuat dokumen PDF dengan namashrinkingPDF.pdf, mengecilkan gambar di pdf, dan menyimpannya di jalur C:/itextExamples/
Simpan kode ini dalam file dengan nama 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..");
}
}
Kompilasi dan jalankan file Java yang disimpan dari command prompt menggunakan perintah berikut -
javac ShrinkingPDF.java
java ShrinkingPDF
Setelah dieksekusi, program di atas membuat dokumen PDF, menampilkan pesan berikut.
Table created successfully..
Jika Anda memverifikasi jalur yang ditentukan, Anda dapat menemukan dokumen PDF yang dibuat seperti yang ditunjukkan di bawah ini.