*将轮廓生成闭合区域使用算子gen_region_contour_xld
read_image(Image,'fabrik')
*图像分割
*灰度值在128和255之间的像素点作为同一个区域
threshold(Image,Region,128,255)
*填充区域中的洞
fill_up(Region,RegionFillUp)
*连接区域,连在一起的作为一个区域,这样就将不连接的区域打散
connection(RegionFillUp, ConnectedRegions)
*按区域面积(以象素为单位的)选择目标区域
*这里我们要找到设备操作书的位置
select_shape(ConnectedRegions,SelectedRegions,'area','and',5000,10000)
*提取操作书区域的图像
reduce_domain(Image,SelectedRegions,ImageReduced)
*显示一下看效果
dev_clear_window()
dev_display(ImageReduced)
*在图像中使用阈值分割提取亚像素边缘轮廓
*以灰度值大于Threshold区域和灰度值小于Threshold的区域为分界点提取亚像素精密轮廓
*原型:hreshold_sub_pix(Image : Border : Threshold : )
threshold_sub_pix(ImageReduced,Border,170)
*通过选择轮廓长度过滤出目标轮廓
*原型为select_contours_xld(Contours : SelectedContours : Feature, Min1, Max1, Min2, Max2 : )
select_contours_xld (Border,SelectedContours,'contour_length',100,150,-0.5,0.5)
*通过选择轮廓面积过滤出目标轮廓
*原型为select_shape_xld(XLD : SelectedXLD : Features, Operation, Min, Max : )
select_shape_xld(SelectedContours,SlectedXLD,'area','and',250,999999)
*将轮廓生成闭合区域
*原型为gen_region_contour_xld(Contour : Region : Mode : )
gen_region_contour_xld(SlectedXLD,Region1,'filled')
dev_clear_window()
dev_display(ImageReduced)
dev_display(Region1)
*运行效果如下