任意カーネルフィルタ
Namespace: fvalgcliAssembly: fvalgcli (in fvalgcli.dll) Version: 3.1.0.0 (3.1.0.11)
Syntax
C# |
---|
public static int fnFIE_kernel_filter( FHANDLE hsrc, FHANDLE hdst, F_FILTER_KERNEL_T_PTR kernel, f_border_mode border_mode, double border_value ) |
Visual Basic |
---|
Public Shared Function fnFIE_kernel_filter ( hsrc As FHANDLE, hdst As FHANDLE, kernel As F_FILTER_KERNEL_T_PTR, border_mode As f_border_mode, border_value As Double ) As Integer |
Parameters
- hsrc
- Type: fvalgcli..::..FHANDLE
入力画像ハンドル。(type :uc8, s16, us16, double)
- hdst
- Type: fvalgcli..::..FHANDLE
出力先画像ハンドル。(type: uc8, s16, us16, double) 入力画像と同じサイズ、タイプ、チャネル数で有ること。
- kernel
- Type: fvalgcli..::..F_FILTER_KERNEL_T_PTR
カーネル指定構造体のポインタ。
- border_mode
- Type: fvalgcli..::..f_border_mode
ボーダー処理モード。下記のいずれかを指定。- F_BORDER_NONE :ボーダー部分は処理しない
- F_BORDER_ZERO :0埋めモード
- F_BORDER_VALUE :一定値モード
- F_BORDER_CONTINUOUS :端延長モード
- F_BORDER_REPEAT :繰り返しモード
- F_BORDER_MIRROR1 :反転モード1
- F_BORDER_MIRROR2 :反転モード2
- border_value
- Type: System..::..Double
ボーダー濃度値。border_mode がF_BORDER_VALUEの場合のみ使用されます。 その他のモードの場合は、この値は無視されます。
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> /// 任意カーネルフィルタ. /// </summary> [FvPluginExecute] public void fnFIE_kernel_filter() { int status = (int)f_err.F_ERR_NONE; FHANDLE hsrc1 = FHANDLE.Zero; // 処理画像. FHANDLE hdst = FHANDLE.Zero; // 出力画像. F_FILTER_KERNEL_T_PTR kernel = IntPtr.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); int type = api.fnFIE_img_get_type(hsrc1); // 出力画像の生成. hdst = api.fnFIE_img_root_alloc(type, channels, width, height); // フィルタカーネル生成. kernel = F_FILTER_KERNEL_T_PTR.alloc(3, 3); for (int r = 0; r < 3; r++) for (int c = 0; c < 3; c++) kernel[r, c] = 1; kernel.denom = 9; kernel.anchor_x = 1; kernel.anchor_y = 1; // 処理の実行. status = api.fnFIE_kernel_filter(hsrc1, hdst, kernel, f_border_mode.F_BORDER_NONE, 0); // エラー判定. Assert.IsTrue(status == (int)f_err.F_ERR_NONE, "エラーが発生しました。({0})", (f_err)status); // 出力画像の保存. api.fnFIE_save_png(ResultDir + "/fnFIE_kernel_filter.png", hdst, -1); } finally { // オブジェクトの開放. hsrc1.Dispose(); hdst.Dispose(); kernel.Dispose(); } } } } |
Visual Basic | Copy |
---|---|
' $Revision: 1.1 $ Imports System.Collections.Generic Imports System.Text Imports fvalgcli Public Partial Class FIE ''' <summary> ''' 任意カーネルフィルタ. ''' </summary> <FvPluginExecute> _ Public Sub fnFIE_kernel_filter() Dim status As Integer = CInt(f_err.F_ERR_NONE) Dim hsrc1 As FHANDLE = FHANDLE.Zero ' 処理画像. Dim hdst As FHANDLE = FHANDLE.Zero ' 出力画像. Dim kernel As F_FILTER_KERNEL_T_PTR = IntPtr.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) Dim type As Integer = api.fnFIE_img_get_type(hsrc1) ' 出力画像の生成. hdst = api.fnFIE_img_root_alloc(type, channels, width, height) ' フィルタカーネル生成. kernel = F_FILTER_KERNEL_T_PTR.alloc(3, 3) For r As Integer = 0 To 2 For c As Integer = 0 To 2 kernel(r, c) = 1 Next Next kernel.denom = 9 kernel.anchor_x = 1 kernel.anchor_y = 1 ' 処理の実行. status = api.fnFIE_kernel_filter(hsrc1, hdst, kernel, f_border_mode.F_BORDER_NONE, 0) ' エラー判定. Assert.IsTrue(status = CInt(f_err.F_ERR_NONE), "エラーが発生しました。({0})", CType(status, f_err)) ' 出力画像の保存. api.fnFIE_save_png(ResultDir & "/fnFIE_kernel_filter.png", hdst, -1) Finally ' オブジェクトの開放. hsrc1.Dispose() hdst.Dispose() kernel.Dispose() End Try End Sub End Class |