halcon 提取图像中的感兴趣区域

halcon 提取图像中的感兴趣区域_第1张图片

功能:提取图像红框中圆孔里面的7个白点。 

 具体步骤

P1:加载一张图像

* 加载一张图像
read_image(Image, 'xxx.png')

*获取图像的大小
get_image_size(Image, Width, Height)

*显示图像
dev_close_window()
dev_open_window(0, 0, Width, Height, 'black', WindowHandle)
dev_display(Image)

P2:转为灰度图像

rgb1_to_gray(Image, GrayImage)

halcon 提取图像中的感兴趣区域_第2张图片

P3:均值滤波,二值化,提取亮区域

* 均值滤波
mean_image(GrayImage, ImageMean, 31,31)

* 动态二值化,提取亮区域
dyn_threshold(GrayImage, ImageMean, RegionDynThresh, 5, 'light')
halcon 提取图像中的感兴趣区域_第3张图片 均值滤波

 

halcon 提取图像中的感兴趣区域_第4张图片 二值化,提取亮区域

P4:将提取的二值化区域打散

connection(RegionDynThresh, ConnectedRegions)

halcon 提取图像中的感兴趣区域_第5张图片

 P5:填充所有的区域

fill_up(ConnectedRegions, RegionFillUp)

halcon 提取图像中的感兴趣区域_第6张图片

 P6:根据矩形度筛选所有的区域

select_shape(RegionFillUp, SelectedRegions, 'rectangularity', 'and', 0.9, 1)

halcon 提取图像中的感兴趣区域_第7张图片

 P7:根据面积筛选,过滤面积小的

select_shape(SelectedRegions, SelectedRegions1, 'area', 'and', 6000, 9000)

halcon 提取图像中的感兴趣区域_第8张图片

P8:与ConnectedRegions求取交集,获取方形区域的对应的二值化后的区域

intersection(ConnectedRegions, SelectedRegions1, RegionIntersection)

connection(RegionIntersection, ConnectedRegions1)

halcon 提取图像中的感兴趣区域_第9张图片

 P9:填充所有区域

fill_up(ConnectedRegions1, RegionFillUp1)

halcon 提取图像中的感兴趣区域_第10张图片

 

P10:根据圆度以及圆点面积筛选圆所在的区域

select_shape(RegionFillUp1, SelectedRegions2, 'circularity', 'and', 0.8, 1)
select_shape(SelectedRegions2, SelectedRegions3, 'area', 'and', 500, 700)

halcon 提取图像中的感兴趣区域_第11张图片

P11:根据圆里面小点的面积筛选所有的小圆点

intersection(RegionFillUp1, SelectedRegions3, RegionIntersection1)

select_shape(RegionIntersection1, SelectedRegions4, 'area', 'and', 2, 100)

halcon 提取图像中的感兴趣区域_第12张图片

 

P12:最终获取的效果图如下

halcon 提取图像中的感兴趣区域_第13张图片

 

 

你可能感兴趣的:(图像处理,halcon)