OpenCV 中的 cvMatchTemplate() 的使用举例

本文分享了一个使用OpenCV进行模板匹配的例子,通过加载图片并应用模板匹配算法,找到模板在源图片中的位置,并用矩形框标记出来,有助于理解OpenCV在图像处理中的应用。
部署运行你感兴趣的模型镜像

在学习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{
  for (int cy=0 ; 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);
}

希望对大家有所帮助!

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值