OEM販売のご相談
ご相談ください!

PDF Tool APIサンプルコード:注釈の埋め込み

機能イメージ

フォームXObjectとして注釈を描画します。

概要

サンプルコードの概要

ページ内の注釈を取得してフォームXObjectとして描画し元の注釈を削除します。

  • PtlAnnots: 注釈のコンテナを表現するクラス
  • PtlPage.getAnnots(): 注釈コンテナを取得
  • PtlContent: ページに描画される内容(コンテント)を表現するクラス
  • PtlPage.getContent(): ページコンテントを取得
  • PtlAnnot: PDFの注釈を表現したクラス
  • PtlAnnots.get(index): 指定位置にある注釈を取得
  • PtlContent.drawForm(PtlAnnot): フォームXObjectとして注釈を描画します
  • PtlAnnots.remove(index): 指定位置の注釈を削除し、後続の注釈を前につめます

サンプルコード

/*
	Antenna House PDF Tool API V8.0
	C++ Interface sample program

	概要:注釈をコンテントへ書き込み

	Copyright 2025 Antenna House, Inc.
*/

#include < PdfTk.h >
#include < stdio.h >

using namespace PdfTk;

int main(int argc, char* argv[])
{
	if (argc < 2) {
		printf("usage: AnnotToContent.exe in-pdf-file out-pdf-file\n");
		return 1;
	}
	try
	{
		PtlParamInput input(argv[1]);
		PtlParamOutput output(argv[2]);
		PtlPDFDocument doc;

		// PDFファイルをロードします。
		doc.load(input);

		// ページコンテナの取得
		PtlPages& pages = doc.getPages();

		// ページコンテナが空かどうか
		if (pages.isEmpty()){
			printf("ページコンテナが空\n");
			return 1;
		}

		int numPages = pages.getCount();
        for (int i=0; i= 0; j--)
				{
					// 注釈取得
					PtlAnnot annot = annots.get(j);

					// 注釈をページに書き込む
					content.drawForm(annot);

					// 元の注釈を削除する
					annots.remove(j);
				}
			}
		}

		// ファイルに保存します。
		doc.save(output);

		printf("完了!\n");
	}
	catch (const PtlException &e)
	{
		fprintf(stderr, "Error code : %d\n %s\n", e.getErrorCode(), e.getErrorMessage().c_str());
		return 1;
	}	
	return 0;
}

            
/*
    Antenna House PDF Tool API V8.0
    Java Interface sample program

    概要:注釈をコンテントへ書き込み

    Copyright 2015-2025 Antenna House, Inc.
*/

package Sample;

import jp.co.antenna.ptl.PtlAnnot;
import jp.co.antenna.ptl.PtlAnnots;
import jp.co.antenna.ptl.PtlContent;
import jp.co.antenna.ptl.PtlException;
import jp.co.antenna.ptl.PtlPDFDocument;
import jp.co.antenna.ptl.PtlPage;
import jp.co.antenna.ptl.PtlPages;
import jp.co.antenna.ptl.PtlParamInput;
import jp.co.antenna.ptl.PtlParamOutput;

public class AnnotToContent {

    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) {
        if (args.length < 2)
        {
            System.out.println("usage: java AnnotToContent in-pdf-file out-attach-file");
            return;
        }

        try (PtlParamInput inputFile = new PtlParamInput(args[0]);
            PtlParamOutput outputFile = new PtlParamOutput(args[1]);
            PtlPDFDocument doc = new PtlPDFDocument()) {

            // PDFファイルをロードします。
            doc.load(inputFile);

            try (PtlPages pages = doc.getPages()) //ページコンテナの取得
            {
                // ページコンテナが空かどうか
                if (pages.isEmpty())
                {
                    System.out.println("ページコンテナが空\n");
                    return;
                }

                int numPages = pages.getCount();
                for (int i=0; i= 0; j--)
                            {
                                // 注釈数の取得
                                try (PtlAnnot annot = annots.get(j)) {

                                    // ページに書き込む
                                    content.drawForm(annot);

                                    // 元の注釈を削除する
                                    annots.remove(j);
                                }
                            }
                        }
                    }
                }
            }

            // ファイルに保存します。
            doc.save(outputFile);
        }
        catch (PtlException pex) {
            System.out.println("PtlException : ErrorCode = " + pex.getErrorCode() + "\n  " + pex.getErrorMessage());
        }
        catch (Exception ex) {
            System.out.println(ex.getMessage());
            ex.printStackTrace();
        }
        catch (Error ex) {
            System.out.println(ex.getMessage());
            ex.printStackTrace();
        }
        finally {
            System.out.println("-- 完了 --");
        }
    }
}

            
/*
	Antenna House PDF Tool API V8.0
	.NET Interface sample program

	概要:注釈をコンテントへ書き込み

	Copyright 2025 Antenna House, Inc.
*/

