opencvc++模板识别

OpenCV c++ template recognition

本文关键字:识别 opencvc++      更新时间:2023-10-16

我有一个模板,我想知道模板是否存在于图像中。我在谷歌上搜索了很多,得出的结论是我需要使用cvMatchTemplatecvMinMaxLoc

下面是我的代码:
image = cvLoadImage("C:/images/flower.jpg",1);
templat = cvLoadImage("C:/images/flo.jpg",1);
image2=cvCreateImage( cvSize(image->width, image->height), IPL_DEPTH_8U, 1 );
result=cvCreateImage( cvSize(image->width, image->height), IPL_DEPTH_8U, 1 );
cvZero(result);
cvZero(image2);
cvCvtColor(image,image2,CV_BGR2GRAY);
cvMatchTemplate(image2, templat,result,CV_TM_CCORR_NORMED);
double min_val=0, max_val=0;
CvPoint min_loc, max_loc;
cvMinMaxLoc(result, &min_val, &max_val, &min_loc, &max_loc);
cvRectangle(image, max_loc, cvPoint(max_loc.x+templat->width,  
max_loc.y+templat->height), cvScalar(0), 1);
cvShowImage( "src", image );
cvShowImage( "result image", result);
cvWaitKey(0);

我的问题是当我运行上面的代码时,显示一个消息框说:

Unhandled exception at 0x747d812f in matching.exe: Microsoft C++ exception: cv::Exception at memory location 0x001ff6ec.. 

在黑屏上有一条消息:

OpenCV Error: Sizes of input arguments do not match <image and template should have the same type> in unknown function, file........ocvopencvscrcvcvtempl.cpp, line 356.

请注意,flower.jpg是彩色图像,flo.jpg是该图像的灰度。

知道发生了什么事吗?

您需要将flower.jpgflo.jpg都转换为单通道图像。即使flo.jpg是灰度的,你也要将其加载为三通道图像。另外,result的图像应该是IPL_DEPTH_32F而不是IPL_DEPTH_8U

下面是正确的代码(未经测试):
IplImage* image    = cvLoadImage("C:/images/flower.jpg", 1);
IplImage* templat  = cvLoadImage("C:/images/flo.jpg", 1);
IplImage* image2   = cvCreateImage(cvSize(image->width, image->height), IPL_DEPTH_8U, 1);
IplImage* templat2 = cvCreateImage(cvSize(templat->width, templat->height), IPL_DEPTH_8U, 1); 
cvCvtColor(image, image2, CV_BGR2GRAY);
cvCvtColor(templat, templat2, CV_BGR2GRAY);
int w = image->width - templat->width + 1;
int h = image->height - templat->height + 1;
result = cvCreateImage(cvSize(w, h), IPL_DEPTH_32F, 1);
cvMatchTemplate(image2, templat, result, CV_TM_CCORR_NORMED);
double min_val, max_val;
CvPoint min_loc, max_loc;
cvMinMaxLoc(result, &min_val, &max_val, &min_loc, &max_loc);
cvRectangle(image, max_loc, cvPoint(max_loc.x+templat->width, 
max_loc.y+templat->height), cvScalar(0), 1);
cvShowImage("src", image);
cvShowImage("result image", result);
cvWaitKey(0);

模板匹配假设imagetemplate具有相同的通道数和通道深度。最简单的方法是将它们都以灰度加载:

Mat I = imread("lena.png", 0);
Mat T = imread("template.png", 0);

注:我将命令使用OpenCV2.0 c++接口。所以用imread代替cvLoadImage。旧界面不再开发