Halcon 获取匹配到的模板区域


在使用Halcon进行模板匹配的时候,我们使用find_shape_model、find_scaled_shape_model等算子找到模板后返回的是实例,得到的数据是模板中心的行列坐标、角度和缩放比例等数据,不是具体的区域,下面介绍怎么得到具体区域。

解决思路:

一:先获取模板的轮廓,此时获取的轮廓位置在(0,0)的位置;

二:求出模板到匹配实例的旋转矩阵;

三:利用仿射变换得到匹配实例的轮廓;

四:将轮廓转成区域;

代码及注释讲解:

 1 //获取初始模板轮廓
 2 get_shape_model_contours (ModelContours1, ModelID, 1)  3 //进行模板匹配找模板
 4 find_scaled_shape_model (Image0, ModelID, -3.14, 6.29, 0.95, 1.1, 0.90, 6, 0.5, 'least_squares', 8, 0.9, RowModel3, ColumnModel3, AngleModel3, Scale, Score1)  5 if(|RowModel3|>0)//如果找到的模板数量大于0  6         //显示找到的模板轮廓
 7         dev_display_shape_matching_results (ModelID, 'red', RowModel3, ColumnModel3, AngleModel3, 1, 1, 0)  8         //循环遍历每个找到的实例
 9     for I := 0 to |Score1| - 1 by 1
10         //求出初始模板到实例中间的旋转矩阵--注:初始模板的行列坐标和角度都是0
11         vector_angle_to_rigid (0, 0, 0, RowModel3[I], ColumnModel3[I], AngleModel3[I], HomMat2DRotate) 12         //给旋转矩阵添加缩放信息
13  hom_mat2d_scale (HomMat2DRotate, Scale[I], Scale[I], RowModel3[I], ColumnModel3[I], HomMat2DScale) 14         //通过初始模板和旋转矩阵运算得到模板实例的轮廓
15  affine_trans_contour_xld (ModelContours1, ModelTrans, HomMat2DScale) 16         //轮廓转区域
17         gen_region_contour_xld (ModelTrans, Region, 'filled') 18 endif

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM