1

openCv と c++ を使用して、画像にテンプレートが存在するかどうかを確認したいと考えています。ただし、画像が撮影される距離と画像の位置が異なるため、一致は正しく発生しません。

ここに私のコードがあります:

IplImage* image    = cvLoadImage("C:/images/Photo0734.jpg", 1);
IplImage* templat  = cvLoadImage("C:/images/templatecoin.jpg", 1);
int percent =25;// declare a destination IplImage object with correct size, 
depth and  channels
IplImage* image3 = cvCreateImage( cvSize((int)((image->width*percent)/100) , 
(int)((image->height*percent)/100) ),image->depth, image->nChannels );

//use cvResize to resize source to a destination image
cvResize(image, image3);
IplImage* image2   = cvCreateImage(cvSize(image3->width, image3->height), 
IPL_DEPTH_8U,   1);
IplImage* templat2 = cvCreateImage(cvSize(templat->width, 
templat->height),   IPL_DEPTH_8U, 1); 

cvCvtColor(image3, image2, CV_BGR2GRAY);
cvCvtColor(templat, templat2, CV_BGR2GRAY);


int w = image3->width - templat->width + 1;
int h = image3->height - templat->height + 1;
result = cvCreateImage(cvSize(w, h), IPL_DEPTH_32F, 1);
cvMatchTemplate(image2, templat2, 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(image3, max_loc, cvPoint(max_loc.x+templat->width, 
max_loc.y+templat->height), cvScalar(0,1,1), 1);

cvShowImage("src", image3);
//cvShowImage("result image", result);
cvWaitKey(0);

「マット」は使用できませんのでご了承ください。IplImage* を使用して、コードをスケーリングと回転に対して不変にすることは可能ですか? 助けて。

4

1 に答える 1

0

それを見てみましょう:

SIFTウィキ

SIFT の例

OpenCV SIFT ドキュメント

それはあなたにとって役立つと思います。

于 2013-04-19T18:18:28.353 に答える