/*
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;
}
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
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として描画し、元の注釈そのものは削除します。
注釈は編集できなくなり、単なる固定された表示として残ります。

