Visionpro二次开发学习笔记8-如何将静态或交互式图形添加到CogDisplay中

news2024/11/16 0:00:56

如何将静态或交互式图形添加到CogDisplay中

CogDisplay支持两种类型的图形:静态图形和交互式图形。静态图形一旦添加到显示中,就无法移动或更改。静态图形不能添加提示文本(TipText)。

交互式图形在启用图形的交互属性时,可以通过程序或用户进行移动或更改。可以在交互式图形中添加提示文本。以下示例展示了如何添加提示文本。

以下步骤展示了如何将静态或交互式图形添加到CogDisplay中。

界面设计如下,添加CogDisplay控件用于显示图像,添加几个按钮用来添加图形:

在这里插入图片描述

具体步骤如下:

1. 添加引用

using Cognex.VisionPro;
using Cognex.VisionPro.Display;

2. 声明枚举

        public enum GraphicInteractivityLevel { 
                eNonInteractive=0,
                eNonSelectable=1,
                eFullyInteractive=2
            }

3. 加载默认图像

        private void Form9_Load(object sender, EventArgs e)
                {
                    cogDisplay1.Image = SyntheticImage();
                }

        private CogImage8Grey SyntheticImage()
        {
            CogImage8Grey blackImage = new CogImage8Grey();
            blackImage.Allocate(200,200);

            for (int i = 0; i < blackImage.Width; i++)
            {
                for (int j = 0; j < blackImage.Height; j++)
                {
                    blackImage.SetPixel(i,j,128);
                }
            }
            return blackImage;
        }

4. 添加交互式图形

1. 创建一个形状。本示例使用了CogEllipse。
2. 从交互形状中检索CogGraphicInteractive接口。
3. 设置图形的自由度属性。
4. 将形状添加到交互图形集合中以显示它。
        private void AddInteractive(CogColorConstants color, GraphicInteractivityLevel interactivityLevel) {
            // 1. 创建一个CogEllipse形状
            CogEllipse cogEllipse = new CogEllipse();

            if (cogDisplay1.InteractiveGraphics.Count==0)
            {
                //第一个交互图形在坐标(0,0)
                cogEllipse.CenterX = 0;
                cogEllipse.CenterY = 0;
            }
            else
            {
                //后续图形在前一个图形偏移(50,50)处
                CogEllipse previousEllipse = (CogEllipse)cogDisplay1.InteractiveGraphics[cogDisplay1.InteractiveGraphics.Count - 1];
                cogEllipse.CenterX = previousEllipse.CenterX + 50;
                cogEllipse.CenterY = previousEllipse.CenterY + 50;
            }

            // 添加提示文本。当鼠标悬停在图形上时,将显示此提示文本

            cogEllipse.TipText = $"交互式图形{cogEllipse.CenterX/50}";

            // 设置图形颜色
            cogEllipse.Color = color;

            // 2. 从交互形状中检索CogGraphicInteractive接口
            // 一些图形属性仅通过通用接口访问
            ICogGraphicInteractive graphicInteractive = cogEllipse;

            // 3. 设置图形的自由度(DOF)属性。
            // 没有机制可以使交互图形不可选择,而不使其非交互式
            // 如果所选颜色与未选颜色相同,则它们都显示为不可选择
            cogEllipse.Interactive = interactivityLevel > GraphicInteractivityLevel.eNonInteractive;
            if (interactivityLevel>GraphicInteractivityLevel.eNonSelectable)
            {
                cogEllipse.GraphicDOFEnable = CogEllipseDOFConstants.All;

            }
            else
            {
                graphicInteractive.SelectedColor = cogEllipse.Color;
                graphicInteractive.GraphicDOFEnableBase = CogGraphicDOFConstants.None;
            }

            // 根据其交互级别绘制图形的线样式和鼠标光标
            // 请参见CogStandardCursorConstants以获取所有支持的光标类型
            // 请参见CogGraphicLineStyleConstants以获取所有支持的线样式
            switch (interactivityLevel)
            {
                case GraphicInteractivityLevel.eNonInteractive:
                    //没有特殊光标
                    cogEllipse.LineStyle = CogGraphicLineStyleConstants.Dot;
                    break;
                case GraphicInteractivityLevel.eNonSelectable:
                    graphicInteractive.MouseCursor = CogStandardCursorConstants.TipTextGraphic;
                    cogEllipse.LineStyle = CogGraphicLineStyleConstants.Dash;
                    graphicInteractive.SelectedLineStyle = CogGraphicLineStyleConstants.Dash;
                    break;
                case GraphicInteractivityLevel.eFullyInteractive:
                    graphicInteractive.MouseCursor = CogStandardCursorConstants.ManipulableGraphic;
                    cogEllipse.LineStyle = CogGraphicLineStyleConstants.Solid;
                    graphicInteractive.DragLineStyle = CogGraphicLineStyleConstants.Solid;
                    break;
                default:
                    MessageBox.Show("Unrecognized interactivity level.");
                    break;
            }
            // 4. 将形状添加到交互图形集合以进行显示
            cogDisplay1.InteractiveGraphics.Add(cogEllipse,"test",false);
        }

        private void AddNonInteractive_Click(object sender, EventArgs e)
        {
            AddInteractive(CogColorConstants.Red,GraphicInteractivityLevel.eNonInteractive);
        }

        private void AddNonSelectable_Click(object sender, EventArgs e)
        {
            AddInteractive(CogColorConstants.Yellow,GraphicInteractivityLevel.eNonSelectable);
        }

        private void AddFullyInteractive_Click(object sender, EventArgs e)
        {
            AddInteractive(CogColorConstants.Green,GraphicInteractivityLevel.eFullyInteractive);
        }

