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/markupAnnotation.pdf"; 
PdfWriter writer = new PdfWriter(dest);

이 유형의 객체가 PdfDocument (클래스)에 전달되면이 문서에 추가 된 모든 요소가 지정된 파일에 기록됩니다.

2 단계 : PdfDocument 개체 만들기

그만큼 PdfDocumentclass는 iText에서 PDF 문서를 나타내는 클래스입니다. 이 클래스는 패키지에 속합니다.com.itextpdf.kernel.pdf. 이 클래스를 인스턴스화하려면 (쓰기 모드에서) 클래스의 객체를 전달해야합니다.PdfWriter 생성자에.

아래와 같이 PdfWriter 개체를 생성자에 전달하여 PdfDocument 클래스를 인스턴스화합니다.

// 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 모든 주석의 수퍼 클래스를 나타냅니다.

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

// Creating a PdfTextMarkupAnnotation object 
Rectangle rect = new Rectangle(105, 790, 64, 10); 
float[] floatArray = new float[]{169, 790, 105, 790, 169, 800, 105, 800};
PdfAnnotation annotation = PdfTextMarkupAnnotation.createHighLight(rect,floatArray);

5 단계 : 주석 색상 설정

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

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

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

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

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

// Setting contents to the annotation 
annotation.setContents(new PdfString("Hi welcome to Tutorialspoint"));

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

새로 만들기 PdfPage 클래스를 사용하여 addNewPage() 의 방법 PdfDocument 클래스를 만들고 위에서 만든 주석을 addAnnotation() 아래와 같이 PdfPage 클래스의 메서드입니다.

// Creating a new Pdfpage 
PdfPage pdfPage = pdfDoc.addNewPage();        

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

8 단계 : 문서 닫기

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

// Closing the document 
document.close();

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

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

public class MarkupAnnotation {    
   public static void main(String args[]) throws Exception {   
      // Creating a PdfDocument object       
      String file = "C:/itextExamples/markupAnnotation.pdf";        
      PdfDocument pdfDoc = new PdfDocument(new PdfWriter(file));                   
   
      // Creating a Document object       
      Document doc = new Document(pdfDoc);                      
      
      // Creating a PdfTextMarkupAnnotation object       
      Rectangle rect = new Rectangle(105, 790, 64, 10);       
      float[] floatArray = new float[]{169, 790, 105, 790, 169, 800, 105, 800};
      PdfAnnotation annotation = 
         PdfTextMarkupAnnotation.createHighLight(rect,floatArray);
      
      // Setting color to the annotation       
      annotation.setColor(Color.YELLOW);              
      
      // Setting title to the annotation       
      annotation.setTitle(new PdfString("Hello!"));
      
      // Setting contents to the annotation       
      annotation.setContents(new PdfString("Hi welcome to Tutorialspoint"));
      
      // Creating a new Pdfpage
      PdfPage pdfPage = pdfDoc.addNewPage();
      
      // Adding annotation to a page in a PDF       
      pdfPage.addAnnotation(annotation);
      
      // Closing the document
      doc.close();  
      
      System.out.println("Annotation added successfully");       
   }     
}

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

javac MarkupAnnotation.java 
java MarkupAnnotation

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

Annotation added successfully

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