没啥好讲的,这里对于不是数组部分的东西就不进行讲解了。

  1. area_center(RegionOpening,Area, Row, Column)。使用area_center来求区域的中心和面积时,返回Area, Row, Column这三个参数。当区域的个数大于1时,Area, Row, Column都是一个数组

    返回的Area, Row, Column这个三个数组,Area是根据面积从小到达进行排序的,Row和Column是对应Area的区域的中心,即Row和Column的第一个元素是面积最小的区域的中心坐标

  2. tuple_sort_index(Column,Sorted_Column):对Column进行排序(从小到大),返回的是排序后的元素的索引。例如Column是【300,200, 100】,返回的Sorted_Column=【2,1,0】
  3. new_row := Row[Sorted_Column]:让Row以Sorted_Column的方式进行排序,然后将值赋予new_row。例如Row=【20, 10, 50】,Sorted_Column=【2,1,0】----->  Row[Sorted_Column]  = 【50,10,20】
  4. Halcon中的数组只能是1xN的数组, 即数组里面不能套数组

示例代码:

read_image(Image, 'printer_chip/printer_chip_01')*开启一个大小为512,512的窗口
dev_open_window(0, 0, 512, 512, 'black', WindowHandle)
*显示图像
dev_display(Image)
*在窗口上绘制矩形ROT区域,Row1,Column1是左上角坐标, Row2,Column2是右下角坐标
draw_rectangle1(WindowHandle, Row1, Column1, Row2, Column2)
*生成矩形ROI区域
gen_rectangle1(Rectangle_Roi, Row1, Column1, Row2, Column2)
*对图片进行处理,只留下ROI区域的图像,其余部分都变成黑的
reduce_domain(Image, Rectangle_Roi, ImageReduced) *对图片进行均值滤波操作,10,10是kernel的大小
mean_image(ImageReduced, ImageMean, 10, 10)
*对原图和均值后的图进行像素值求差计算,如果差值超过5则保留
dyn_threshold(ImageReduced, ImageMean, RegionDynThresh, 5, 'dark')
*将区域打散
connection(RegionDynThresh, ConnectedRegions)
*使用面积来进行过滤
select_shape(ConnectedRegions, SelectedRegions, 'area', 'and', 4000, 99999)
*对区域进行填充
fill_up(SelectedRegions, RegionFillUp)
*使用大小为50*50的矩形区域来进行开开运算操作,放的下50*50矩阵的区域保留,放不下的就剔除
opening_rectangle1(RegionFillUp, RegionOpening, 50, 50)
*统计区域的数量
count_obj(RegionOpening, Number)
*求每一个区域的中心和面积,当区域的个数大于1时,Area, Row, Column都是一个数组
area_center(RegionOpening,Area, Row, Column)
*因为区域都在同一水平线上,所以根据column来进行排序操作,从小到大。返回的是排序后index的数组
tuple_sort_index(Column,Sorted_Column) *halcon里的数组操作,就是把Row和Column的元素按照上面的排序方式来排序
new_row := Row[Sorted_Column]
new_column := Column[Sorted_Column] *创建一个数组来统计相邻的两个区域之间的距离
distance_list := []
*使用for循环来遍历,计算当前区域和下一个区域的距离
for j := 0 to Number-1 by 1
*描绘出区域的中心位置
gen_circle(Circle, new_row[j], new_column[j], 10)
*因为这里要描绘出每个区域的中心,所以j等于Number-1还要绘制中心
*但j等于Number-1的时候就不计算距离了,因为Number-1已经是最后一个区域了,没有别的区域能和他计算距离了
*所以使用break跳出循环
if (j == Number-1)
break
endif
*计算点和点之间的距离公式,new_row[j], new_column[j]是第一个点的坐标
distance_pp(new_row[j], new_column[j], new_row[j+1], new_column[j+1], Distance)
*将两个局域的距离放入数组。说明一下在halcon数组只能是1xN的数组,不能数组里面套数组
distance_list[j] := Distance
endfor

