C#与Halcon联合(9)自制多功能halcon窗体

1.窗体功能

①按比例显示图像,不填充拉伸
②可鼠标拖动图像移动,滚轮缩放
③可显示图像十字叉辅助显示
④可以显示鼠标位于窗体位置的坐标及图像灰度值
⑤可以保存当前窗体中显示的图像
⑥可以对窗体进行截图
⑦可以插入halcon窗体中的obj 与 msg ,并显示

2.使用windows窗体控件库,制作该halcon多功能窗体

①新建一个控件库项目
在这里插入图片描述
②添加右键菜单
在这里插入图片描述
③部分代码展示–代码过多就不完全展示了
底下有库,及其测试程序,自己酌情下载,绝对物超所值,可直接用于项目

        //放入显示的图片
        public void SetImage(HObject ho_Image)
        {
            HOperatorSet.SetWindowParam(this.HalconWindow, "background_color", "gray");
            HOperatorSet.GenEmptyObj(out myImage);
            myImage.Dispose();
            myImage = ho_Image;

            //副图像
            HOperatorSet.GenEmptyObj(out extraImage);
            extraImage.Dispose();
            extraImage = ho_Image;

            //掩膜图像
            HOperatorSet.GenEmptyObj(out maskImage);
            maskImage.Dispose();
            maskImage = ho_Image;

            //清空擦除恢复区域
            region_removeds = null;

            if (myImage != null)
            {
                HTuple width, height;
                HOperatorSet.GetImageSize(myImage, out width, out height);
                if (width.I != myImageWidth || height.I != myImageHeight)
                {
                    myImageWidth = width;
                    myImageHeight = height;
                    GetWindowExtents();
                }
            }


            //显示辅助线
            if (ShowAuxiliaryline.Checked)
            {
                HOperatorSet.GenEmptyObj(out region);
                region.Dispose();
                HOperatorSet.GenRectangle1(out region, (HTuple)0, (HTuple)0, myImageHeight, myImageWidth);
                HObject vLine, hLine;
                HOperatorSet.GenContourPolygonXld(out vLine, new HTuple().TupleConcat(0).TupleConcat(myImageHeight.I), new HTuple()
    .TupleConcat((HTuple)((double)myImageWidth.I * 0.5)).TupleConcat((HTuple)((double)myImageWidth.I * 0.5)));

                HOperatorSet.ConcatObj(vLine, region, out region);
                HOperatorSet.GenContourPolygonXld(out hLine, new HTuple().TupleConcat((HTuple)((double)myImageHeight.I * 0.5))
                    .TupleConcat((HTuple)((double)myImageHeight.I * 0.5)), new HTuple().TupleConcat(0).TupleConcat(myImageWidth.I));
                HOperatorSet.ConcatObj(region, hLine, out region);
            }
            else
            {
                HOperatorSet.GenEmptyObj(out region);
                region.Dispose();
                HOperatorSet.GenRectangle1(out region, (HTuple)0, (HTuple)0, myImageHeight, myImageWidth);
            }

            //如果橡皮擦依旧开着
            if (bEraser || bRecover)
            {
                HObject eraserObj;
                HOperatorSet.GenEmptyObj(out eraserObj);
                eraserObj.Dispose();
                HOperatorSet.GenRectangle1(out eraserObj, windowTop - (eraserSize / 2), windowLeft - (eraserSize / 2)
                    , windowTop + (eraserSize / 2), windowLeft + (eraserSize / 2));

                eraserIndex = AddObj(eraserObj, "red", false);
                eraserObjClearFlag = true;
            }
        }

        private void GetWindowExtents()
        {
            HTuple win_Width, win_Height, win_Col, win_Row, cwin_Width, cwin_Height;
            HOperatorSet.GetWindowExtents(this.HalconWindow, out win_Row, out win_Col, out win_Width, out win_Height);//获取窗体大小规格
            basicWHeight = win_Height;
            basicWWidth = win_Width;
            cwin_Height = 1.0 * win_Height / win_Width * myImageWidth;//宽不变计算高          
            if (cwin_Height > myImageHeight)//宽不变高能容纳
            {
                cwin_Height = 1.0 * (cwin_Height - myImageHeight) / 2;
                windowTop = -cwin_Height;
                windowLeft = 0;
                windowBottom = cwin_Height + myImageHeight;
                windowRight = myImageWidth;
            }
            else//高不变宽能容纳
            {
                cwin_Width = 1.0 * win_Width / win_Height * myImageHeight;//高不变计算宽
                cwin_Width = 1.0 * (cwin_Width - myImageWidth) / 2;

                windowTop = 0;
                windowLeft = -cwin_Width;
                windowBottom = myImageHeight;
                windowRight = cwin_Width + myImageWidth;
            }
        }



        //添加事件
        public void AddObject(HObject ho_Object, string ho_Color, bool ho_FillMode = false)
        {
            AddObj(ho_Object, ho_Color, ho_FillMode);
        }

        //添加文字
        public void AddMessage(string ho_Content, bool ho_FontInWin, string ho_FontColor, HTuple ho_Size, HTuple ho_Row, HTuple ho_Col, string ho_BackColor = "", bool ho_BackColorEnable = false)
        {
            AddMsg(ho_Content, ho_FontInWin, ho_FontColor, ho_Size, ho_Row, ho_Col, ho_BackColor, ho_BackColorEnable);
        }

