局所平均値と標準偏差を用いてSauvola法による画像2値化
Namespace: fvalgcliAssembly: fvalgcli (in fvalgcli.dll) Version: 3.1.0.0 (3.1.0.11)
Syntax
C# |
---|
public static int fnFIE_sauvola_threshold(
FHANDLE hSrc,
FHANDLE hDst,
int iH,
int iV,
double dK,
double dR,
f_border_mode iBrdMod
) |
Visual Basic |
---|
Public Shared Function fnFIE_sauvola_threshold (
hSrc As FHANDLE,
hDst As FHANDLE,
iH As Integer,
iV As Integer,
dK As Double,
dR As Double,
iBrdMod As f_border_mode
) As Integer |
Parameters
- hSrc
- Type: fvalgcli..::..FHANDLE
入力画像 (type: uc8, us16, s16, float, double)
- hDst
- Type: fvalgcli..::..FHANDLE
出力2値画像 (type: bin)
- iH
- Type: System..::..Int32
局所領域の横サイズ( 1〜255 の奇数。但し iH と iV のどちらかは3以上でなければならない)
- iV
- Type: System..::..Int32
局所領域の縦サイズ( 1〜255 の奇数。但し iH と iV のどちらかは3以上でなければならない)
- dK
- Type: System..::..Double
計算式の k
- dR
- Type: System..::..Double
計算式の R ( 絶対値が1以上の値。但し、入力画像の型が double,float の場合は 0 以外を許容。 )
- iBrdMod
- Type: fvalgcli..::..f_border_mode
ボーダー処理モード
- F_BORDER_NONE ボーダー拡張しない
- F_BORDER_CONTINUOUS 端延長モード
- F_BORDER_MIRROR1 反転モード1
- F_BORDER_MIRROR2 反転モード1
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 |
---|
using System;
using System.Collections.Generic;
using System.Text;
using fvalgcli;
namespace TC
{
public partial class FIE
{
[FvPluginExecute]
public void fnFIE_sauvola_threshold()
{
int status = (int)f_err.F_ERR_NONE;
FHANDLE hsrc1 = FHANDLE.Zero;
FHANDLE hdst = 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_BIN, channels, width, height);
status = api.fnFIE_sauvola_threshold(hsrc1, hdst, 5, 7, 1.0, 10.0, f_border_mode.F_BORDER_NONE);
Assert.IsTrue(status == (int)f_err.F_ERR_NONE, "エラーが発生しました。({0})", (f_err)status);
api.fnFIE_save_png(ResultDir + "/fnFIE_sauvola_threshold.png", hdst, -1);
}
finally
{
hsrc1.Dispose();
hdst.Dispose();
}
}
}
} |
Visual Basic | Copy |
---|
Imports System.Collections.Generic
Imports System.Text
Imports fvalgcli
Public Partial Class FIE
<FvPluginExecute> _
Public Sub fnFIE_sauvola_threshold()
Dim status As Integer = CInt(f_err.F_ERR_NONE)
Dim hsrc1 As FHANDLE = FHANDLE.Zero
Dim hdst 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_BIN), channels, width, height)
status = api.fnFIE_sauvola_threshold(hsrc1, hdst, 5, 7, 1.0, 10.0, _
f_border_mode.F_BORDER_NONE)
Assert.IsTrue(status = CInt(f_err.F_ERR_NONE), "エラーが発生しました。({0})", CType(status, f_err))
api.fnFIE_save_png(ResultDir & "/fnFIE_sauvola_threshold.png", hdst, -1)
Finally
hsrc1.Dispose()
hdst.Dispose()
End Try
End Sub
End Class |
See Also