5. 添加静态图形

  1. 创建一个形状。本示例使用了CogRectangleAffine
  2. 将形状添加到静态图形集合中以显示它
        double staticPositionX = 0, staticPositionY = 0;
        private void AddStatic_Click(object sender, EventArgs e)
        {
             // 初始化坐标
            if (cogDisplay1.StaticGraphics.ZOrderGroups.Count == 0)
            {
                staticPositionX = 0;
                staticPositionY = 0;
            }

            //创建静态图形
            CogRectangleAffine staticGraphic = new CogRectangleAffine();

            //设置图形属性
            staticGraphic.CenterX = staticPositionX;
            staticGraphic.CenterY = staticPositionY;

            staticGraphic.TipText = "Static graphics don't support tiptext!!!";

            staticGraphic.Color = CogColorConstants.Orange;

            staticGraphic.LineWidthInScreenPixels *= 3;
            //添加图形到显示控件
            cogDisplay1.StaticGraphics.Add(staticGraphic,"test");
            //更新坐标
            staticPositionX += 50;
            staticPositionY += 50;
        }

6. 删除所有图形

        private void RemoveGraphics_Click(object sender, EventArgs e)
            {
                cogDisplay1.StaticGraphics.Clear();
                while (cogDisplay1.InteractiveGraphics.Count>0)
                {
                    cogDisplay1.InteractiveGraphics.Remove(0);
                }
            }

7. 界面效果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1993779.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【数据结构】-----二叉搜索树(C++)

目录 前言 一、是什么 ​编辑 二、实现 Ⅰ、结点类 Ⅱ、结构及基本接口实现 ​编辑 ①插入 ②查找 ③删除(重难点) 情况一&#xff1a;待删除结点为叶子结点(无孩子) 情况二&#xff1a;待删除结点存在一个孩子结点(可能左/右) 情况三&#xff1a;待删除结点存在…

【iOS】—— 事件传递链和响应者链总结

事件传递链和响应者链总结 1. 事件传递链&#xff1a;事件传递链&#xff1a;传递流程&#xff1a;总结第一响应者&#xff1a; 2. 响应者链响应者链传递流程总结响应者链流程 总结&#xff1a; 之前也学习过这个内容这次在复习的时候&#xff0c;就想着写一下总结&#xff1a;…

Linux部署python3.0版本——及基本操作

&#xff08;一&#xff09;部署环境 首先查看列表&#xff0c;找到python3.0的包 yum list installed|grep python 如果没有&#xff0c;是因为yum源的问题&#xff0c;可部署阿里云镜像然后下载epel包&#xff0c;这里的内容可参考前面的阿里云镜像部署 然后进行下载 yum…

TensorRT-LLM中的 Quantization GEMM(Ampere Mixed GEMM)的 CUTLASS 2.x 实现讲解

在LLM的推理和部署中&#xff0c;低精度量化对于性能的提升十分关键&#xff0c;本次分享将为大家介绍TRT-LLM中是如何基于CUTLASS 2.x来实现PerChannel/AWQ/SmoothQuant等量化方法在模型推理过程的计算。Slides来自BiliBili NVIDIA英伟达频道 上传的《TensorRT-LLM中的 Quanti…

最新CSS3伪类和伪元素详解

第4章 伪类和伪元素 4.1结构伪类 E:first-child{},第一个元素 样式&#xff1a; p:first-child {color: red; } <div><p>Lorem ipsum</p><p>Dolor sit amet.</p> </div> 4.1.1nth-*伪类 以计数为基础的&#xff0c;默认情况下&…

某赛通电子文档安全管理系统 CDGAuthoriseTempletService1 SQL注入漏洞复现(XVE-2024-19611)

0x01 产品简介 某赛通电子文档安全管理系统(简称:CDG)是一款电子文档安全加密软件,该系统利用驱动层透明加密技术,通过对电子文档的加密保护,防止内部员工泄密和外部人员非法窃取企业核心重要数据资产,对电子文档进行全生命周期防护,系统具有透明加密、主动加密、智能…

RPA在政务服务中的挑战与解决方案

随着数字化时代的到来&#xff0c;数字政务的建设已成必然趋势&#xff0c;RPA作为数字化转型的重要工具之一&#xff0c;能够帮助政府单位快速实现业务流程的自动化和智能化&#xff0c;提高工作效率和质量&#xff0c;为建设数字政务提供强有力的支持&#xff0c;因此正被越来…

深植根基、蓬勃向上 | openKylin 2.0正式发布!