3.效果展示–图像与操作说明

①点击加载图像按键,之后自制的多功能窗体会加载图像
图像显示是按照比例显示的,不会被拉伸;
在这里插入图片描述
②拖动图像,点击右键菜单选择DragImage,勾选上即可拖动图像,
不想拖动就取消勾选即可;
在这里插入图片描述
图像被拖动之后;
在这里插入图片描述
③缩小和放大图像,鼠标在多功能窗体内,滑动滚轮即可,向上放大,向下缩小;

放大图像;
在这里插入图片描述
图像缩小;
在这里插入图片描述
④当拖动或者放大缩小图像,导致图像不知道跑到哪了,这时候
对准窗体,右键选择FitWindow(自适应)即可还原图像
在这里插入图片描述
⑤显示十字叉辅助线,点击右键选择ShowAuxiliaryline,勾选上,即可看到效果
不需要了可以再次点击,取消勾选

在这里插入图片描述
⑥显示鼠标在窗体坐标位置及该位置下图像对应的灰度值
点击右键,勾选上ShowImageGray,不需要取消勾选即可
在这里插入图片描述
勾选之后,该显示会跟随鼠标的移动
在这里插入图片描述

⑦图像保存–右键点击SaveImage,即可保存当前窗体中的图片,图片格式为bmp
在这里插入图片描述
在这里插入图片描述
保存之后,查看确实是存在777.bmp
在这里插入图片描述⑧保存截屏,右键选择MenuItem_SaveCapture,
即可保存当前窗体的截屏,图像格式为bmp
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
⑨添加obj事件
可以随意添加obj,闭合的obj也可以选择显示的模式-填充显示还是非填充显示,
比如ROI区域,封闭但是自带填充,这时候,选择不填充显示比较好

        private void button3_Click(object sender, EventArgs e)
        {
            HObject ho_Obj = null;
            HOperatorSet.GenRegionLine(out ho_Obj,double.Parse(txb_oriRow.Text) , double.Parse(txb_oriCol.Text), double.Parse( txb_EndRow.Text), double.Parse(txb_EndCol.Text));
            mcHWindow1.AddObject(ho_Obj,txb_color.Text,false);
            mcHWindow1.FlushWindow();
        }

将mcHWindow1.AddObject(ho_Obj,txb_color.Text,false);中的false改成true就是填充显示了
第一个参数就是要显示的obj
第二个参数就是obj显示的颜色
第三个参数就是显示的模式,true为填充显示,false为轮廓显示

在这里插入图片描述

⑩显示文本–使用AddMessage函数即可添加文本

        private void button4_Click(object sender, EventArgs e)
        {
            mcHWindow1.AddMessage(txb_string.Text,true,"green",int.Parse(txb_size.Text),0,0,txb_backColor.Text,ckb_backColor.Checked);
            mcHWindow1.FlushWindow();         
        }

