2013-07-04 111 views
1

当我尝试启动我的应用程序时,它在执行contourArea时意外崩溃。OpenCV:contourArea声明失败

以下是错误:

OpenCV Error: Assertion Failed (contour.checkVector(2) >= 0 && (contour.depth() ==CV_32F || contour.depth() == CV_32S)) in unknown function, file ..\..\..\src\opencv\modules\imgproc\src\contours.cpp, line 1904 

我的程序很简单:从相机 1.catch帧, 2.高斯和中值滤波, 3.形态学开, 4.阈值, 5 。findContours, 6.提请contourn与大面积

这里是我的代码:

#include <opencv2/opencv.hpp> 
#include <stdio.h> 

using namespace cv; 
using namespace std; 

Mat mask(480,640, CV_8UC1); 
vector<Vec4i> hierarchy; 
vector<vector<Point> > contours; 
vector<Point> my_contourn; 

int main(){ 
VideoCapture camera(0); 

if(!camera.isOpened()){ 
    return -1; 
} 

while(1){ 
    Mat cameraframe,filtered_img,mask2; 
    camera >> cameraframe; 

    GaussianBlur(cameraframe,filtered_img,Size(11,11),0,0); 
    medianBlur(filtered_img,filtered_img,11); 
    cvtColor(filtered_img,filtered_img,CV_BGR2HSV); 
    inRange(filtered_img, Scalar(0, 76, 97), Scalar(20, 143, 205), mask); 
    morphologyEx(mask,mask,MORPH_OPEN,getStructuringElement(MORPH_RECT,Size(9,9),Point(4,4))); 
    GaussianBlur(mask,mask,Size(3,3),0,0); 
    dilate(mask,mask,getStructuringElement(MORPH_ELLIPSE,Size(7, 7),Point(0, 0))); 


    mask.copyTo(mask2); 
    findContours(mask2,contours,hierarchy,CV_RETR_EXTERNAL,CV_CHAIN_APPROX_SIMPLE,Point(0, 0)); 

    double area,max_area=0.0; 


    for(int i=0;i<contours.size();i++){ 

     area = fabs(contourArea(contours[i])); 
     if (area>max_area) 
     { 
      max_area=area; 
      my_contourn=contours[i]; 
     } 
    } 

    drawContours(mask, my_contourn, 10, Scalar(255,0,0), 2, 8); 

    imshow("my cont",mask); 

    if(waitKey(30)>=0) 
     break; 
} 
return 0; 
} 

我该如何解决?

+0

请发布一个[简短,可编辑的例子](http://sscce.org)。您发布的代码无法编译,并且在尝试修复编译器错误后,我无法重新创建您的问题。如果我们可以复制粘贴代码并运行它,那么人们可以更容易地提供帮助! – Aurelius

+0

此外,[这个问题](http://stackoverflow.com/q/16948057/1601291)描述了同样的问题,它似乎是唯一的VS 2012. – Aurelius

+0

编辑:在这里你的简短和可编辑的例子 –

回答

0

我确认这是一个VS2012问题。在VS2010上,一切都很好。

0

这个奇怪的错误也发生在VS2013上。

尝试将轮廓[i]从矢量类型转换为CV :: Mat,然后将其传递到contourArea。

Mat conMat(contours[i].size(), 2, CV_32FC1); 
for(int i = 0; i < contours[i].size(); i ++) 
{ 
    conMat.at<float>(i, 0) = contours[i].x; 
    conMat.at<float>(i, 1) = contours[i].y; 
}  
area = fabs(contourArea(conMat)); 

这对我很有用。