halcon数组的一些使用的更多相关文章

  1. Halcon学习(三)赋值与数组操作

    assign : 对数据赋值,对数组的初始化.但不能对数组中的某一个值进行赋值. 举例:Tuple1 := [1,0,3,4,5,6,7,8,9]    // 对数组进行初始化 Val := sin( ...

  2. zw版·Halcon与delphi(兼谈opencv)

    zw版·Halcon与delphi(兼谈opencv) QQ群 247994767(delphi与halcon) <Halcon与delphi>系列,早两年就想写,不过一方面,因为Halc ...

  3. 《zw版·Halcon-delphi系列原创教程》 zw版-Halcon常用函数Top100中文速查手册

    <zw版·Halcon-delphi系列原创教程> zw版-Halcon常用函数Top100中文速查手册 Halcon函数库非常庞大,v11版有1900多个算子(函数). 这个Top版,对 ...

  4. 《zw版·Halcon-delphi系列原创教程》 Halcon分类函数014,tuple,元组

    <zw版·Halcon-delphi系列原创教程> Halcon分类函数014,tuple,元组 为方便阅读,在不影响说明的前提下,笔者对函数进行了简化: :: 用符号“**”,替换:“p ...

  5. halcon算子

    halcon的算子列表   Chapter 1 :Classification 1.1 Gaussian-Mixture-Models 1.add_sample_class_gmm 功能:把一个训练样 ...

  6. Halcon编程-基于纹理的mara检测

    表面瑕疵检测是机器视觉领域非常重要的一个应用.机器视觉是集光学.机电和计算机三个领域的一门不算新的技术.但目前表面瑕疵检测在学界主要是计算机专业或者控制专业瞄准图像处理方向在做,而视觉光学系统这一块主 ...

  7. halcon摄像机标定

    摄像机标定程序: 注意:E:/calibration_image :为标定图像文件路径       'E:/calibration_description/caltab_123mm.descr:为标定 ...

  8. halcon的算子列表

    Chapter 1 :Classification 1.1 Gaussian-Mixture-Models 1.add_sample_class_gmm 功能:把一个训练样本添加到一个高斯混合模型的训 ...

  9. Halcon相机标定

    摄像机标定程序: 注意:E:/calibration_image :为标定图像文件路径       'E:/calibration_description/caltab_123mm.descr:为标定 ...

随机推荐

  1. 如何基于ZEGO SDK 实现通话质量监测

    如何基于ZEGO SDK 实现通话质量监测 1 功能简介 在进行视频通话过程中,用户有时候会出现网络不好的情况,比如在进行多人视频通话或者多人唱歌时,我们需要实时显示用户的网络质量. 示例源码 请参考 ...

  2. 通知:PostgreSQL证书申报退税请抓紧!

    2021年个税申报已于3月开始为了确保PostgreSQL证书能顺利退税中心特调研了学员中仅针对证书一项做退税申请没几天就得到结果2021年取得的PostgreSQL职业 技术证书确定可以退税!   ...

  3. vite创建vue3+ts项目流程

    vite+vue3+typescript搭建项目过程   vite和vue3.0都出来一段时间了,尝试一下搭vite+vue3+ts的项目 相关资料网址 vue3.0官网:https://v3.vue ...

  4. macOS 安装 Nebula Graph 看这篇就够了

    本文首发于 Nebula Graph Community 公众号 背景 刚学习图数据的内容,当前网上充斥大量的安装文档,参差不齐,部署起来令人十分头疼. 现整理一份比较完整的安装文档,供大家学习参考, ...

  5. ThinkPhP $map用法

    ThinkPHP内置了非常灵活的查询方法,可以快速的进行数据查询操作,查询条件可以用于CURD等任何操作,作为where方法的参数传入即可,下面来一一讲解查询语言的内涵.查询方式ThinkPHP可以支 ...

  6. Bugku CTF练习题---分析---flag被盗

    Bugku CTF练习题---分析---flag被盗 flag:flag{This_is_a_f10g} 解题步骤: 1.观察题目,下载附件 2.下载的文件是一个数据包,果断使用wireshark打开 ...

  7. 【hexo博客搭建】本地搭建hexo博客(上)

    前言 本篇文章会从本地(Windows 10)搭建-主题更换-部署阿里云详细步骤,如果在搭建过程中,遇到问题,可以通过博客页脚下的QQ联系我,或者在下面评论留言 一.本地搭建 1.安装前置 1.1安装 ...

  8. 从 Notion 分片 Postgres 中吸取的教训(Notion 工程团队)

    https://www.notion.so/blog/sharding-postgres-at-notion 今年(2021)早些时候,我们对 Notion 进行了五分钟的定期维护. 虽然我们的声明指 ...

  9. django的下载安装,目录结构的介绍,简单的django应用

    1.django的下载安装 pip3 install django==1.11.9 2.django的创建 1.在windows的cmd窗口下 1.1创建django项目 django-admin s ...

  10. 软件项目管理 ——1.2.PMBOK与软件项目管理知识体系

    软件项目管理 --1.2.PMBOK与软件项目管理知识体系 归档于软件项目管理初级学习路线 第一章 软件项目管理基本概念 <初级学习路线合集 > @ 目录 软件项目管理 --1.2.PMB ...