错误消息:无法匹配调用'(cv :: Rect)(cv :: Mat&amp;,cv :: Point_ <int>,cv :: Point,cv :: Scalar,int)'

时间:2015-08-04 14:27:32

标签: c++ opencv

我到处都看了很多,找不到问题的答案。 我试图从这个帖子中复制一个文本检测软件(Extracting text OpenCV) 但是在代码的末尾有一个消息错误,说明矩形没有匹配,即使我已经在上面绘制了一个并且我们进入了循环。 我已经测试了我能想到的所有值,一切看起来都是正确的。

这是完整的代码;

#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <iostream>
#include <opencv2/imgproc/imgproc.hpp>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>


using namespace cv;
using namespace std;





int main( int argc, char** argv )
{

namedWindow("source_window2",WINDOW_AUTOSIZE);
namedWindow("source_window3",WINDOW_AUTOSIZE);
Mat input = imread(argv[1], CV_LOAD_IMAGE_COLOR);
Mat in_gray = imread(argv[1],CV_LOAD_IMAGE_GRAYSCALE);
Mat gradient;

Mat Kernelellipse = getStructuringElement(MORPH_ELLIPSE, Size(3,3));
morphologyEx(in_gray, gradient, MORPH_GRADIENT, Kernelellipse);
Mat thresh;
//on convertit en binaire
threshold(gradient, thresh, 0.0, 255.0, THRESH_BINARY | THRESH_OTSU);
rectangle(input,Point(0,0),Point(50,50),Scalar(255,255,255),2);
Mat Kernelrectangle = getStructuringElement(MORPH_RECT, Size(9,1));
Mat fermee;
morphologyEx(thresh, fermee, MORPH_CLOSE, Kernelrectangle);
imshow("source_window3", fermee);

Mat noire = Mat::zeros(thresh.size(), CV_8UC1);
//on cheche les contours
vector<vector<Point> > contours;
vector<Vec4i> hierarchy;
findContours(fermee, contours, hierarchy, CV_RETR_CCOMP, CV_CHAIN_APPROX_SIMPLE, Point(0, 0));
for (int i = 0; i < contours.size(); ++i)
{
    Rect rectangle = boundingRect(contours[i]);
    Mat noirerectangle(noire, rectangle);
    noirerectangle = Scalar(0, 0, 0);
    //on les dessine
    drawContours(noire, contours, i, Scalar(255, 255, 255), CV_FILLED);
    double proportion_de_blanc = (double)countNonZero(noirerectangle)/(rectangle.width*rectangle.height);

    if (proportion_de_blanc > 0.45 && (rectangle.height > 8 && rectangle.width > 8))
    {
        rectangle(input,rectangle.tl(),rectangle.br(),Scalar(0,255,0),2);
    }


}
imshow("source_window2",input);





waitKey(0);
return(0);

}

我的问题是在最后一个循环中:

    if (proportion_de_blanc > 0.45 && (rectangle.height > 8 && rectangle.width > 8))
    {
        rectangle(input,rectangle.tl(),rectangle.br(),Scalar(0,255,0),2);
    }

2 个答案:

答案 0 :(得分:2)

您将其中一个定义为:

Rect rectangle = boundingRect(contours[i]);

名称​​矩形rectangle绘图功能发生冲突。所以:

  1. 使用其他名称重命名矩形,例如Rectangle rect = boundingRect(contours[i]);

  2. 调用矩形绘制方法为cv::rectangle(input,rectangle.tl(),rectangle.br(),Scalar(0,255,0),2);

答案 1 :(得分:1)

你有

Rect rectangle = boundingRect(contours[i]);

创建名为Rect的{​​{1}}类型的变量。然后在你的for循环中,你调用我假设的是rectangle函数

rectangle()

在进行调用的范围内,编译器将rectangle(input,rectangle.tl(),rectangle.br(),Scalar(0,255,0),2); 视为变量而不是函数。要解决此问题,您需要使用rectangle来限定rectangle,或者您可以更改变量的名称。