REGION間AND演算
Namespace: fvalgcliAssembly: fvalgcli (in fvalgcli.dll) Version: 3.1.0.0 (3.1.0.11)
Syntax
C# |
---|
public static int fnFIE_region_and(
FHANDLE hsrc1,
FHANDLE hsrc2,
ref FHANDLE hdst
) |
Visual Basic |
---|
Public Shared Function fnFIE_region_and (
hsrc1 As FHANDLE,
hsrc2 As FHANDLE,
ByRef hdst As FHANDLE
) As Integer |
Return Value
Type:
Int32
以下のエラーコードを返します。
エラーコード:f_err | 内容 |
---|
F_ERR_NONE | 正常終了 |
F_ERR_NOMEMORY | メモリ不足エラー |
F_ERR_INVALID_OBJECT | 不正なハンドル |
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_region_and()
{
FHANDLE himage1 = FHANDLE.Zero;
FHANDLE himage2 = FHANDLE.Zero;
FHANDLE himaged = FHANDLE.Zero;
FHANDLE hregion1 = FHANDLE.Zero;
FHANDLE hregion2 = FHANDLE.Zero;
FHANDLE hRegion = FHANDLE.Zero;
FHANDLE hFill = FHANDLE.Zero;
FHANDLE htemp = FHANDLE.Zero;
try
{
api.fnFIE_load_img_file(TestImageDir + "/TC/SampleCode/blob_BIN.png", ref himage1, f_color_img_type.F_COLOR_IMG_TYPE_UC8);
api.fnFIE_load_img_file(TestImageDir + "/TC/SampleCode/blob_BIN_2.png", ref himage2, f_color_img_type.F_COLOR_IMG_TYPE_UC8);
Assert.IsTrue(himage1 != FHANDLE.Zero, "himage1 が異常です.");
Assert.IsTrue(himage2 != FHANDLE.Zero, "himage2 が異常です.");
int width = api.fnFIE_img_get_width(himage1);
int height = api.fnFIE_img_get_height(himage1);
int type = api.fnFIE_img_get_type(himage1);
int channels = api.fnFIE_img_get_channels(himage1);
himaged = api.fnFIE_img_root_alloc(type, channels, width, height);
api.fnFIE_img_and(himage1, himage2, himaged);
PNT_T offset = new PNT_T();
offset.x = 0;
offset.y = 0;
hregion1 = fnFIE_region_encode(himage1, offset);
hregion2 = fnFIE_region_encode(himage2, offset);
api.fnFIE_region_and(hregion1, hregion2, ref hRegion);
fnFIE_region_fill(hRegion, ref hFill);
fnFIE_region_set_connection(hRegion);
fnFIE_region_set_runlength(hRegion);
fnFIE_region_get_area(hRegion);
fnFIE_region_get_center(hRegion);
fnFIE_region_get_distance_to_boundary(hRegion);
fnFIE_region_get_equivalent_ellipse(hRegion);
fnFIE_region_get_maxminpos(hRegion);
fnFIE_region_get_moment1(hRegion);
fnFIE_region_get_moment2(hRegion);
fnFIE_region_get_perimeter(hRegion);
fnFIE_region_get_rect1_area(hRegion);
fnFIE_region_get_rect1_lratio(hRegion);
fnFIE_region_get_rect1_sratio(hRegion);
fnFIE_region_get_rect2_area(hRegion);
fnFIE_region_get_rect2_lratio(hRegion);
fnFIE_region_get_rect2_size(hRegion);
fnFIE_region_get_rect2_sratio(hRegion);
fnFIE_region_get_runlength(hRegion);
fnFIE_region_get_xydiff(hRegion);
fnFIE_region_get_xyrange(hRegion);
}
finally
{
himage1.Dispose();
himage2.Dispose();
himaged.Dispose();
hRegion.Dispose();
hFill.Dispose();
hregion1.Dispose();
hregion2.Dispose();
htemp.Dispose();
}
}
}
} |
Visual Basic | Copy |
---|
Imports System.Collections.Generic
Imports System.Text
Imports fvalgcli
Public Partial Class FIE
<FvPluginExecute> _
Public Sub fnFIE_region_and()
Dim himage1 As FHANDLE = FHANDLE.Zero
Dim himage2 As FHANDLE = FHANDLE.Zero
Dim himaged As FHANDLE = FHANDLE.Zero
Dim hregion1 As FHANDLE = FHANDLE.Zero
Dim hregion2 As FHANDLE = FHANDLE.Zero
Dim hRegion As FHANDLE = FHANDLE.Zero
Dim hFill As FHANDLE = FHANDLE.Zero
Dim htemp As FHANDLE = FHANDLE.Zero
Try
api.fnFIE_load_img_file(TestImageDir & "/TC/SampleCode/blob_BIN.png", himage1, f_color_img_type.F_COLOR_IMG_TYPE_UC8)
api.fnFIE_load_img_file(TestImageDir & "/TC/SampleCode/blob_BIN_2.png", himage2, f_color_img_type.F_COLOR_IMG_TYPE_UC8)
Assert.IsTrue(himage1 <> FHANDLE.Zero, "himage1 が異常です.")
Assert.IsTrue(himage2 <> FHANDLE.Zero, "himage2 が異常です.")
Dim width As Integer = api.fnFIE_img_get_width(himage1)
Dim height As Integer = api.fnFIE_img_get_height(himage1)
Dim type As Integer = api.fnFIE_img_get_type(himage1)
Dim channels As Integer = api.fnFIE_img_get_channels(himage1)
himaged = api.fnFIE_img_root_alloc(type, channels, width, height)
api.fnFIE_img_and(himage1, himage2, himaged)
Dim offset As New PNT_T()
offset.x = 0
offset.y = 0
hregion1 = fnFIE_region_encode(himage1, offset)
hregion2 = fnFIE_region_encode(himage2, offset)
api.fnFIE_region_and(hregion1, hregion2, hRegion)
fnFIE_region_fill(hRegion, hFill)
fnFIE_region_set_connection(hRegion)
fnFIE_region_set_runlength(hRegion)
fnFIE_region_get_area(hRegion)
fnFIE_region_get_center(hRegion)
fnFIE_region_get_distance_to_boundary(hRegion)
fnFIE_region_get_equivalent_ellipse(hRegion)
fnFIE_region_get_maxminpos(hRegion)
fnFIE_region_get_moment1(hRegion)
fnFIE_region_get_moment2(hRegion)
fnFIE_region_get_perimeter(hRegion)
fnFIE_region_get_rect1_area(hRegion)
fnFIE_region_get_rect1_lratio(hRegion)
fnFIE_region_get_rect1_sratio(hRegion)
fnFIE_region_get_rect2_area(hRegion)
fnFIE_region_get_rect2_lratio(hRegion)
fnFIE_region_get_rect2_size(hRegion)
fnFIE_region_get_rect2_sratio(hRegion)
fnFIE_region_get_runlength(hRegion)
fnFIE_region_get_xydiff(hRegion)
fnFIE_region_get_xyrange(hRegion)
Finally
himage1.Dispose()
himage2.Dispose()
himaged.Dispose()
hRegion.Dispose()
hFill.Dispose()
hregion1.Dispose()
hregion2.Dispose()
htemp.Dispose()
End Try
End Sub
End Class |
See Also