PDF Tool APIサンプル集:カラーキーマスクの例
カラーキーマスクを追加したPDFを出力する
コンソールアプリケーションです
概要
引数に
1.PDFにする画像のパス
2.PDFの出力先となるファイルパス
を指定してカラーキーマスクを追加したPDFを出力する
コンソールアプリケーションです
1ページ目に「RGBの範囲指定」でカラーキーマスク指定し
範囲指定内の赤色をマスクした画像をPDFに変換して追加します
2ページ目に赤色(RGB)をカラーキーマスク指定し
マスクした画像をPDFに変換して追加しました
下の出力結果イメージでは
1P目は指定範囲内の赤色っぽい色々をマスクした画像のPDF化となり
2P目は赤色単色のみマスクした画像のPDF化となっています
コマンドラインでの実行例
sample.exe c:\test\test_09.bmp c:\sav\out.pdf
ダウンロード
出力結果イメージ
サンプルコード
/* Antenna House PDF Tool API 7.0 C# Interface sample program 概要:画像ファイルのPDF化(カラーキーマスク) Copyright 2022 Antenna House,Inc. */ using System; using PdfTkNet; namespace sample09cs { class Program { static void Main(string[] args) { Console.WriteLine("PDF Tool API V7.0 C# サンプル"); // 画像ファイルと出力ファイルの初期値を設定 string inFilePath = @"C:\test\test_09.bmp"; string outFilePath = @"C:\sav\out.pdf"; // 入力ファイル名 if (args.Length > 0) { inFilePath = args[0]; } // 出力ファイル名 if (args.Length > 1) { outFilePath = args[1]; } try { using (PtlParamInput inputImage = new PtlParamInput(inFilePath)) using (PtlParamOutput output = new PtlParamOutput(outFilePath)) using (PtlPDFDocument doc = new PtlPDFDocument()) using (PtlPages pages = doc.getPages()) { // マスクの色をRGBの範囲指定した場合のページを追加(1ページ目) // 画像のページ作成に使うパラメータクラス using (PtlParamImagePage paramImagePage = new PtlParamImagePage()) { // 画像の描画に使うパラメータクラス using (PtlParamDrawImage paramDrawImage = new PtlParamDrawImage()) { // 入力画像ストリームの設定 paramDrawImage.setImageStream(inputImage); // カラーキーマスクの色をRGBの範囲指定で設定する paramDrawImage.setColorKeyMaskColor(0.9f, 1.0f, 0.0f, 0.6f, 0.0f, 0.6f); // ページに挿入する画像パラメーターの設定。 paramImagePage.setImage(paramDrawImage); } // 用紙タイプの設定 PAPER_IMAGE_SIZE /* 画像サイズに合わせる */ paramImagePage.setPaperType(PtlParamImagePage.PAPER_TYPE.PAPER_IMAGE_SIZE); // ページの追加 pages.append(paramImagePage); } // マスクの色をRGBで指定した場合のページを追加(2ページ目) // 画像のページ作成に使うパラメータクラス using (PtlParamImagePage paramImagePage = new PtlParamImagePage()) { // 画像の描画に使うパラメータクラス using (PtlParamDrawImage paramDrawImage = new PtlParamDrawImage()) { // 入力画像ストリームの設定 paramDrawImage.setImageStream(inputImage); // 赤色のカラーキーマスクにする using (PtlColorDeviceRGB color = new PtlColorDeviceRGB(1.0f, 0.0f, 0.0f)) { paramDrawImage.setMaskColor(color, PtlParamDrawImage.MASK_TYPE.MASK_COLORKEY); } // ページに挿入する画像パラメーターの設定。 paramImagePage.setImage(paramDrawImage); } // 用紙タイプの設定 PAPER_IMAGE_SIZE /* 画像サイズに合わせる */ paramImagePage.setPaperType(PtlParamImagePage.PAPER_TYPE.PAPER_IMAGE_SIZE); // ページの追加 pages.append(paramImagePage); } doc.save(output); Console.WriteLine("-- 完了 --"); } } catch (PtlException pex) { Console.WriteLine(pex.getErrorCode() + " : " + pex.getErrorMessageJP()); pex.Dispose(); } catch (Exception ex) { Console.WriteLine(ex.Message); } } } }