mcHWindow1.AddMessage(txb_string.Text,true,“green”,int.Parse(txb_size.Text),0,0,txb_backColor.Text,ckb_backColor.Checked);
第一个参数为显示的文本内容
第二个参数为默认在窗体中显示
第三个参数为,文字的颜色
第四个参数,文字的大小
第五个参数,文字在窗体上的坐标,以左上角(0,0)为基准
第六个参数,背景颜色
第七个参数,背景显示使能,true为显示背景,false为不显示背景

在这里插入图片描述

4.如何使用自制的halcon多功能窗体

直接将mcHControl.dll拖到工具箱中,就会出现控件mcHWindow
在这里插入图片描述
同时将mcHControl.dll放到项目的debug\bin文件下,添加引用即可使用
在这里插入图片描述

5.视频展示链接与测试代码链接

视频链接:
https://www.bilibili.com/video/BV1AL4y1z7sF?spm_id_from=333.999.0.0

代码链接:
https://download.csdn.net/download/adsd1233123/34650662

  • 4
    点赞
  • 68
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
要在 C# 中实现 Halcon 窗口的橡皮擦功能,你可以使用 Halcon 的交互操作函数来实现。 首先,你需要为 Halcon 窗口添加鼠标事件处理程序,以便捕获鼠标移动和点击的事件。你可以使用 HMouse 的事件来实现此功能。 ```csharp // 引入 Halcon 的命名空间 using HalconDotNet; // 创建一个 HWindowControl 对象 HWindowControl hWindowControl = new HWindowControl(); // 在窗体中添加 HWindowControl 控件 this.Controls.Add(hWindowControl); // 激活 Halcon 窗口 HOperatorSet.OpenWindow(0, 0, hWindowControl.Width, hWindowControl.Height, hWindowControl.HalconID, "", "", out HTuple windowHandle); // 添加鼠标事件处理程序 hWindowControl.HMouseDown += HWindowControl_HMouseDown; hWindowControl.HMouseMove += HWindowControl_HMouseMove; hWindowControl.HMouseUp += HWindowControl_HMouseUp; // 鼠标按下事件处理程序 private void HWindowControl_HMouseDown(object sender, HMouseEventArgs e) { if (e.Button == MouseButtons.Left) { // 获取鼠标点击的位置 int row = e.Y; int column = e.X; // 在指定位置绘制橡皮擦 HOperatorSet.SetDraw(hWindowControl.HalconID, "margin"); HOperatorSet.SetColor(hWindowControl.HalconID, "white"); HOperatorSet.SetLineWidth(hWindowControl.HalconID, 10); HOperatorSet.DispCircle(hWindowControl.HalconID, row, column, 5); } } // 鼠标移动事件处理程序 private void HWindowControl_HMouseMove(object sender, HMouseEventArgs e) { if (e.Button == MouseButtons.Left) { // 获取鼠标当前位置 int row = e.Y; int column = e.X; // 在指定位置绘制橡皮擦 HOperatorSet.SetDraw(hWindowControl.HalconID, "margin"); HOperatorSet.SetColor(hWindowControl.HalconID, "white"); HOperatorSet.SetLineWidth(hWindowControl.HalconID, 10); HOperatorSet.DispCircle(hWindowControl.HalconID, row, column, 5); } } // 鼠标释放事件处理程序 private void HWindowControl_HMouseUp(object sender, HMouseEventArgs e) { // 清除橡皮擦绘制 HOperatorSet.ClearWindow(hWindowControl.HalconID); } ``` 上述代码中,我们通过捕获鼠标的按下、移动和释放事件,在 Halcon 窗口中绘制橡皮擦。当鼠标按下时,在指定位置绘制一个白色的圆形,当鼠标移动时,根据当前位置继续绘制圆形,当鼠标释放时,清除窗口中的橡皮擦绘制。 希望以上代码能帮到你!如果还有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱搞事的程小猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值