steger line/curve extraction filter
Namespace: fvalgcliAssembly: fvalgcli (in fvalgcli.dll) Version: 3.1.0.0 (3.1.0.11)
Syntax
C# |
---|
public static int fnFIE_steger_filter( FHANDLE fhSrc, FHANDLE fhDst, FHANDLE fhDir, double dSigma, double dThresh, f_line_detect_mode line_mode ) |
Visual Basic |
---|
Public Shared Function fnFIE_steger_filter ( fhSrc As FHANDLE, fhDst As FHANDLE, fhDir As FHANDLE, dSigma As Double, dThresh As Double, line_mode As f_line_detect_mode ) As Integer |
Parameters
- fhSrc
- Type: fvalgcli..::..FHANDLE
処理対象画像( type: uc8, s16, us16, double )
- fhDst
- Type: fvalgcli..::..FHANDLE
線強度画像( type: double )
- fhDir
- Type: fvalgcli..::..FHANDLE
線角度画像( type: s16 ) [0,16384]の範囲に正規化されます。
- dSigma
- Type: System..::..Double
ガウス微分時のσ(1.0以上)
- dThresh
- Type: System..::..Double
線強度の閾値(0.0以上)
- line_mode
- Type: fvalgcli..::..f_line_detect_mode
抽出する線の種類- F_RIDGE_MODE :輝度が周囲画素よりも高い線
- F_VALLEY_MODE :輝度が周囲画素よりも低い線
Return Value
Type: Int32以下のエラーコードを返します。
エラーコード:
f_err | 内容 |
---|---|
F_ERR_NONE | 正常終了 |
F_ERR_NOMEMORY | メモリ不足エラー |
F_ERR_INVALID_IMAGE | 画像オブジェクトの異常 |
F_ERR_INVALID_PARAM | パラメータ異常 |
F_ERR_NO_LICENCE | ライセンスエラー、または未初期化エラー |
Examples
C# | Copy |
---|---|
// $Revision: 1.1 $ using System; using System.Collections.Generic; using System.Text; using fvalgcli; namespace TC { public partial class FIE { /// <summary> /// steger line/curve extraction filter. /// </summary> [FvPluginExecute] public void fnFIE_steger_filter() { int status = (int)f_err.F_ERR_NONE; FHANDLE hsrc1 = FHANDLE.Zero; // 処理画像. FHANDLE hdst = FHANDLE.Zero; // 出力画像(線強度画像). FHANDLE hdir = FHANDLE.Zero; // 出力画像(線角度画像). try { // 入力画像ファイルのロード. api.fnFIE_load_img_file(TestImageDir + "/testdata/gray_04.bmp", ref hsrc1, f_color_img_type.F_COLOR_IMG_TYPE_UC8); // 入力画像の情報取得. int width = api.fnFIE_img_get_width(hsrc1); int height = api.fnFIE_img_get_height(hsrc1); int channels = api.fnFIE_img_get_channels(hsrc1); // 出力画像の生成. hdst = api.fnFIE_img_root_alloc((int)f_imgtype.F_IMG_DOUBLE, channels, width, height); hdir = api.fnFIE_img_root_alloc((int)f_imgtype.F_IMG_S16, channels, width, height); // 処理の実行. status = api.fnFIE_steger_filter(hsrc1, hdst, hdir, 1.5, 1, f_line_detect_mode.F_RIDGE_MODE); // エラー判定. Assert.IsTrue(status == (int)f_err.F_ERR_NONE, "エラーが発生しました。({0})", (f_err)status); // 線強度画像の保存 api.fnFIE_save_tiff(ResultDir + "/fnFIE_steger_filter_dst.tiff", hdst, f_tiff_compression.F_TIFF_COMPRESSION_NONE, 0); // 線角度画像の保存 api.fnFIE_save_tiff(ResultDir + "/fnFIE_steger_filter_dir.tiff", hdir, f_tiff_compression.F_TIFF_COMPRESSION_NONE, 0); } finally { // オブジェクトの開放. hsrc1.Dispose(); hdst.Dispose(); hdir.Dispose(); } } } } |
Visual Basic | Copy |
---|---|
' $Revision: 1.1 $ Imports System.Collections.Generic Imports System.Text Imports fvalgcli Public Partial Class FIE ''' <summary> ''' steger line/curve extraction filter. ''' </summary> <FvPluginExecute> _ Public Sub fnFIE_steger_filter() Dim status As Integer = CInt(f_err.F_ERR_NONE) Dim hsrc1 As FHANDLE = FHANDLE.Zero ' 処理画像. Dim hdst As FHANDLE = FHANDLE.Zero ' 出力画像(線強度画像). Dim hdir As FHANDLE = FHANDLE.Zero ' 出力画像(線角度画像). Try ' 入力画像ファイルのロード. api.fnFIE_load_img_file(TestImageDir & "/testdata/gray_04.bmp", hsrc1, f_color_img_type.F_COLOR_IMG_TYPE_UC8) ' 入力画像の情報取得. Dim width As Integer = api.fnFIE_img_get_width(hsrc1) Dim height As Integer = api.fnFIE_img_get_height(hsrc1) Dim channels As Integer = api.fnFIE_img_get_channels(hsrc1) ' 出力画像の生成. hdst = api.fnFIE_img_root_alloc(CInt(f_imgtype.F_IMG_DOUBLE), channels, width, height) hdir = api.fnFIE_img_root_alloc(CInt(f_imgtype.F_IMG_S16), channels, width, height) ' 処理の実行. status = api.fnFIE_steger_filter(hsrc1, hdst, hdir, 1.5, 1, f_line_detect_mode.F_RIDGE_MODE) ' エラー判定. Assert.IsTrue(status = CInt(f_err.F_ERR_NONE), "エラーが発生しました。({0})", CType(status, f_err)) ' 線強度画像の保存 api.fnFIE_save_tiff(ResultDir & "/fnFIE_steger_filter_dst.tiff", hdst, f_tiff_compression.F_TIFF_COMPRESSION_NONE, 0) ' 線角度画像の保存 api.fnFIE_save_tiff(ResultDir & "/fnFIE_steger_filter_dir.tiff", hdir, f_tiff_compression.F_TIFF_COMPRESSION_NONE, 0) Finally ' オブジェクトの開放. hsrc1.Dispose() hdst.Dispose() hdir.Dispose() End Try End Sub End Class |