方法如下:
Image
Image
圖像<灰色,浮動> c =新圖像<灰色,浮動>(a.Width,a .Height);
//使用指定的方法將wxh大小的重疊補丁與templ進行比較,並返回比較結果
./ * CV_TM_SQDIFF平方差匹配法:該方法採用平方差來進行匹配;最好的匹配值為0;匹配越差,匹配值越大
.CV_TM_CCORR相關匹配法:該方法採用乘法操作;數值越大表明匹配程度越好。
CV_TM_CCOEFF相關係數匹配法:1表示完美的匹配; -1表示最差的匹配
CV_TM_SQDIFF_NORMED歸一化平方差匹配法
CV_TM_CCORR_NORMED歸一化相關匹配法
CV_TM_CCOEFF_NORMED歸一化相關係數匹配法* /
c = a.MatchTemplate(b,TemplateMatchingType.CcoeffNormed);
Point maxp = new Point(0,0);
Point minp = new Point(0,0);
/ *查找最小和最大元素值及其位置。在整個數組中搜索極值
選擇ROI(如果是IplImage)或if mask非IntPtr。在指定的數組區域中為零。如果數組有多個通道
則必須是具有COI集的IplImage。如果多維數組min_loc-> x和max_loc-> x將包含端點的原始(線性)位置* /
CvInvoke.MinMaxLoc(c,ref min,ref max,ref minp,ref maxp);
CvInvoke.Rectangle(a,new Rectangle(maxp,new Size(b.Width,b.Height)),new MCvScalar(0,255,0),1); //畫出矩形
輸出最大,表示相似度。
注意:模板圖像的大小必須小於原圖。