iText - एक तालिका में छवि जोड़ना

इस अध्याय में, हम देखेंगे कि iText लाइब्रेरी का उपयोग करके पीडीएफ डॉक्यूमेंट में टेबल पर एक इमेज कैसे जोड़ें।

तालिका में एक छवि जोड़ना

आप को इंस्टेंट करके खाली पीडीएफ डॉक्यूमेंट बना सकते हैं Documentकक्षा। इस वर्ग को त्वरित करते समय, आपको पास होने की आवश्यकता हैPdfDocumentएक पैरामीटर के रूप में वस्तु, इसके निर्माता के लिए। फिर, दस्तावेज़ में एक तालिका जोड़ने के लिए, आपको तत्काल करने की आवश्यकता हैTable वर्ग और दस्तावेज़ का उपयोग करके इस ऑब्जेक्ट को जोड़ें add() तरीका।

इस तालिका में एक छवि जोड़ने के लिए, आपको तत्काल सूचना देने की आवश्यकता है Cell वर्ग, बनाएँ और जोड़ने के लिए आवश्यक छवि का एक ऑब्जेक्ट, छवि को जोड़ें cell का उपयोग कर वस्तु add() की विधि Cell कक्षा।

एक तालिका के कक्ष में एक छवि सम्मिलित करने के लिए निम्नलिखित चरण हैं।

चरण 1: एक PdfWriter ऑब्जेक्ट बनाना

PdfWriter वर्ग पीडीएफ के लिए डॉक्टर लेखक का प्रतिनिधित्व करता है, यह वर्ग पैकेज के अंतर्गत आता है com.itextpdf.kernel.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 पैकेज की कक्षा com.itextpdf.layoutएक आत्मनिर्भर पीडीएफ बनाते समय मूल तत्व है। इस वर्ग के निर्माणकर्ताओं में से एक वर्ग की एक वस्तु को स्वीकार करता हैPdfDocument

झटपट Document कक्षा की वस्तु को पास करके कक्षा PdfDocument पिछले चरणों में बनाया गया है, जैसा कि नीचे दिखाया गया है।

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

चरण 4: एक टेबल ऑब्जेक्ट बनाना

Tableवर्ग कोशिकाओं और स्तंभों में क्रमबद्ध कोशिकाओं से भरे दो आयामी ग्रिड का प्रतिनिधित्व करता है। यह पैकेज के अंतर्गत आता है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();

उदाहरण

निम्न जावा प्रोग्राम दर्शाता है कि iText लाइब्रेरी का उपयोग करके पीडीएफ दस्तावेज़ में एक तालिका के सेल में एक छवि कैसे जोड़ें। यह नाम के साथ एक पीडीएफ दस्तावेज़ बनाता हैaddingImage.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..");     
   } 
}

निम्न आदेशों का उपयोग करके कमांड प्रॉम्प्ट से सहेजी गई जावा फ़ाइल को संकलित करें और निष्पादित करें -

javac AddingImageToTable.java 
java AddingImageToTable

निष्पादन के बाद, उपरोक्त कार्यक्रम एक पीडीएफ दस्तावेज़ बनाता है, जो निम्न संदेश प्रदर्शित करता है।

Image added to table successfully..

यदि आप निर्दिष्ट पथ को सत्यापित करते हैं, तो आप नीचे दिए गए पीडीएफ दस्तावेज़ बना सकते हैं, जैसा कि नीचे दिखाया गया है।