トラスト・ソフトウェア・システム
トラスト・ソフトウェア・システム

PDF Prep Tool Suite テキスト追加C++サンプル

「PDF Prep Tool Suite」ソフトは、PDF文書を作成、編集、分割、統合するためのAPI(ライブラリ)です。

PDF文書にテキスト・コンテント、画像、ベクタ・グラフィックスを追加します。 さらに、インターラクティブな要素(ハイパー・リンク、フォーム・フィールド、ブックマークなど)を追加し処理します。

PDF文書は、新たに生成することができます。プロパティ(位置、フォント、サイズ、色など)は自由に選択できます。 作成されたPDF文書には、暗号化やWebの表示用に最適化が施されます。

機能概要はこちらです。
無償評価版(リンク先は英語)はこちらです。 ダウンロード手順
他のC++サンプルC#サンプルを公開しています。
PDF Prep Tool Suite ソフト 購入(価格)

無償評価版のダウンロードとインストール

 ライブラリ(評価版API)は無償でダウンロード(試用)できますので、PDF Prep Tool Suiteダウンロード手順を参照してダウンロードください。
 ファイルをダウンロードしてから、インストールもしくは適当なフォルダーに解凍します。以下のようなフォルダーができあがりますので、適宜ご利用ください。
binライブラリやライセンスマネージャーなど
doc使用説明書やjavadocなど
includeC/C++用のヘッダー(.h)ファイル
jarPrepTool.jar、I2PA.jar(Javaのラッパー)
libC/C++用のlibファイル
ご注意ください:サンプル(英語版)はPDF Tools AG社のページからダウンロードできますが、それを動作させるためにはコードの変更が必要な場合があります。
以下のサンプルは、正しい動作を確認しています。ソースコードはこちらからダウンロードできます。

無償評価版と共にダウンロードしたライセンスキーをbin/LicenseManager.exeを使って登録してください。 ライセンスキーの登録方法はこちらです。

サンプルの実行前に、bin/pdprep32.dll、bin/Img2PdfAPI.dllをサンプル実行イメージと同じフォルダーにコピーしてください。文字化けする場合は、bin/pdcjk.dllも同様にコピーしてください。
COMインターフェースで利用する場合は、bin/pdprep32.dll、bin/Img2PdfAPI.dllをregsvr32.exeを使って登録してください。なお、64ビット版Windowsの場合は、WOW64/regsvr32.exeを使って登録してください。

テキストを追加するC++サンプルと解説

 PDF文書にテキストフィールドを追加して、新しいPDF文書を作成するサンプルです。
#include <stdio.h>
#include "pdprep.h"

#pragma comment(lib,"pdprep32.lib")

int main(int argc, char* argv[])
{
    PTError     TheError;
    Handle      doc;
    InputHandle in;
    float       box[] = {50.0f, 250.0f, 200.0f, 40.0f};
    //                  {X-axis,Y-axis, width,  height}

    // 引数チェック
    if(argc < 3){
        printf("usage: flatten PDF-InputFile PDF-OutputFile\n");
        return 1;
    }

    // 初期化
    PTInitialize();

    // 新しいPDF文書を作成し、入力のPDFをオープン
    doc = PDocNew(argv[2], 0, 0, &TheError);
    PDocInputOpen(doc,argv[1]);
    in  = PDocGetInputHandle(doc);

    // テキストフィールド "field1"を追加し、データをセットする
    IDocAddTextField(in,"field1", "", box, 1, 4, 12.0f, 0, 4096, 4, 0, 0xa0ffa0, 0, 0x000000);
    PDocInputSetFormData(doc,"field1", "ABCD EFGH IKJK LMNO PQRS TUVW XYZ", 4096, 4);

    // flattenを有効にする
    PDocSetFlatten(doc, 1, PTFlattenVisibleOrPrintable);

    // すべてをコピーして文書を閉じる
    PDocInputCopyAll(doc);
    PDocClose(doc);
    return 0;
}
このサンプルでは、以下の手順でPDFを作成します。
  1. 初期化
  2. 出力のPDF作成
  3. 入力のPDFを開く
  4. テキストフィールドを作成し文字列をセットする
  5. 外観を変更する
  6. すべてのページをコピー
  7. PDFを閉じる
参考)フォームフィールドにはデフォルトのフォントで書き込まれます。そのため、フォントの指定は省略できます。
PTInitialize 初期化
PDocNew( ) 出力のPDF文書生成とそのハンドルを取得
引数に以下の値を設定します。
第一引数作成するPDF文書のファイル(パス)名
第二引数作成するPDF文書のページ幅(ポイント単位)
第三引数作成するPDF文書のページ高さ(ポイント単位)
第四引数エラーコードが格納されるインスタンス
PDocInputOpen( ) 入力PDFを開く
引数に以下の値を設定します。
第一引数PDF文書のハンドル
第二引数入力PDF文書ファイル(パス)名
PDocGetInputHandle( ) 入力PDFのハンドル取得
引数にPDF文書のハンドルを設定します。
IDocAddTextField( ) テキストフォームを追加
PDocInputSetFormData( ) テキストフォームにデータを設定
PDocSetFlatten( ) フォームフィールドを除去し他のコンテンツと同等にする
指定したフォームはその機能を失い、他のコンテンツ同様の形態に変わります。
PDocInputCopyAll( ) 入力PDFのすべてのページを出力PDFにコピー
引数に、出力PDFのハンドルを設定します。

サンプルコード

 C++ PDF Prep Tool Suite サンプル (MS Visual Studio 2008 Project) PtsCppSamples.zip

ご質問、お問い合わせ

 メールで support@TrustSS.co.jp 宛てにお送りください。
または、質問のページからお送りいただくようお願いします。ご要望も承っております。(匿名で送れます。)

(記載の会社名および製品名は、各社の登録商標および商標です。)
PDF製品 C++サンプル
PDF Security
PDF Validator
PDF to PDF/A Converter
PDF to Image Converter
PDF Imager-LP
Image to PDF Converter
PDF Printer
PDF Viewer
PDF Viewer-L
PDF Prep Tool Suite
PDF Optimization
PDF Command Line Suite
PDF Extract
PDF Easy Parse
株)トラスト・ソフトウェア・システム
暗号化・電子署名・タイムスタンプ ライブラリ作成します。
お問い合わせください。