VisionPro二次开发学习笔记4-使用C#创建绘图图形

VisionPro提供了许多可以添加到CogDisplay的基本形状,例如CogCircle,CogRectangle,CogEllipse和CogRectangleAffine。这些形状可以是用户可以用鼠标操作的交互式图形,也可以是用户无法更改的静态形状。

若要在CogDisplay控件上绘制图形,您需要在Visual Studio.NET应用程序中添加对Cognex.VisionPro,Cognex.VisionPro.Core和Cognex.VisionPro.Display.Controls程序集的引用。

绘制图形

以下编程语句创建CogRectangle和CogCircle的实例,设置其属性,并将其添加到CogDisplay控件。

  1. 添加引用
csharp 复制代码
using Cognex.VisionPro;
using Cognex.VisionPro.Display;
  1. 声明变量
csharp 复制代码
CogRectangle cgRect;
CogCircle cgCirc;
  1. 创建图形对象

    csharp 复制代码
    cgRect = new CogRectangle();
    cgCirc = new CogCircle();
    • cgRect 是一个矩形对象的实例,cgCirc 是一个圆对象的实例。这两个对象都是 Cognex VisionPro 中用于图形表示的类。
  2. 设置矩形的属性

    csharp 复制代码
    cgRect.X = 150;
    cgRect.Y = 150;
    cgRect.Color = CogColorConstants.Green;
    cgRect.SelectedSpaceName = "*";
    cgRect.Interactive = true;
    • cgRect.XcgRect.Y:设置矩形的左上角坐标为 (150, 150)。
    • cgRect.Color:设置矩形的颜色为绿色。
    • cgRect.SelectedSpaceName:设置为 "*",表示该图形可以在任何坐标空间中选择。
    • cgRect.Interactive:设置为 true,表示该矩形是交互式的,用户可以与之进行交互。
  3. 设置矩形的交互属性

    csharp 复制代码
    cgRect.GraphicDOFEnable = CogRectangleDOFConstants.Size;
    • GraphicDOFEnable:设置用户可以交互的属性,这里指定用户只能改变矩形的大小,而不能移动其位置或改变其他属性。
  4. 设置圆的属性

    csharp 复制代码
    cgCirc.CenterX = 220;
    cgCirc.CenterY = 220;
    cgCirc.Color = CogColorConstants.Blue;
    cgCirc.SelectedSpaceName = "*";
    cgCirc.Interactive = true;
    • cgCirc.CenterXcgCirc.CenterY:设置圆的中心坐标为 (220, 220)。
    • cgCirc.Color:设置圆的颜色为蓝色。
    • cgCirc.SelectedSpaceName:与矩形类似,表示该圆也可以在任何坐标空间中选择。
    • cgCirc.Interactive:设置为 true,表示该圆是交互式的。
  5. 设置圆的交互属性

    csharp 复制代码
    cgCirc.GraphicDOFEnable = CogCircleDOFConstants.Radius;
    • GraphicDOFEnable:这里指定用户只能改变圆的半径,而不能移动其中心或改变其他属性。
  6. 将图形添加到显示控件

    csharp 复制代码
    cogDisplay1.InteractiveGraphics.Add(cgCirc, null, false);
    cogDisplay1.InteractiveGraphics.Add(cgRect, null, false);
    • cogDisplay1.InteractiveGraphics.Add:将创建的圆和矩形添加到 cogDisplay1 控件的交互图形列表中。第二个参数为 null,表示不指定图形的标签,第三个参数为 false,表示不自动更新图形。

总结

这个方法的作用是初始化两个图形(一个矩形和一个圆),并将它们添加到一个显示控件中,使得用户可以通过鼠标交互来调整这些图形的大小(矩形)和半径(圆)。通过设置颜色、交互属性和允许的交互方式,提供了一个用户友好的图形界面,便于用户进行视觉化操作。

相关推荐
CoovallyAIHub11 分钟前
让Qwen-VL的检测能力像YOLO一样强,VLM-FO1如何打通大模型的视觉任督二脉
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
突破跨模态识别瓶颈!火箭军工程大学提出MFENet:让AI在白天黑夜都能准确识人
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
TypeScript超越Python,以66%增速跃升第一,Python稳居AI领域王座
深度学习·算法·计算机视觉
XINVRY-FPGA1 小时前
5CEFA9F23I7N Altera CycloneV E(Enhanced)FPGA
人工智能·嵌入式硬件·计算机视觉·fpga开发·硬件工程·dsp开发·fpga
王哈哈^_^2 小时前
【完整源码+数据集】车牌数据集,yolov8车牌检测数据集 7811 张,汽车车牌识别数据集,智慧交通汽车车牌识别系统实战教程
人工智能·深度学习·yolo·目标检测·计算机视觉·毕业设计·智慧城市
mudtools2 小时前
.NET驾驭Excel之力:Excel应用程序的创建与管理
c#·.net·excel·wps
mudtools2 小时前
.NET驾驭Excel之力:自动化数据处理 - 开篇概述与环境准备
c#·自动化·.net·excel·wps
唐青枫2 小时前
C#.NET WebAPI 返回类型深度解析:IActionResult 与 ActionResult<T> 的区别与应用
c#·.net
gorgeous(๑>؂<๑)11 小时前
【ICLR26匿名投稿】OneTrackerV2:统一多模态目标跟踪的“通才”模型
人工智能·机器学习·计算机视觉·目标跟踪
William_cl12 小时前
C# ASP.NET MVC 数据验证实战:View 层双保险(Html.ValidationMessageFor + jQuery Validate)
后端·c#·asp.net·mvc