[机器视觉]halcon应用实例 用户自定义多ROI模板匹配

news2025/1/21 14:10:34

        本示在前面几个halcon ROI示例的基础上继续扩展,更靠进实标情况。为了使ROI匹配更灵活,就要求可以让用户或工程根据实际使用情况自己去画ROI,想画几个是几个。数量不能在代码里写死。

        这次升级的主要是增加了一个while循环根据用户的鼠标按键来进行判断是否继续画,还是退出画ROI。

效果

代码

dev_set_color ('red')
dev_set_draw ('margin')
*获取窗口句柄对象
dev_get_window (WindowHandle)
*读取图片
read_image (Image, 'E:/stevenChen/机器视觉学习/HDevelop/视觉图片/ROI/1.bmp')

*生成一个空区域
gen_empty_region (ROIRegion)

dev_disp_text ('开始绘制ROI区域', 'window', 'top', 'left', 'green', [], [])
*选取ROI
mbutton := 1

while(mbutton == 1)
    *画矩形
    *参数说明
    *WindowHandle (输入参数)窗口句柄
    *Row, Column (输出参数)矩形的中心坐标
    draw_rectangle2 (WindowHandle, Row, Column, Phi, Length1, Length2)
    *生成矩形
*根据上面算子的输出参数生成一个矩形
*Rectangle 输出参数,生成的矩形
*Row1, Column1 (输入参数)矩形的左上角坐标
*Row2, Column2 (输入参数)矩形的右上角坐标
    gen_rectangle2 (Rectangle2, Row, Column, Phi, Length1, Length2)
    *连接两个对象,ObjectsConcat = [Objects1,Objects2]
*参数列表:
*第1个参数Objects1是输入对象,即对象1
*第2个参数Objects2是输入变量,即对象2
*第3个参数ObjectsConcat是输出变量,即连接后的区域
    concat_obj (ROIRegion, Rectangle2, ROIRegion)
    
    *获取鼠标按键,按下鼠标左键 继续绘制,按下鼠标右键结束绘制
    get_mbutton (WindowHandle, Row1, Column1, mbutton)
endwhile


*把所有的输入区域合并为一个区域
*功能:函数将Region元组内的全部区域合并成一个独立的区域,保存于RegionUnion
*参数:
*Region (input_object) ——要计算其并集的区域,也就是一个个的输入区域
*RegionUnion (output_object) ——所有输出区域的并集
            *要素数: RegionUnion <= Region
union1 (ROIRegion, RegionUnion)

*锁定ROI并创建模板
*单ROI
*获得特定区域Region位置的图像,获取区域图像
*Image (输入参数)输入的图像
*Rectangle 输入参数)输入的区域,上面画的矩形区域
*ImageReduced (输出参数)输出的图像,是Image中Rectangle的那部分图像
reduce_domain (Image, RegionUnion, ImageReduced)
*用于创建形状模板
*形状模板是一种用于检测和匹配特定形状的工具,常用于目标识别、物体定位和测量等应用中。
*参数说明:
*ObjectModel:包含待创建模板的形状的二值图像。
*NumLevels:金字塔层数,用于多尺度匹配。可设为“auto”或0—10的整数
*AngleStart:起始角度(以度为单位),用于模板的旋转范围。rad(-180)
*AngleExtent:旋转角度的范围(以度为单位)。rad(-180), rad(180)表示360度匹配
*AngleStep:旋转角度的步长,可以是’auto’或具体的值。
*ScaleMin:最小缩放比例。
*ScaleMax:最大缩放比例。
*ScaleStep:缩放比例的步长。
*Optimization:优化模式,用于加速模板匹配。
*Metric:模板匹配的度量方式。
*Contrast:对比度增强系数。
*MinContrast:最小对比度阈值。
*ModelID:输出的模板ID。
*https://blog.csdn.net/xiaogongzhu001/article/details/131120014
*1.NumLevels(金字塔的层数),金字塔的层数越大,找到匹配使用的时间就越小。(金字塔的层数越大,提取到的特征越少,精准度越低,所以对应的识别时间少)
*如果金字塔的层数设置的太大,模板不容易识别出来,这是需要将find_shape_model函数中MinScore和Greediness参数设置的低一些。
*参数解析及优化 https://blog.csdn.net/the_future_way/article/details/115345989
*create_shape_model (ImageReduced, 'auto', rad(0), rad(360), 'auto', 'auto', 'use_polarity', 'auto', 'auto', ModelID)
create_shape_model (ImageReduced, 'auto', rad(-180), rad(180), 'auto', 'auto', 'use_polarity', 'auto', 'auto', ModelID)
*-----模板创建结束----------------------------------

