В этой главе мы увидим, как добавить изображение в документ PDF с помощью библиотеки iText.
Добавление изображения в PDF
Вы можете создать пустой PDF-документ, создав экземпляр класса Document . При создании экземпляра этого класса вам необходимо передать объект PdfDocument в качестве параметра его конструктору. Чтобы добавить изображение в PDF, создайте объект изображения, который требуется добавить, и добавьте его с помощью метода add () класса Document .
Ниже приведены инструкции по добавлению изображения в документ PDF.
Шаг 1: Создание объекта PdfWriter
Класс PdfWriter представляет DocWriter для PDF. Этот класс принадлежит пакету com.itextpdf.kernel.pdf . Конструктор этого класса принимает строку, представляющую путь к файлу, в котором должен быть создан PDF.
Создайте экземпляр класса PdfWriter, передав строковое значение (представляющее путь, по которому вам нужно создать PDF), в его конструктор, как показано ниже.
// Creating a PdfWriter String dest = "C:/itextExamples/addingImage.pdf"; PdfWriter writer = new PdfWriter(dest);
Когда объект этого типа передается в PdfDocument (класс), каждый элемент, добавленный в этот документ, будет записан в указанный файл.
Шаг 2: Создание объекта PdfDocument
Класс PdfDocument — это класс, который представляет документ PDF в iText. Этот класс принадлежит пакету com.itextpdf.kernel.pdf . Чтобы создать экземпляр этого класса (в режиме записи), вам нужно передать объект класса PdfWriter его конструктору.
Создайте экземпляр класса PdfDocument, передав вышеупомянутый созданный объект PdfWriter его конструктору, как показано ниже.
// Creating a PdfDocument PdfDocument pdfDoc = new PdfDocument(writer);
После создания объекта PdfDocument вы можете добавить различные элементы, такие как страница, шрифт, вложение файла и обработчик события, используя соответствующие методы, предоставляемые его классом.
Шаг 3: Создание объекта Document
Класс Document пакета com.itextpdf.layout является корневым элементом при создании самодостаточного PDF. Один из конструкторов этого класса принимает объект класса 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-программа демонстрирует, как добавить изображение в PDF-документ с помощью библиотеки iText. Он создает документ PDF с именем добавление изображения.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-документ, как показано ниже.