2

我在 OpenCV 中实现倒角匹配程序时遇到了这个问题

https://code.ros.org/trac/opencv/browser/trunk/opencv/samples/cpp/chamfer.cpp?rev=4194

以下是它正在读取模板图像的代码

http://img593.imageshack.us/img593/6391/5klx.png

和测试图像 http://img5.imageshack.us/img5/6619/u76z.png

,我正在使用 VS 2008 和 OpenCV2.4.6

#include "stdafx.h"

#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/contrib/contrib.hpp>
#include <iostream>
using namespace cv;
using namespace std;

int main( int argc, char** argv )
{    
    IplImage *src;
    src = cvLoadImage("C:\\Users\\JOSHI\\Desktop\\Images\\logo_in_clutter.png",1);      
    Mat img=cvarrToMat(src);  
    imshow("Mat",img); 

    src = cvLoadImage("C:\\Users\\JOSHI\\Desktop\\Images\\logo.png",1);  
    Mat tpl=cvarrToMat(src);  
    imshow("Mat",tpl); 
    Mat cimg;

    // if the image and the template are not edge maps but normal grayscale images,
    // you might want to uncomment the lines below to produce the maps. You can also
    // run Sobel instead of Canny.    
     Canny(img, img, 5, 50, 3);
     Canny(tpl, tpl, 5, 50, 3);    
    vector<vector<Point> > results;
    vector<float> costs;
    int best = chamerMatching( img, tpl, results, costs );
    if( best < 0 )
    {
        cout << "not found;\n";
        return 0;
    }    
    size_t i, n = results[best].size();
    for( i = 0; i < n; i++ )
    {
        Point pt = results[best][i];
        if( pt.inside(Rect(0, 0, cimg.cols, cimg.rows)) )
           cimg.at<Vec3b>(pt) = Vec3b(0, 255, 0);
    }
    imshow("result", cimg);

    waitKey();
    return 0;
}

这是错误图像 http://img138.imageshack.us/img138/7339/m1d.png

你能告诉我为什么我会收到这个错误,因为我是 OpenCV 和图像处理的新手

4

1 回答 1

1

我有同样的问题。解决方法:http : //code.opencv.org/issues/3603 需要从源码下载opencv,打开chamfermatching.cpp和注释行:

~Matching()
{
    for (size_t i = 0; i<templates.size(); i++) {
        //delete templates[i];
    }
}

然后你需要重建opencv。在此之后它应该工作。

于 2014-05-19T09:16:57.553 回答