В этой главе мы увидим, как добавить изображение в таблицу в документе PDF с помощью библиотеки iText.
Добавление изображения в таблицу
Вы можете создать пустой документ PDF, создав экземпляр класса Document . При создании экземпляра этого класса вам необходимо передать объект PdfDocument в качестве параметра его конструктору. Затем, чтобы добавить таблицу в документ, вам нужно создать экземпляр класса Table и добавить этот объект в документ с помощью метода add () .
Чтобы добавить изображение в эту таблицу, необходимо создать экземпляр класса Cell , создать и добавить объект изображения, который требуется добавить, добавить изображение в объект ячейки с помощью метода add () класса Cell .
Ниже приведены шаги для вставки изображения в ячейку таблицы.
Шаг 1: Создание объекта PdfWriter
Класс PdfWriter представляет Doc Writer для 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: Создание объекта Table
Класс Table представляет собой двумерную сетку, заполненную ячейками, упорядоченными по строкам и столбцам. Он принадлежит пакету com.itextpdf.layout.element .
Создайте класс Table, как показано ниже.
// Creating a table float [] pointColumnWidths = {200F, 200F}; Table table = new Table(pointColumnWidths);
Шаг 5: Создание ячейки
Создайте объект ячейки, создав экземпляр класса Cell пакета com.itextpdf.layout , как показано ниже.
// Adding cell to the table Cell cell = new Cell(); // Creating a cell
Шаг 6: Создание изображения
Для создания объекта изображения , прежде всего, создайте объект 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);
Добавьте объект изображения в ячейку, используя метод add () класса ячейки, как показано ниже.
// Adding image to the cell cell.add(img.setAutoScale(true));
Шаг 7: Добавление ячейки в таблицу
Наконец, чтобы добавить эту ячейку в таблицу, вызовите метод addCell () класса Table и передайте объект ячейки в качестве параметра этому методу, как показано ниже.
table.addCell(cell);
Шаг 8: Добавление таблицы в документ
Добавьте объект таблицы, созданный на предыдущем шаге, с помощью метода add () класса Document , как показано ниже.
// Adding list to the document document.add(table);
Шаг 9: Закрытие документа
Закройте документ с помощью метода close () класса Document , как показано ниже.
// Closing the document document.close();
пример
Следующая программа на Java демонстрирует, как добавить изображение в ячейку таблицы в документе PDF с помощью библиотеки iText. Он создает документ PDF с именем добавление изображения.pdf , добавляет к нему таблицу, вставляет изображение (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-документ, как показано ниже.