2024年8月8日&#xff0c;openKylin 2.0版本正式发布&#xff01;该版本默认搭载Linux 6.6 LTS内核&#xff0c;完成180操作系统核心组件自主选型升级&#xff0c;深度融合AI技术&#xff0c;上线麒麟AI助手等实用AI功能&#xff0c;并为用户带来包括开明软件包格式、不可变系统…

Unity 在Editor下保存对Text组件的文本的修改

Unity 在Editor下保存对Text组件的文本的修改 /****************************************************文件&#xff1a;TimeStampForText.cs作者&#xff1a;lenovo邮箱: 日期&#xff1a;2024/8/8 1:9:21功能&#xff1a; *************************************************…

聚观早报 | 小米15 Ultra相机规格;一加Ace 5参数规格

聚观早报每日整理最值得关注的行业重点事件&#xff0c;帮助大家及时了解最新行业动态&#xff0c;每日读报&#xff0c;就读聚观365资讯简报。 整理丨Cutie 8月8日消息 小米15 Ultra相机规格 一加Ace 5参数规格 iOS 18.1代码曝光 SK电讯加大AI投入 Figure 02 人形机器人…

【VScode】如何在anaconda虚拟环境中打开vscode项目

文章目录 【必备知识】打开anaconda虚拟环境切换到项目工作目录激活anaconda虚拟路径让vscode从当前目录打开 【必备知识】 anaconda环境变量配置及配置python虚拟环境 https://blog.csdn.net/xzzteach/article/details/140621596 打开anaconda虚拟环境 切换到项目工作目录 …

Ftrans文件摆渡方案:重塑文件传输与管控的科技先锋

一、哪些行业会用到文件摆渡相关方案 文件摆渡相关的产品和方案通常用于需要在不同的网络、安全域、网段之间传输数据的场景&#xff0c;主要是一些有核心数据需要保护的行业&#xff0c;做了网络隔离和划分。以下是一些应用比较普遍的行业&#xff1a; 金融行业&#xff1a;…

第 11 课:多方安全计算在安全核对的行业实践

业务背景&#xff1a;安全核对产生的土壤 产品方案&#xff1a;从试点到规模化的路 技术共建&#xff1a;与隐语的共同成长

three.js 空间坐标绘制多边形围栏(结合react)

空间坐标点绘制多边形&#xff0c;实际上可以理解为是由 “点” 到 “线” 到 “面” 的一个过程。将空间坐标点通过THREE.Shape绘制多条线并闭合而得到一个封闭的二维形状平面对象&#xff0c;使用THREE.ShapeGeometry将Shape对象转换为Geometry对象添加Mesh&#xff0c;最终得…

全国多地公布2024下半年软考报名具体时间

下半年开考科目&#xff1a; 高级资格&#xff1a;系统分析师、系统架构设计师、网络规划设计师、系统规划与管理师 中级资格&#xff1a;软件设计师、网络工程师、信息安全工程师、信息系统监理师、多媒体应用设计师、系统集成项目管理工程师 初级资格&#xff1a;网络管理…

【时时三省】(C语言基础)操作符2

山不在高&#xff0c;有仙则名。水不在深&#xff0c;有龙则灵。 ——csdn时时三省 赋值操作符 它可以重新赋值 示例: 使用赋值操作符赋值 复合赋值符 &#xff0b;&#xff1d; -&#xff1d; &#xff0a;&#xff1d; /&#xff1d; &#xff05;&#xff1d; &g…

Linux磁盘管理_LVM逻辑卷_SWAP交换分区_Centos-LVM格式磁盘扩容

目录 一、基本磁盘管理1.1 创建分区1.2 创建文件系统1.3 挂载mount1.4 查看挂载信息1.5 重启失效解决方式 二、逻辑卷LVM2.1 LVM2.2 创建LVM2.3 扩大卷组VG2.4 命令汇总 三、交换分区SWAP管理3.1 SWAP3.2 查看swap3.3 增加交换分区 四、Centos调整分区&#xff0c;在线调整分区…

05 数据类型

目录 分类数值类型小数类型字符串类型日期和时间类型集合类型 1. 分类 2. 数值类型 tinyint create table t1 (num tinyint); insert into t1 values (1); insert into t1 values (128); – 越界插入&#xff0c;报错 select * from t1; 说明: 在mysql中&#xff0c;整形可以指…

LeetCode面试150——14最长公共前缀

题目难度&#xff1a;简单 默认优化目标&#xff1a;最小化平均时间复杂度。 Python默认为Python3。 目录 1 题目描述 2 题目解析 3 算法原理及代码实现 3.1 横向扫描 3.2 纵向扫描 3.3 分治 3.4 二分查找 参考文献 1 题目描述 编写一个函数来查找字符串数组中的最长…

MyBatis 基本操作 - 注解版

目录 一&#xff0c;查询 - select 1.1 全列查询 1.2 指定列查询 1.3 赋值问题 方法一&#xff1a;起别名 方法二&#xff1a;结果映射 方法三&#xff1a;添加配置 二&#xff0c;新增 - Insert 2.1 使用对象插入 2.2 获取主键 三&#xff0c;删除 - Delete 四&am…