アイコン 株式会社トラスト・ソフトウェア・システム ロゴ

開発者向けPDFライブラリ - Pdftools SDK

Optimize & Compress PDF (PDFを最適化・圧縮)機能

電子文書の交換、アーカイブ、印刷などの特定のターゲットのニーズに合わせてPDF文書を最適化・圧縮します。

PDFの作成プロセスでは特定の対象アプリケーション向けに最適化されていないPDFが生成されることが少なくありません。
ファイル サイズが大きいくダウンロードに時間が必要な場合や、同じフォントが複数回埋め込まれている場合などは印刷に時間を要する場合があります。
Pdftools SDK を使用すると、さまざまな構成オプションを使用して特定の用途に見合った出力を作成できます。

この機能は、冗長情報や代替情報の削除、フォントのサブセット化と合成、画像のダウンサンプリングなどを実行し、ページ内容や文書構造を圧縮・最適化します。

見積もり

 NOTE:
この機能は「Pdftools SDK」ライブラリの一部です。
Pdftools SDKの全機能は無償で試用できます。

APIリファレンス

APIリファレンスはこちらです。(すべて英文)

画像を圧縮・最適化機能

一般に画像はファイルサイズを大幅に増加させることがあります。Pdftools SDK は画像オブジェクトを最適化し、画像タイプによる画像圧縮の設定、圧縮アルゴリズムと圧縮品質の選択、カラー プロファイルやカラー チャネルなどのカラー管理オプションの設定などによって画像オブジェクトの一部または全体の変換や削除をします。

圧縮処理

画像オブジェクトの処理

カラー・マネージメント

フォントの最適化

PDF ドキュメントを追加しない場合はPDFにフォントを埋め込む必要はありません。
既存のフォントプログラムをサブセット化してドキュメントの再現に必要のない未使用のグリフをすべて削除できます。
標準フォントの削除や、フォントとフォントプログラムを結合するタイミングを決定できます。

コンテンツと構造を圧縮して最適化

不要なオブジェクトは理由もなくファイル サイズを大きくします。
これらの未使用、冗長、不要なオブジェクトを削除してファイル サイズを縮小し、レンダリングを高速化できます。

サンプル

C#のサンプルプロジェクトではPdftools SDKライブラリ(DLL)をNuGetから自動でダウンロードします。
CのサンプルプロジェクトにはPdftools SDKライブラリ(DLL)が含まれています。

ライセンスキー無し(無償)で試用できます。ただし、結果に「透かし」が入ります。
「透かし」の削除をご希望の場合は問い合わせページまたはメールでお問い合わせください。

License Agreement(利用許諾契約書)が含まれていますので必ず確認してください。

PDF文書を最適化する

"Web"最適化プロファイルを使用してPDF文書を最適化します。


サンプル・プロジェクト(C)をダウンロード ReadMeを開く
サンプル・プロジェクト(C#)をダウンロード ReadMeを開く
サンプル・プロジェクトをダウンロード
サンプル・プロジェクトの実行手順を参照してください
  1. // 入力PDFファイルを開く
  2. pInStream = _tfopen(szInPath, _T("rb"));
  3. GOTO_CLEANUP_IF_NULL_PRINT_ERROR(pInStream, _T("Failed to open the input file \"%s\" for reading.\n"), szInPath);
  4. TPdfToolsSys_StreamDescriptor inDesc;
  5. PdfToolsSysCreateFILEStreamDescriptor(&inDesc, pInStream, 0);
  6. pInDoc = PdfToolsPdf_Document_Open(&inDesc, _T(""));
  7. GOTO_CLEANUP_IF_NULL_PRINT_ERROR(
  8. pInDoc, _T("Failed to create a document from the input file \"%s\". %s (ErrorCode: 0x%08x).\n"), szInPath,
  9. szErrorBuff, PdfTools_GetLastError());
  10.  
  11. // 書き込み用の出力ストリームを生成
  12. pOutStream = _tfopen(szOutPath, _T("wb+"));
  13. GOTO_CLEANUP_IF_NULL_PRINT_ERROR(pOutStream, _T("Failed to open the output file \"%s\" for writing.\n"), szOutPath);
  14. TPdfToolsSys_StreamDescriptor outDesc;
  15. PdfToolsSysCreateFILEStreamDescriptor(&outDesc, pOutStream, 0);
  16.  
  17. // 最適化パラメータを定義するプロファイルを生成
  18. // Webプロファイルは、電子文書交換用に文書を最適化するのに適しています。
  19. pProfile = (TPdfToolsOptimizationProfiles_Profile*)PdfToolsOptimizationProfiles_Web_New();
  20.  
  21. // オプション:最適化プロセスの要件に応じてプロファイルのパラメータを変更できます。
  22.  
  23. // PDF文書を最適化
  24. pOptimizer = PdfToolsOptimization_Optimizer_New();
  25. pOutDoc = PdfToolsOptimization_Optimizer_OptimizeDocument(pOptimizer, pInDoc, &outDesc, pProfile, NULL);
  26. GOTO_CLEANUP_IF_NULL_PRINT_ERROR(pOutDoc, _T("The processing has failed. (ErrorCode: 0x%08x).\n"),
  27. PdfTools_GetLastError());
サンプル・プロジェクトの実行手順を参照してください
  1. private static void Optimize(string inPath, string outPath)
  2. {
  3. // 入力PDFファイルを開く
  4. using var inStr = File.OpenRead(inPath);
  5. using var inDoc = Document.Open(inStr);
  6.  
  7. // 最適化パラメータを定義するプロファイルを生成
  8. // Webプロファイルは、電子文書交換用に文書を最適化するのに適しています。
  9. var profile = new Profiles.Web();
  10.  
  11. // オプション:最適化プロセスの要件に応じてプロファイルのパラメータを変更できます。
  12.  
  13. // 出力ストリームを生成
  14. using var outStr = File.Create(outPath);
  15.  
  16. // PDF文書を最適化
  17. using var outDoc = new Optimizer().OptimizeDocument(inDoc, outStr, profile);
  18. }

お問い合わせ、ご質問、技術サポート

質問のページからお送りいただくようお願いします。
または、メールでsupport@trustss.co.jpあてにお送りください。


ご購入前の技術的質問も無償で対応します。サポート受付ページからお願いします。

> PDF Structure (PDF構成)

> PDF Imager-LP (画像化)

> PDF Stamper (電子印鑑)

> Pdftools SDK

- Pdftools SDKサンプルの利用手順
- Toolbox Add-on
> Pdftools SDK APIリファレンス