iText-텍스트 주석

이 장에서는 iText 라이브러리를 사용하여 PDF 문서에 텍스트 주석을 추가하는 방법을 알아 봅니다.

PDF에서 텍스트 주석 만들기

인스턴스화하여 빈 PDF 문서를 만들 수 있습니다. Document수업. 이 클래스를 인스턴스화하는 동안PdfDocument 생성자에 대한 매개 변수로 객체.

PDF 문서에서 텍스트 주석을 사용하려면 다음 개체를 만들어야합니다. PdfTextAnnotation 클래스를 추가하고 PdfPage.

다음은 PDF 문서에서 텍스트 주석을 사용하는 단계입니다.

1 단계 : PdfWriter 개체 만들기

그만큼 PdfWriter클래스는 PDF 용 DocWriter를 나타냅니다. 이 클래스는 패키지에 속합니다.com.itextpdf.kernel.pdf. 이 클래스의 생성자는 PDF가 생성 될 파일의 ​​경로를 나타내는 문자열을받습니다.

아래와 같이 생성자에 문자열 값 (PDF를 만들어야하는 경로를 나타냄)을 전달하여 PdfWriter 클래스를 인스턴스화합니다.

// Creating a PdfWriter 
String dest = "C:/itextExamples/textAnnotation.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 개체 만들기

그만큼 Document 패키지 클래스 com.itextpdf.layout자급 자족 PDF를 만드는 동안 루트 요소입니다. 이 클래스의 생성자 중 하나는 클래스의 객체를받습니다.PdfDocument.

인스턴스화 Document 클래스의 객체를 전달하여 클래스 PdfDocument 아래와 같이 이전 단계에서 생성되었습니다.

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

4 단계 : PdfAnnotation 개체 만들기

그만큼 PdfAnnotation 패키지 클래스 com.itextpdf.kernel.pdf.annot 모든 주석의 수퍼 클래스를 나타냅니다.

파생 클래스 중 PdfTextAnnotation클래스는 텍스트 주석을 나타냅니다. 아래와 같이이 클래스의 개체를 만듭니다.

// Creating PdfAnnotation 
Rectangle rect = new Rectangle(20, 800, 0, 0); 
PdfAnnotation ann = new PdfTextAnnotation(rect);

5 단계 : 주석 색상 설정

다음을 사용하여 주석에 색상을 설정합니다. setColor() 의 방법 PdfAnnotation수업. 이 메서드에color 주석의 색상을 매개 변수로 나타내는 객체입니다.

// Setting color to the annotation 
ann.setColor(Color.GREEN);

6 단계 : 주석의 제목 및 내용 설정

다음을 사용하여 주석의 제목과 내용을 설정합니다. setTitle()setContents() 의 방법 PdfAnnotation 아래에 표시된대로 각각 클래스.

// Setting title to the annotation 
ann.setTitle(new PdfString("Hello"));        

// Setting contents of the annotation 
ann.setContents("Hi welcome to Tutorialspoint.");

7 단계 : 페이지에 주석 추가

새로 만들기 PdfPage 클래스를 사용하여 addNewPage() PdfDocument 클래스의 메서드를 사용하고 addAnnotation() 의 방법 PdfPage 아래와 같이 클래스.

// Creating a new page PdfPage page = 
pdf.addNewPage();        

// Adding annotation to a page in a PDF 
page.addAnnotation(ann);

8 단계 : 문서 닫기

다음을 사용하여 문서를 닫습니다. close() 의 방법 Document 아래와 같이 클래스.

// Closing the document 
document.close();

다음 Java 프로그램은 iText 라이브러리를 사용하여 PDF 문서에 텍스트 주석을 추가하는 방법을 보여줍니다. 이름을 가진 PDF 문서를 생성합니다.textAnnotation.pdf, 텍스트 주석을 추가하고 경로에 저장합니다. C:/itextExamples/

이 코드를 이름으로 파일에 저장하십시오. TextAnnotation.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.PdfTextAnnotation; 
import com.itextpdf.layout.Document;  

public class TextAnnotation {    
   public static void main(String args[]) throws Exception {        
      // Creating a PdfWriter       
      String dest = "C:/itextExamples/textAnnotation.pdf";       
      PdfWriter writer = new PdfWriter(dest);               
      
      // Creating a PdfDocument       
      PdfDocument pdf = new PdfDocument(writer);               
      
      // Creating a Document        
      Document document = new Document(pdf);             
      
      // Creating PdfTextAnnotation object
      Rectangle rect = new Rectangle(20, 800, 0, 0);       
      PdfAnnotation ann = new PdfTextAnnotation(rect);              
      
      // Setting color to the annotation
      ann.setColor(Color.GREEN);              
      
      // Setting title to the annotation 
      ann.setTitle(new PdfString("Hello"));              
      
      // Setting contents of the annotation       
      ann.setContents("Hi welcome to Tutorialspoint.");              
      
      // Creating a new page       
      PdfPage page =  pdf.addNewPage();              
      
      // Adding annotation to a page in a PDF
      page.addAnnotation(ann);

      // Closing the document       
      document.close();       
      
      System.out.println("Annotation added successfully");    
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac TextAnnotation.java 
java TextAnnotation

실행시 위 프로그램은 다음 메시지를 표시하는 PDF 문서를 생성합니다.

Annotation added successfully

지정된 경로를 확인하면 아래와 같이 생성 된 PDF 문서를 찾을 수 있습니다.