OpenCV里的模板匹配(转载)

void CFollowDlg::MatchTemplate(CString path){//double a=0.;   IplImage* imgSrc = cvLoadImage(path);IplImage* imgTemp = cvLoadImage("C://t.bmp");CvSize sizeSrc = cvGetSize(imgSrc);CvSize sizeTemp = cvGetSize(imgTemp);CvSize sizeResult = cvSize(sizeSrc.width-sizeTemp.width+1,sizeSrc.height-sizeTemp.height+1);IplImage* imgResult = cvCreateImage(sizeResult,IPL_DEPTH_32F,1);   cvMatchTemplate(imgSrc,imgTemp,imgResult,CV_TM_CCORR_NORMED);//   a=cvMatchShapes(imgSrc,imgTemp,CV_CONTOURS_MATCH_I3);   float dMax = 0.;CvPoint point = cvPoint(0,0);//if(!a) MessageBox("Not Successful!",MB_OK);for (int cx=0 ; cx<sizeResult.width ; cx++){  for (int cy=0 ; cy<sizeResult.height ; cy++)  {   float fTemp = CV_IMAGE_ELEM(imgResult,float,cy,cx);   if (dMax < fTemp)   {    dMax = fTemp;    point = cvPoint(cx,cy);   }  }}CvPoint point2 = cvPoint(point.x+sizeTemp.width,point.y+sizeTemp.height);cvRectangle(imgSrc,point,point2,cvScalar(255));cvNamedWindow( "Test", CV_WINDOW_AUTOSIZE );cvShowImage("Test",imgSrc);   /*   for(;;)    {        int k = cvWaitKey(5);        if( k == 27 ) break;    }*/ }void CFollowDlg::OnButton4() { // TODO: Add your control notification handler code here CString path; CFileDialog dlg(TRUE); if(dlg.DoModal()==IDOK)  path=dlg.GetPathName(); MatchTemplate(path);}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值