iText - लाइन एनोटेशन

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

एक Pdf में एक लाइन एनोटेशन बनाना

आप को इंस्टेंट करके खाली पीडीएफ डॉक्यूमेंट बना सकते हैं Documentकक्षा। इस वर्ग को त्वरित करते समय, आपको पास होने की आवश्यकता हैPdfDocument एक पैरामीटर के रूप में वस्तु, इसके निर्माता के लिए।

अपने पीडीएफ दस्तावेज़ में पाठ एनोटेशन का उपयोग करने के लिए, आपको एक ऑब्जेक्ट बनाने की आवश्यकता है PdfTextAnnotation वर्ग और यह करने के लिए जोड़ें PdfPage

पीडीएफ दस्तावेज़ में पाठ एनोटेशन का उपयोग करने के चरण निम्नलिखित हैं।

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

PdfWriterक्लास एक पीडीएफ के लिए DocWriter का प्रतिनिधित्व करता है। यह वर्ग पैकेज का हैcom.itextpdf.kernel.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 इसके निर्माता के लिए।

PdfWocument वर्ग को उसके निर्माता को PdfWriter ऑब्जेक्ट को पास करके तुरंत दिखाए, जैसा कि नीचे दिखाया गया है।

// Creating a PdfDocument  
PdfDocument pdfDoc = new PdfDocument(writer);

PdfDocument ऑब्जेक्ट बन जाने के बाद, आप अपने वर्ग द्वारा प्रदान किए गए संबंधित तरीकों का उपयोग करके पेज, फॉन्ट, फाइल अटैचमेंट, इवेंट हैंडलर जैसे विभिन्न तत्वों को जोड़ सकते हैं।

चरण 3: दस्तावेज़ ऑब्जेक्ट बनाना

Document पैकेज की कक्षा com.itextpdf.layoutएक आत्मनिर्भर पीडीएफ बनाते समय मूल तत्व है। इस वर्ग के निर्माणकर्ताओं में से एक वर्ग की एक वस्तु को स्वीकार करता हैPdfDocument

क्लास के ऑब्जेक्ट को पास करके डॉक्यूमेंट क्लास को इंस्टेंट करें 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 क्लास की विधि का उपयोग करें, जैसा कि नीचे दिखाया गया है।

// 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();

उदाहरण

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

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

javac LineAnnotation.java 
java LineAnnotation

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

Annotation added successfully

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