c#面积识别

HObject ho_Image, ho_GrayImage, ho_Regions;
HObject ho_RegionFillUp, ho_ConnectedRegions, ho_SelectedRegions;

// Local control variables 

HTuple hv_WindowID = null, hv_Width = null;
HTuple hv_Height = null, hv_Area = null, hv_Row = null;
HTuple hv_Column = null;

int i = 0;

private void button1_Click(object sender, EventArgs e)
{
    if (HDevWindowStack.IsOpen())
    {
        HOperatorSet.CloseWindow(HDevWindowStack.Pop());
    }

   
        HOperatorSet.GenEmptyObj(out ho_Image);
        string ImagePath;
        openFileDialog1.Filter = "图片文件|*.jpg;*.bmp;*.gif;*.png;*.jpeg";
        openFileDialog1.RestoreDirectory = true;//选择路径

        if (openFileDialog1.ShowDialog() == DialogResult.OK)
        {
            ImagePath = openFileDialog1.FileName;
            ho_Image.Dispose();
            HOperatorSet.ReadImage(out ho_Image, ImagePath);
            HOperatorSet.GetImageSize(ho_Image, out hv_Width, out hv_Height);
            HOperatorSet.OpenWindow(0, 0, hWindowControl1.Width, hWindowControl1.Height, hWindowControl1.HalconWindow, "visible", "", out hv_WindowID);
            HDevWindowStack.Push(hv_WindowID);
        }

        if (HDevWindowStack.IsOpen())
        {
            HOperatorSet.SetPart(HDevWindowStack.GetActive(), 0, 0, hv_Height, hv_Width);
        }


    if (HDevWindowStack.IsOpen())
    {
        HOperatorSet.DispObj(ho_Image, HDevWindowStack.GetActive());
    }
   


}

private void button2_Click(object sender, EventArgs e)
{
    HOperatorSet.GenEmptyObj(out ho_GrayImage);
    HOperatorSet.GenEmptyObj(out ho_Regions);
    HOperatorSet.GenEmptyObj(out ho_RegionFillUp);
    HOperatorSet.GenEmptyObj(out ho_ConnectedRegions);
    HOperatorSet.GenEmptyObj(out ho_SelectedRegions);


    ho_GrayImage.Dispose();
    HOperatorSet.Rgb1ToGray(ho_Image, out ho_GrayImage);
    ho_Regions.Dispose();
    HOperatorSet.Threshold(ho_GrayImage, out ho_Regions, 38, 167);
    ho_RegionFillUp.Dispose();
    HOperatorSet.FillUp(ho_Regions, out ho_RegionFillUp);
    ho_ConnectedRegions.Dispose();
    HOperatorSet.Connection(ho_RegionFillUp, out ho_ConnectedRegions);
    ho_SelectedRegions.Dispose();
    HOperatorSet.SelectShape(ho_ConnectedRegions, out ho_SelectedRegions, "area",
        "and", 32194, 43322.7);
    HOperatorSet.AreaCenter(ho_SelectedRegions, out hv_Area, out hv_Row, out hv_Column);

    ho_Image.Dispose();
    ho_GrayImage.Dispose();
    ho_Regions.Dispose();
    ho_RegionFillUp.Dispose();
    ho_ConnectedRegions.Dispose();
    ho_SelectedRegions.Dispose();

    textBox1.Text = "面积:" + hv_Area + "," + "坐标:(" + hv_Row + "," + hv_Column + ")";
   
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值