*-----开始测试----------------------------------------------
*4.加载测试图像
read_image (Image1, 'E:/stevenChen/机器视觉学习/HDevelop/视觉图片/ROI/120.bmp')

*5.使用已有模板句柄来匹配
*形状模板匹配
*形状匹配原理:模板创建后,会根据模板中的边缘等关系去图像中进行搜索,可以理解成提取模板中的灰度发生变化的那些点,
*然后再去图像中匹配,这样的效果是对干扰比较稳定,匹配速度快,并且即使边缘发生部分遮挡,匹配效果依旧较好
*参数说明
*参数1:输入图像--单通道图像
*参数2:模板句柄
*参数3:搜索时的起始角度 rad(-180), rad(180) 正好是一圈
*参数4:搜索时的终止角度,必须与创建模板时的有交集 
*参数5:被找到的模板最小分数--大于等于这个值才能被匹配
*      默认值:0.5      建议值:0.3,0.4,0.5,0.6,0.7,0.8,0.9,1.0
*      典型值范围:0≤MinScore ≤ 1
*      最小增量:0.01       建议增量:0.05
*参数6:要找到的模板最大实例数
*参数7:要找到的模型实例的最大重叠
*      默认值:0.5       建议值:0.0,0.1,0.2,0.3,0.4,0.5,0.6,0.7,0.8,0.9,1.0
*      典型值范围:0≤ MaxOverlap≤ 1      最小增量:0.01     建议增量:0.05
*参数8:计算精度的设置
*        'none', 'interpolation', 'least_squares', 'least_squares_high', 'least_squares_very_high'
*        'max_deformation 1', 'max_deformation 2', 'max_deformation 3', 'max_deformation 4'
*        'max_deformation 5', 'max_deformation 6'
*参数9:搜索时金字塔的层级
*参数10:贪婪度,搜索启发式,一般都设为0.8,越高速度快,容易出现找不到的情况
*       0≤ Greediness ≤ 1   
*最后4个:输出匹配位置的行和列坐标、角度、得分 【中心坐标】
*https://blog.51cto.com/liming19680104/5152387
*find_shape_model (Image1, ModelID, rad(0), rad(360), 0.5, 1, 0.5, 'least_squares', 0, 0.9, Row, Column, Angle, Score)
find_shape_model (Image1, ModelID, rad(-180), rad(180), 0.5, 1, 0.5, 'least_squares', 0, 0.9, Row, Column, Angle, Score)

*6.把匹配轮廓显示到图像中
*ModelContours 输出参数,匹配到的模块轮廓,
*ModelID 输入参数,模板ID,
*Level 金字塔层数
get_shape_model_contours(ModelContours, ModelID, 1)
*从点和角度计算刚性仿射变换
*参数:
*Row1 (输入参数) ——原始点的行坐标
*Column1 (输入参数) ——原始点的列坐标
*Angle1 (输入参数) ——原始点的角度
*Row2 (输入参数) ——转换点的行坐标
*Column2 (输入参数) ——转换点的列坐标
*Angle2 (输入参数) ——转换点的角度
*HomMat2D (输出参数) ——输出转换矩阵
*原文链接:https://blog.csdn.net/m0_51271525/article/details/121017373
vector_angle_to_rigid (0, 0, 0, Row, Column, Angle, HomMat2D)
*仿射变换轮廓
*对XLD轮廓进行任意仿射2D变换
*将任意仿射2D变换,即缩放、旋转、平移和倾斜(倾斜)应用于轮廓中给定的xld轮廓,并以ContoursAffineTrans的形式返回变换后的轮廓
*参数:
*Contours (输入参数) ——输入XLD轮廓。
*ContoursAffineTrans (输出参数) ——转换后的XLD轮廓
*HomMat2D (输入参数) ——输入转换矩阵
affine_trans_contour_xld (ModelContours, ContoursAffineTrans, HomMat2D)

