开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 9357|回复: 4
收起左侧

[技术专题] Halcon实例 转 OpenCV(易语言)计算回形针方向

[复制链接]
结帖率:88% (79/90)
发表于 2022-5-17 18:11:32 | 显示全部楼层 |阅读模式   江苏省*
本帖最后由 z13228604287 于 2022-5-17 18:41 编辑

4031d139a837445e83d2516565c746ec.png
思路步骤:

    ① 读取图像

    ② 二值化

    ③ 根据面积剔除非回形针的region

    ④ 计算每个region的方向和中心

    ⑤ 结果输出

    转到OpenCV时,主要有几个小问题需要理清:

   ① 轮廓的方向怎么计算?直线拟合?还是计算轮廓中心和回形针端点来算角度?

    ② 回形针的端点坐标如何计算?

   ③ 绘制箭头?


如下是OpenCV实现的部分代码和效果图:
  
窗口程序集名保 留  保 留备 注
程序集1   
子程序名返回值类型公开备 注
_启动子程序整数型 本子程序在程序启动后最先执行
变量名类 型静态数组备 注
图片多维矩阵类 
灰度图多维矩阵类 
轮廓多维数组点2i类 
边框矩形矩形2i类0
边框旋转矩形类0
矩形点2f类4
i整数型 
坐标集点2i类0
最大距离双精度小数型 
矩类 
中心点点2i类 
最远点点2i类 
j整数型 
距离双精度小数型 
角度双精度小数型 
图片 = 视觉_图像解码 ( #图片1, 1)
如果真 (图片. ())
视觉_控制台输出 (“读取图像错误,请重新检查!”, )
视觉_控制台命令 (“pause”)
返回 (-1)
视觉_颜色空间转换 (图片, 灰度图, #颜色_BGR转GRAY, 0)
视觉_阈值 (灰度图, 灰度图, 85, 255, #阈值_二进制_取反 )
视觉_查找轮廓 (灰度图, 轮廓, , #检测_外部, #逼近_任何, )
重定义数组 (边框矩形, 假, 轮廓.尺寸 ())
重定义数组 (边框, 假, 轮廓.尺寸 ())
计次循环首 (轮廓.尺寸 (), i)
' //计算每个轮廓最小外接矩形
边框 [i]视觉_最小轮廓矩形 (轮廓.取点2i类数组 (i))
' //筛选非回形针目标
如果真 (边框 [i].宽 < 30 边框 [i].高 < 30)
到循环尾 ()
最大距离 = 0
矩 = 视觉_计算矩 (轮廓.取点2i类数组 (i), , )
中心点 = 点2i (矩.m10 () ÷ 矩.m00 (), 矩.m01 () ÷ 矩.m00 ())
坐标集 = 轮廓.取点2i类数组 (i)
计次循环首 (取数组成员数 (坐标集), j)
距离 = 求平方根 (求次方 (坐标集 [j].左边 - 中心点.左边, 2)求次方 (坐标集 [j].顶边 - 中心点.顶边, 2))
如果真 (距离 > 最大距离)
最远点 = 点2i (坐标集 [j].左边, 坐标集 [j].顶边)
最大距离 = 距离

计次循环尾 ()
' 视觉_绘制轮廓 (img, contours, i - 1, 标量 (0, 255, 0), 5, 8, , 2147483647, )
视觉_箭头线 (图片, 中心点, 最远点, 标量 (0, 0, 255), 2, 8, 0, 0.3)
角度 = 四舍五入 (标线角度 (中心点, 最远点), 1)
视觉_放置文本 (图片, 到文本 (角度), 中心点, #字体_衬线_简单, 0.8, 标量 (0, 255, 255), 2, 8, )
计次循环尾 ()
视觉_显示图像 (“小白鼠”, 图片)
视觉_等待按键 (0)
返回 (0)  ' 可以根据您的需要返回任意数值
子程序名返回值类型公开备 注
标线角度双精度小数型 
参数名类 型参考可空数组备 注
点开始点2i类
点结束点2i类
变量名类 型静态数组备 注
角度双精度小数型 
判断 (点开始.左边 = 点结束.左边)
角度 = 90
判断 (点开始.顶边 = 点结束.顶边)
角度 = 0
角度 = 求反正切 ( (点结束.顶边 - 点开始.顶边) ÷ (点结束.左边 - 点开始.左边)) × 180 ÷ #pi
判断 (角度 < 0)
角度 = 取绝对值 (角度)
如果真 (角度 > 0)
角度 = 180 - 角度

如果真 (点结束.顶边 - 点开始.顶边 > 0 点结束.左边 - 点开始.左边 > 0)
角度 = 角度 - 180

返回 (角度)


i支持库列表   支持库注释   
OpenCV(未知支持库)

QQ图片20220517181017.png

评分

参与人数 1好评 +1 精币 +2 收起 理由
just1993 + 1 + 2 支持开源~!感谢分享

查看全部评分


发表于 2023-1-26 15:59:38 | 显示全部楼层   海南省屯昌县
大佬666666
回复 支持 反对

使用道具 举报

发表于 2022-11-17 15:48:34 | 显示全部楼层   福建省龙岩市
厉害,感谢分享
回复 支持 反对

使用道具 举报

结帖率:100% (16/16)
发表于 2022-5-17 20:12:56 | 显示全部楼层   江苏省苏州市
本帖最后由 刀子嘴豆腐心 于 2022-5-17 20:21 编辑

厉害
回复 支持 反对

使用道具 举报

结帖率:81% (21/26)

签到天数: 4 天

发表于 2022-5-17 19:27:55 | 显示全部楼层   浙江省温州市
大佬666666
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表