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
    ()

コントラストの強調 - Part 1

概要

ICImagingControlを使ってどのようにイメージデータにアクセスするかを示しています。

サンプルプログラム

Software IC Imaging Control 3.5, Visual Studio™ 2019
サンプル(C#) contrast_enhancement1_cs_3.5.zip
サンプル(VB.NET) contrast_enhancement1_vb_3.5.zip
関連ファイル contrast_enhancement_vc7_framefilter_3.5.zip
※ダイアログ画面に関してプラットフォームはx86のみ対応

サンプルツールの外観

このサンプルでは、"Contrast Enhancement"フレームフィルタを使用します。

このフィルタはここでダウンロードできるサンプルに含んでおり、そのファイル名は ContrastEnhancement.FTF です。

"Contrast Enhancement"はイメージデータのヒストグラムを広げコントラストを強調する画像処理を行います。ピクセル輝度値は0 ~ 255の間で上限と下限を設定する事ができます。
これら上限・下限の設定はこのフレームフィルタのパラメータとして設定する事ができます。ここで設定した下限値よりも暗いピクセル輝度は0とされ、また上限値より明るいピクセル輝度は255とされます。また、Enabledチェックボックスにより、このフィルタのOn/Offが可能です。

private TIS.Imaging.FrameFilter filter;
Dim filter As TIS.Imaging.FrameFilter

ここで利用しているフレームフィルタのプロジェクトもダウンロードが可能ですが、ここで示しているサンプルはあくまでもこのフィルタを部品として使用しているため、使用者はその内容を理解する必要がありません。
まずTIS.Imaging.FrameFilterタイプの変数filterをForm1の中で宣言する必要があります。
この変数にはフレームフィルタとその接続が含まれます。

private void Form1_Load(object sender, System.EventArgs e)
{
    icImagingControl1.ShowDeviceSettingsDialog();
    if (!icImagingControl1.DeviceValid)
        return;

    try
    {
        filter = icImagingControl1.FrameFilterCreate("ContrastEnhancement", "");
        // ICのデバイスパスにフレームフィルタを挿入します
        icImagingControl1.DeviceFrameFilters.Add(filter);
        // フィルタをEnableにします
        cbEnable.Checked = true;
        // Enableチェックボックスを初期化します
        filter.SetBoolParameter("Enable", cbEnable.Checked);
        icImagingControl1.LiveStart();
    }
    catch(Exception ex)
    {
        MessageBox.Show("Failed to load the frame filter!");
    }
} 
Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
    IcImagingControl1.ShowDeviceSettingsDialog()
    If Not IcImagingControl1.DeviceValid Then
        'Unload(Me)
        Exit Sub
    End If


    Try
        filter = IcImagingControl1.FrameFilterCreate("ContrastEnhancement", "")
        ' ICのデバイスパスにフレームフィルタを挿入します
        IcImagingControl1.DeviceFrameFilters.Add(filter)
        ' フィルタをEnableにします
        cbEnable.Checked = True
        ' Enableチェックボックスを初期化します
        filter.SetBoolParameter("Enable", cbEnable.Checked)
        IcImagingControl1.LiveStart()
    Catch ex As System.Exception
        MessageBox.Show("Failed to load the frame filter!")
    End Try

End Sub

プログラム開始時、icImagingControl1.ShowDeviceSettingsDialogを使用してデバイス選択ダイアログを表示します。 デバイスが正しく選択されたら、次にIcImagingControl1.FrameFilterCreateをコールして"ContrastEnhancement"をロードします。例外エラーをハンドリングするため、フレームフィルタのロードは try..catchブロックでラップしてください。

フレームフィルタがロードされたらICImagingControlのデバイスパスに挿入して、パラメータ"Enabled"をtrueにセットします。icImagingControl1.LiveStartをコールしてライブストリームを開始します。

private void cbEnable_CheckedChanged(object sender, System.EventArgs e)
{
    filter.BeginParameterTransfer();
    filter.SetBoolParameter("Enable", cbEnable.Checked);
    filter.EndParameterTransfer();
}
Private Sub cbEnable_CheckedChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles cbEnable.CheckedChanged
    filter.BeginParameterTransfer()
    filter.SetBoolParameter("Enable", cbEnable.Checked)
    filter.EndParameterTransfer()
End Sub

フィルタはチェックボックスcbEnableでスイッチできます。

private void btParameter_Click(object sender, System.EventArgs e)
{
    filter.ShowDialog();
    if (filter.GetBoolParameter("Enable"))
        cbEnable.Checked = true;
    else
        cbEnable.Checked = false;

}
Private Sub btParameter_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btParameter.Click
    filter.ShowDialog()
    If filter.GetBoolParameter("Enable") Then
        cbEnable.Checked = True
    Else
        cbEnable.Checked = False
    End If
End Sub

メソッド filter.ShowDialogでこのフィルタがもつ設定ダイアログを表示でき、上限値、下限値の設定ができます。ダイアログが閉じられると、チェックボックスcbEnableはフィルタパラメータのEnableチェックボックスと同期されます。

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

Copyright © ARGO Corporation. All Rights Reserved.