using System;
using PdfTkNet;

namespace AnnotToContent
{
    class Program
    {
        static void Main(string[] args)
        {
            if (args.Length < 2)
            {
                Console.WriteLine("usage: AnnotToContent.exe in-pdf-file out-pdf-file");
                return;
            }
            try
            {
                using (PtlParamInput input = new PtlParamInput(args[0]))
                using (PtlParamOutput output = new PtlParamOutput(args[1]))
                using (PtlPDFDocument doc = new PtlPDFDocument())
                {

                    // PDFファイルをロードします。
                    doc.load(input);

                    // ページコンテナの取得
                    using (PtlPages pages = doc.getPages())
                    {

                        // ページコンテナが空かどうか
                        if (pages.isEmpty())
                        {
                            Console.WriteLine("ページコンテナが空");
                            return;
                        }

                        int numPages = pages.getCount();
                        for (int i = 0; i < numPages; i++)
                        {
                            Console.WriteLine("ページ : " + (i + 1));

                            using (PtlPage page = pages.get(i)) // ページの取得
                            using (PtlAnnots annots = page.getAnnots()) // 注釈コンテナの取得
                            {
                                // 注釈コンテナが空かどうか
                                if (annots.isEmpty())
                                {
                                    Console.WriteLine("注釈なし");
                                }
                                else
                                {
                                    using (PtlContent content = page.getContent())
                                    {
                                        // 注釈数の取得
                                        int numAnnots = annots.getCount();
                                        Console.WriteLine("注釈数 : " + numAnnots);
                                        for (int j = numAnnots - 1; j >= 0; j--)
                                        {
                                            using (PtlAnnot annot = annots.get(j))
                                            {
                                                bool bl=content.drawForm(annot);        // ページに書き込む
                                                annots.remove(j);               // 元の注釈を削除する
                                            }
                                        }
                                    }
                                }
                            }
                        }
                        doc.save(output);
                    }
                }
            }
            catch (PtlException pex)
            {
                Console.WriteLine(pex.getErrorCode() + " : " + pex.getErrorMessageJP());
                pex.Dispose();
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
            }
            finally
            {
                Console.WriteLine("-- 完了 --");
            }
        }
    }
}

            

サンプルコードのダウンロードはこちら

実行例

コマンドラインでの実行例

AnnotToContent.exe C:\in\testAnnot.pdf C:\sav\outAnnotToContent.pdf
ページ : 1
注釈数 : 3
ページ : 2
注釈数 : 5
ページ : 3
注釈数 : 13
ページ : 4
注釈数 : 6
ページ : 5
注釈なし
ページ : 6
注釈なし
ページ : 7
注釈なし
ページ : 8
注釈なし
完了!
        
java -jar AnnotToContent.jar C:\in\testAnnot.pdf C:\sav\outAnnotToContent.pdf
ページ1
注釈数 : 3
ページ2
注釈数 : 5
ページ3
注釈数 : 13
ページ4
注釈数 : 6
ページ5
注釈なし
ページ6
注釈なし
ページ7
注釈なし
ページ8
注釈なし
-- 完了 --
AnnotToContent.exe C:\in\testAnnot.pdf C:\sav\outAnnotToContent.pdf
ページ : 1
注釈数 : 3
ページ : 2
注釈数 : 5
ページ : 3
注釈数 : 13
ページ : 4
注釈数 : 6
ページ : 5
注釈なし
ページ : 6
注釈なし
ページ : 7
注釈なし
ページ : 8
注釈なし
-- 完了 --

出力結果イメージ

ページ内の注釈の見た目だけをフォームXObjectとして描画し、元の注釈そのものは削除します。
注釈は編集できなくなり、単なる固定された表示として残ります。

出力イメージ

サンプルコードのダウンロード

サンプルコード

サンプルで使用した入出力PDF