功能:提取图像红框中圆孔里面的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)
P3:均值滤波,二值化,提取亮区域
* 均值滤波
mean_image(GrayImage, ImageMean, 31,31)
* 动态二值化,提取亮区域
dyn_threshold(GrayImage, ImageMean, RegionDynThresh, 5, 'light')
P4:将提取的二值化区域打散
connection(RegionDynThresh, ConnectedRegions)
P5:填充所有的区域
fill_up(ConnectedRegions, RegionFillUp)
P6:根据矩形度筛选所有的区域
select_shape(RegionFillUp, SelectedRegions, 'rectangularity', 'and', 0.9, 1)
P7:根据面积筛选,过滤面积小的
select_shape(SelectedRegions, SelectedRegions1, 'area', 'and', 6000, 9000)
P8:与ConnectedRegions求取交集,获取方形区域的对应的二值化后的区域
intersection(ConnectedRegions, SelectedRegions1, RegionIntersection)
connection(RegionIntersection, ConnectedRegions1)
P9:填充所有区域
fill_up(ConnectedRegions1, RegionFillUp1)
P10:根据圆度以及圆点面积筛选圆所在的区域
select_shape(RegionFillUp1, SelectedRegions2, 'circularity', 'and', 0.8, 1)
select_shape(SelectedRegions2, SelectedRegions3, 'area', 'and', 500, 700)
P11:根据圆里面小点的面积筛选所有的小圆点
intersection(RegionFillUp1, SelectedRegions3, RegionIntersection1)
select_shape(RegionIntersection1, SelectedRegions4, 'area', 'and', 2, 100)
P12:最终获取的效果图如下