IC Imaging Control (.NET C#/Visual Basic)

  • サンプルプログラムトップページ
  • デバイスのオープンとハンドリング
    • C# VB.NET カメラの映像を既存のアプリケーションに組み込む方法
    • C# VB.NET デバイスを開く
    • C# VB.NET デバイスの開閉
    • C# VB.NET ダイアログボックスを使用してデバイスを開く
    • C# VB.NET 複数のデバイスを開く
    • C# VB.NET デバイスのシリアル番号を読み取る
    • C# VB.NET ICImagingControlの標準プロパティダイアログの使用
    • C# VB.NET デバイスプロパティ設定の保存と復元
  • ライブ表示
    • C# VB.NET ライブ表示のリサイズ
    • C# VB.NET フルスクリーン表示
    • C# VB.NET 十字マークのオーバーレイ
    • C# VB.NET WFPでvideoWindowを使ったビデオ表示
  • フレームフィルタ
    • C# VB.NET 低輝度、高輝度ピクセルの強調 その1
    • C# VB.NET 低輝度、高輝度ピクセルの強調 その2
  • ライブ表示とマルチプロセス
    • C# VB.NET ライブ表示のみ
    • C# VB.NET 静止画保存
    • C# VB.NET 任意のタイミングで画像処理と静止画保存を同時に処理
    • C# VB.NET 録画しながら任意のタイミングで静止画保存
    • C# VB.NET 全フレームリアルタイム画像処理しながら
             NG判定を静止画保存
    • C# VB.NET 全フレームリアルタイム画像処理しながら
             NG判定を静止画保存、同時に録画
  • イメージの取得
    • C# VB.NET イメージデータの取得
    • C# VB.NET 静止画ファイル保存(BMP)
    • C# VB.NET 静止画ファイル保存(JPEG)
    • C# VB.NET 静止画ファイルの連番保存
    • C# VB.NET カメラ画像保存&FTPで任意のサーバーに転送する
    • C# VB.NET リングバッファを使用したイメージシーケンスの取得と再生
    • C# VB.NET 静止画とAVI動画保存
    • C# VB.NET メモリーレコーディング
             (高速カメラで撮影した現象をRAMメモリー領域に保存)
    • C# VB.NET ソフトウェアトリガーで画像を表示・保存
    • C# VB.NET 録画時間を指定したAVIファイル保存
    • C# VB.NET 外部トリガーで録画の開始
    • C# VB.NET 取得したイメージの輝度値をCSV形式で出力する
             (16bit対応)
  • 画像処理
    • C# VB.NET イメージデータへのアクセス
    • C# VB.NET コントラストの強調 - Part 1
    • C# VB.NET コントラストの強調 - Part 2
    • C# VB.NET コントラストの強調 - Part 3
    • C# VB.NET レーザーポインタの位置を特定する
    • C# VB.NET OpenCVの画像処理
             (アナログタコメーターのデジタル化)
    • C# VB.NET AIモデルを使ったリアルタイム処理
  • Version 3.5サンプル
    • C# VB.NET 関心領域の画像更新
      Advanced Image Processing
    • C# VB.NET 2値化
      Binarization
    • C# VB.NET 明るさの調整
      BrightnessProperty
    • C# VB.NET 動画保存(MediaStreamSink)
      Capturing a Video File
    • C# VB.NET 動画保存(AviStartCapture)
      Capturing an AVI File
    • C# VB.NET 共通ファイル
      Common
    • C# VB.NET オーバーレイの作成
      Creating an Overlay
    • C# VB.NET デモアプリ
      demoapp
    • C# VB.NET VCDプロパティ:GPIOプロパティ編
      DigitalIO
    • C# VB.NET コールバック関数を使ってバッファを表示させる
      Display Buffer
    • C# VB.NET フィルターの適用
      Filter Inspector
    • C# VB.NET 静止画をキャプチャし保存する
      Grabbing an Image
    • C# VB.NET イメージバッファの輝度値を読み込み、輝度反転処理を施す
      Image Processing
    • C# VB.NET VCDプロパティ:全プロパティ一覧を表示する編
      List VCDProperties
    • C# VB.NET デバイス設定ダイアログの作成
      Making Device Settings
    • C# VB.NET イメージバッファにアクセスする
      Pixelformat
    • C# VB.NET コーデックのプロパティを保存する
      Saving Codec Properties
    • C# VB.NET スクロールとズーム
      croll And Zoom
    • C# VB.NET VCDプロパティ:露光とゲイン編
      StandardProperties
    • C# VB.NET VCDプロパティ:ストロボアウト編
      Strobe
    • C# VB.NET VCDプロパティ:
             プロパティダイアログ画面のカスタマイズ編
      VCD Property Page
    • C# VB.NET VCDプロパティ:明るさとホワイトバランス編
      VCD Simple Property
    • C# VB.NET VCDプロパティ:オートフォーカス編
    • C# VB.NET デバイスの再接続方法とフレーム落ちの確認
  • リンク集

    ICImagingControl WEB APIリファレンスマニュアル/サンプルプログラム

    :日本語対応済み :日本語化準備中
    開発言語 APIリファレンスマニュアル サンプルプログラム
    C 4.0
    ()
    - - 4.0
    ()
    - -
    C++ 4.0
    ()
    3.5
    ()
    3.4
    ()
    4.0
    ()
    3.5 3.4
    ()
    C#/VB.NET 4.0
    ()
    3.5
    ()
    3.4
    ()
    4.0
    ()
    3.5
    ()
    3.4
    ()
    Python 4.0
    ()
    3.5 3.4
    ()
    4.0
    ()
    3.5 3.4
    ()

任意のタイミングで画像処理と静止画保存を同時に処理

概要

ICImagingControlを使用してTheImagingSourceのデバイスで取得できる映像をリアルタイムに表示しながら、任意のタイミングで画像処理を行い、画像処理結果を静止画保存するためのサンプルプログラムです。FrameSnapsinkがメインのAPIです。

処理内容とタイミング 1.ライブ表示のみ 2.静止画保存 3.任意のタイミングで画像処理と静止画保存を同時に処理 4.録画しながら任意のタイミングで静止画保存 5.全フレームリアルタイム画像処理しながら、NG判定を静止画保存 6.全フレームリアルタイム画像処理しながらNG判定を静止画保存、同時に録画
処理タイミング
  • 画像処理:任意
  • 静止画保存:任意
ライブ
表示
〇 LiveDisplay 〇 LiveDisplay 〇 LiveDisplay 〇 LiveDisplay - -
画像
処理
× × 〇 SnapSingle × - -
静止画
保存
× 〇 SnapSingle 〇 SnapSingle 〇 SetStringParameter
(FrameFilter)
- -
動画
保存
× × × 〇 LiveStart
(MediaStreamSink)
- -
処理タイミング
  • 画像処理:全フレーム
  • 静止画保存:画像処理後NG判定のもの
ライブ
表示
- - - - 〇 DisplayImageBuffer 〇 DisplayImageBuffer
画像
処理
- - - - 〇 FrameQueueSinkQueueSink 〇 FrameQueueSinkQueueSink
静止画
保存
- - - - 〇 SaveAsBitmap
(コールバック関数内で定義)
〇 SaveAsBitmap
(コールバック関数内で定義)
動画
保存
- - - - × 〇 Windows API
メインになる
ICImagingControl Sinkクラス
FrameNotificationSink FrameSnapsink FrameSnapsink MediaStreamSink FrameQueueSink FrameQueueSink
使用例 拡大観察してモニター表示しているものを作業者がモニターで目視チェック。 モニター表示による拡大観察と作業者による画像保存操作。 オフラインでの寸法測定と測定画像の保存。 オフラインでの寸法測定と測定画像の保存と作業内容の録画。 インラインの画像検査。NG判定画像保存でトレサビ管理。 インラインの画像検査。NG判定画像保存でトレサビ管理と、録画によるラインの監視。
sinkのオブジェクトが用意している
コールバック関数
有り
(コールバック関数はあるが全フレーム取得は保証されていない)
無し 無し 無し 有り 有り
Sinkの切り替え 無し 無し 無し 有り 無し 無し

サンプルプログラム

Software IC Imaging Control 3.5, Visual Studio™ 2019
サンプル(C#) multi_process3_cs_3.5.zip

サンプルツールの外観

フォームを立ち上げたときのイベント

private void Form1_Load(object sender, System.EventArgs e)
{
    // ディスプレイのサイズを調整
    icImagingControl1.LiveDisplayDefault = false;
    icImagingControl1.LiveDisplaySize = icImagingControl1.Size;

    icImagingControl1.Sink = new TIS.Imaging.FrameSnapSink();
}									

まず、ICImagingControlのコントロールパネルのサイズを合わせるためにLiveDisplayDefault プロパティでfalseに設定しています。 次にicImagingControl1コントロールのSinkプロパティに、新しいTIS.Imaging.FrameSnapSinkオブジェクトを設定します。これにより、FrameSnapSinkがフレームキャプチャを実行し、フレームを取得することが可能となります。

[デバイス選択 ShowDeviceSettingsDialog]ボタンをクリックしたときの処理

private void cmdSelectDevice_Click(object sender, EventArgs e)
{
    // The device settings dialog needs the live mode to be stopped
    if (icImagingControl1.LiveVideoRunning)
    {
        icImagingControl1.LiveStop();
    }

    // デバイスダイアログを表示する
    icImagingControl1.ShowDeviceSettingsDialog();
    icImagingControl1.LiveStart();
}

[デバイス選択 ShowDeviceSettingsDialog]ボタンをクリックしたときのイベントです。最初にライブモードが停止していること(LiveStartメソッドを呼んでいないこと)を確認するために、LiveVideoRunningプロパティを確認しています。ShowDeviceSettingsDialogメソッドを呼び出して、下図のようなデバイス設定ダイアログを表示し、ダイアログにてカメラの選択、ビデオフォーマットの設定、フレームレートの設定を行い、OKを押下してデバイス設定ダイアログを閉じます。その後、icImagingControl1.LiveStart();にてカメラのリアルタイムの映像を画面に表示します。

[プロパティ ShowPropertyDialog]ボタンをクリックしたときの処理

private void cmdShowOriginalDialog_Click(object sender, EventArgs e)
{
    icImagingControl1.ShowPropertyDialog();
}

[プロパティ ShowPropertyDialog]ボタンをクリックしたときのイベントです。下図のようなIC Imaging Controlのプロパティダイアログを表示します。プロパティダイアログには、カメラのゲイン、露光時間、ホワイトバランス、明るさ、コントラストなどのカメラの機能に関する設定が含まれており、それらの設定をプロパティダイアログ上で変更することができます。

[画面表示ON LiveDisplay=True]ボタンをクリックしたときの処理

private void cmdDisplayON_Click(object sender, EventArgs e)
{
    icImagingControl1.LiveStop();
    icImagingControl1.LiveDisplay = true;
    icImagingControl1.LiveStart();
}

[画面表示ON LiveDisplay=True]ボタンを押下したときのイベントです。フォーム上のICImagingControlのコントロール(画面上)にカメラの映像を表示させるか、または非表示にするか切り替えるために使用されます。LiveStartの呼び出し中は画面表示のON/OFFを切り替えることができないので、上記のようにまずLiveStopをしてライブストリーミングを停止し、LiveDisplayのプロパティにTrue/Falseを変更した後、LiveStartを再度呼び出しています。

[画面表示OFF LiveDisplay=False]ボタンをクリックしたときの処理

private void cmdDisplayOFF_Click(object sender, EventArgs e)
{
    icImagingControl1.LiveStop();
    icImagingControl1.LiveDisplay = false;
    icImagingControl1.LiveStart();
}

[画面表示OFF LiveDisplay=False]ボタンを押下したときのイベントです。フォーム上のICImagingControlのコントロール(画面上)にカメラの映像を表示させるか、または非表示にするか切り替えるために使用されます。LiveStartの呼び出し中は画面表示のON/OFFを切り替えることができないので、上記のようにまずLiveStopをしてライブストリーミングを停止し、LiveDisplayのプロパティにTrue/Falseを変更した後、LiveStartを再度呼び出しています。

[ライブスタート LiveStart(FrameSnapSink)]ボタンをクリックしたときの処理

private void cmdLiveStartFrameSnapSink_Click(object sender, EventArgs e)
{
    icImagingControl1.LiveStart();
}

上記はIC Imaging ControlのLiveStartを定義したものです。cmdLiveStartFrameSnapSink_Clickメソッドは、[ライブスタート LiveStart(FrameSnapSink)]ボタンがクリックされたときに呼び出されます。LiveStartメソッドは、カメラからのライブストリーミングを開始します。ライブストリーミングが開始されたかどうかは、画面右上部にあるカウンターがカウントアップしていることで確認できます。なお、LiveDisplay = falseの場合には画面上に映像が映りませんが、カメラからは画像フレームをPCに出力するという動作を開始しています。

[画像処理開始 SingleSnap]ボタンをクリックしたときの処理

private void btnSaveBMP_ImageProcess_Click(object sender, EventArgs e)
{
    TIS.Imaging.FrameSnapSink snapSink = icImagingControl1.Sink as TIS.Imaging.FrameSnapSink;
    TIS.Imaging.IFrameQueueBuffer frm = snapSink.SnapSingle(TimeSpan.FromSeconds(5));

    System.Drawing.Bitmap bmp = FrameExtensions.CreateBitmapCopy(frm);

    // 画像処理の例:輝度反転
    for (int y = 0; y < bmp.Height; y++)
    {
        for (int x = 0; x < bmp.Width; x++)
        {
            Color c = bmp.GetPixel(x, y);
            int r = 255 - c.R;
            int g = 255 - c.G;
            int b = 255 - c.B;
            bmp.SetPixel(x, y, Color.FromArgb(c.A, r, g, b));
        }
    }

    bmp.Save(""output.bmp"");
}

フレームをスナップショットし、ビットマップに変換してから、単純な画像処理を行い、最終的にビットマップを保存する処理を行っています。
まず、IC Imaging ControlのFrameSnapSinkオブジェクトを使用して、ビデオフレームを取得します。SnapSingleメソッドは、指定された時間内に1つのフレームをスナップショットするために使用されます。ここでは、5秒間待機してフレームをキャプチャしています。
次に、画像処理しやすい形式にするためにIFrameQueueBufferオブジェクトを取得し、FrameExtensions.CreateBitmapCopyメソッドを使用して、ビットマップ形式に変換します。CreateBitmapCopyメソッドは、IFrameQueueBufferオブジェクトを受け取り、それをSystem.Drawing.Bitmapオブジェクトに変換します。
System.Drawing.Bitmapオブジェクトになったところで、各ピクセルの色を反転させる単純な画像処理を行います(ビットマップの各ピクセルを反復処理して、その色のRGB値を255から減算して色合いを反転させています)。
最後に、処理されたビットマップをファイルに保存します。ここでは、output.bmpというファイル名を使用しています。
画像処理することで下記のように輝度値が反転した画像に変換することができます。

[ライブストップ LiveStop]ボタンをクリックしたときの処理

private void cmdLiveStopFrameSnapSink_Click(object sender, EventArgs e)
{
    icImagingControl1.LiveStop();
}

上記はIC Imaging ControlのLiveStopを定義したものです。cmdLiveStopFrameSnapSink_Clickメソッドは、[ライブストップ LiveStop]ボタンがクリックされたときに呼び出されます。LiveStopメソッドは、カメラからのライブストリーミングを停止します。

フレームカウントやフレームレートを記載する処理

画面右上にあるカメラから送られてくるフレーム数のカウントアップやフレーム落ちのカウントはDriverFrameDropInformationのプロパティを使っています。詳細については別のサンプルページにて解説を行っておりますので下記を参照ください。

https://www.argocorp.com/software/sdk/ICImagingControl/Sample_program/dotnet_35/reconnect-camera.html

▲ このページの先頭に戻る

Copyright © ARGO Corporation. All Rights Reserved.