*显示结果
dev_display (Image)
dev_set_color ('green')
dev_display (ContoursAffineTrans)

*释放模板句柄
clear_shape_model (ModelID)

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

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

相关文章

入门LLMs开发 — LangChain

像OpenAI的GPT-4这样的大型语言模型&#xff08;LLMs&#xff09;已经风靡全球。它们可以自动执行各种任务&#xff0c;如回答问题、翻译语言、分析文本等。LLMs是第一种真正感觉像“人工智能”的机器学习类型。 然而&#xff0c;在将LLMs应用于实际产品时仍然存在挑战。特别是…

2 月 27 日算法练习-动态规划

思路&#xff1a;没用完全背包优化的动态规划只能O(n^3)只能过 40% #include<bits/stdc.h> using namespace std; const int N 5e37; const int mod 1e97; string s; int len; int num[N],dp[N][N];int solve(int need,int flag){memset(num, 0, sizeof(num));memset(…

C打印内存16进制

下面是一段C代码打印16进制 void print_hex(const char *msg, void *addr, int len) {uint8_t *p (uint8_t *)addr;printf("%s ,stat:%0x8, len:%d\n", msg, addr, len);for (int i 0; i < len / 16; i) {printf("0x%08x: ", p i * 16);for (int j …

微服务:Feign篇

1.什么是Feign Feign是一种声明式、模板化的HTTP客户端&#xff0c;可用于调用HTTP API实现微服务之间的远程服务调用。它的特点是使用少量的配置定义服务客户端接口&#xff0c;可以实现简单和可重用的RPC调用。 先来看我们以前利用RestTemplate发起远程调用的代码&#xff…

30天JS挑战(第十二天)------输入序列验证

第十二天挑战(输入序列验证) 地址&#xff1a;https://javascript30.com/ 所有内容均上传至gitee&#xff0c;答案不唯一&#xff0c;仅代表本人思路 中文详解&#xff1a;https://github.com/soyaine/JavaScript30 该详解是Soyaine及其团队整理编撰的&#xff0c;是对源代…

Golang 开发实战day02 - Print Formatting

Golang 教程02 - Print&#xff0c;Formatting Strings Go语言提供了丰富的格式化字符串功能&#xff0c;用于将数据格式化为特定格式的字符串。本课程将详细介绍Go语言中Print和Formatting Strings的用法&#xff0c;并提供代码示例供大家参考。 Print 类型及使用 1.Print …

ruoyi-vue-plus4.X版本实现内嵌swagger文档(简单解决方法)

1.在common模块中添加pom依赖 <dependency><groupId>org.webjars</groupId><artifactId>swagger-ui</artifactId><version>4.15.5</version></dependency>结果如下&#xff1a; 2.在ResourcesConfig配置类的addResourceHandl…

【前端】Vite打包页面简单部署到GitHub上

创建仓库---->上传代码---->设置 注意点已经打上箭头,代码我传到的是test分支 vite打包的配置如图&#xff0c;base是仓库名称&#xff0c;docs是build后生成的打包目录。 上传到GitHub就自动部署了 访问就是第一张图里的一串地址&#xff0c;这种方式比较方便吧

「项目实践」如何实现导购推荐“千人千面”

前言 在电商背景下&#xff0c;为用户提供精准的导购推荐不仅能极大提升购物体验&#xff0c;也成为推动业务增长的关键驱动力。随着人工智能和数据科学的快速发展&#xff0c;实现“千人千面”的个性化推荐已不再是无法触及的梦想。如何在众多商品中准确捕捉用户的偏好&#…

计算机网络-第3章 数据链路层

主要内容&#xff1a;两个信道及对应的协议&#xff1a;点对点信道和广播信道&#xff0c;扩展以太网和高速以太网 本章的分组转发为局域网内的转发&#xff0c;不经过路由&#xff0c;网络层分组转为为网络与网络之间的转发&#xff0c;经过路由。局域网属于网络链路层的范围…

maven打包失败 Cannot create resource output directory[已解决]

文章目录 前言1.打开资源管理器&#xff08;ctrlAltdelete打开任务管理器&#xff09;2. 选择性能&#xff0c;再选择打开资源监视器3. 搜索“target”4. 我这里示范操作输入的perfmon&#xff0c;显示perfmon.exe占用的&#xff0c;右键结束这个进程 。5.然后重新用package打包…

什么是物联网?物联网如何工作?

物联网到底是什么&#xff1f; 物联网(Internet of Things&#xff0c;IoT)的概念最早于1999年被提出&#xff0c;官方解释为“万物相连的互联网”&#xff0c;是在互联网基础上延伸和扩展&#xff0c;将各种信息传感设备与网络结合起来而形成的一个巨大网络&#xff0c;可以实…

Crossover24新版发布!搭载Wine9提升Mac游戏体验!

2024年2月28日&#xff0c;著名的软件Crossover正式推出了2024年的首个全新版本Crossover24。Crossover 24版本的更新带来了许多功能优化和游戏优化&#xff0c;使用户能够更好地在Mac系统上运行各种软件和游戏&#xff0c;并且支持32位旧版软件的兼容运行。 Crossover24最新版…

【论文笔记】Gemma: Open Models Based on Gemini Research and Technology

Gemma 日期: March 5, 2024 平台: CSDN, 知乎 状态: Writing Gemma: Open Models Based on Gemini Research and Technology 谷歌最近放出的Gemma模型【模型名字来源于拉丁文gemma&#xff0c;意为宝石】采用的是与先前Gemini相同的架构。这次谷歌开源了两个规模的模型&…

python--产品篇--游戏-坦克1

文章目录 准备代码效果 准备 下载 代码 5# coding: utf-8# 游戏运行主程序 import sys import pygame import scene import bullet import food import tanks import home from pygame.locals import *# 开始界面显示 def show_start_interface(screen, width, height):tfo…

leetcode10正则表达式匹配

leetcode10正则表达式匹配 思路python 思路 难点1 如何理解特殊字符 ’ * ’ 的作用&#xff1f; 如何正确的利用特殊字符 ’ . ’ 和 ’ * ’ &#xff1f; * 匹配零个或多个前面的那一个元素 "a*" 可表示的字符为不同数目的 a&#xff0c;包括&#xff1a; "…

漫画手绘视频教程分享

下载地址&#xff1a; 漫画手绘教程: https://url83.ctfile.com/d/45573183-60305653-039aed?p7526 (访问密码: 7526)

Doris实战——银联商务实时数仓构建

目录 前言 一、应用场景 二、OLAP选型 三、实时数仓构建 四、实时数仓体系的建设与实践 4.1 数仓分层的合理规划 4.2 分桶分区策略的合理设置 4.3 多源数据迁移方案 4.4 全量与增量数据的同步 4.5 离线数据加工任务迁移 五、金融级数仓稳定性最佳实践 5.1 多租户资…

DQL语言学习(2024/3/5)one

1.基础查询&#xff1a; select 查询列表 from 表名&#xff1b; 查询列表可以是&#xff1a;①表中的字段、②常量值、③表达式、④函数 ①查询表中的单个字段&#xff0c;多个字段&#xff0c;所有字段 select *from 表名&#xff1b; ③查询表达式: select 100*98; ④…

pip 安装

1、下载pip安装包 pip PyPI-python 2.7的版本 2、解压安装包 在文件路径中输入cmd进行安装配置到第三步骤 3、用python setup.py install 进行命令行安装 显示如下为安装成功 4、安装成功后需要在环境变量进行配置pip的路径 C:\Python27\Scripts 5、测试pip安装是否成功