2010-06-21 13 views
8

Próbuję użyć funkcji findContours w OpenCV, ale VS 2008 daje błąd mówiąc:OpenCV findContours funkcja problemem

OpenCV Error: Bad flag (parametr lub pole struktura) (Nierozpoznane lub UNSUPPORT ed typ array) w nieznanej funkcji, plik ........ \ ocv \ opencv \ src \ cxcore \ cxarr ay.cpp, linia 2476

Ta aplikacja zażądała, aby środowisko wykonawcze zakończyło ją w nietypowy sposób. Aby uzyskać więcej informacji, skontaktuj się z zespołem pomocy technicznej aplikacji. Naciśnij dowolny klawisz, aby kontynuować. . .

Oto kod:

Mat_<Vec<float,3>> originalimage; 

Mat_<Vec<float,3>> resultingimage; 

vector<vector<cv::Point>> v; 

originalimage = cv::imread("Original.ppm"); 

cv::findContours(originalimage,v,CV_RETR_LIST,CV_CHAIN_APPROX_NONE); 

góry dzięki

+0

Są to prawidłowe deklaracje: Mat_ > originalimage; Mat_ > resultimage; wektor > v; – user123668

Odpowiedz

3

FindContours akceptuje tylko obrazu binarnego. Oznacza to, że każdy obraz, który jest wyprowadzany z cvThreshold cvAdapiveThreshold cvCanny

try dodanie tego oświadczenia przed cv :: findContours

cvThreshold(originalImage,resultingImage,100,100,CV_THRESH_BINARY) 

następnie wywołać findcontours z resultingImage.

jeśli to działa, to powinieneś wprowadzić prawidłowe parametry do cvThreshold (100 to tylko przykład) .Sprawdź odnośnik w tej sprawie.

EDYCJA: resultImage powinno być pojedynczym obrazem kanału !!

3

Miałem ten sam problem (lub przynajmniej podobny) z tą funkcją. Nie udało mi się tego naprawić, więc użyłem starej funkcji cvFindContours w stylu C. Dodałem przykładową funkcję, w której użyłem funkcji cvFindContours do wyczyszczenia obrazu typu blob. To może nie być najszybsze rozwiązanie, ale działa.

void filtBproject(Mat& Bproject){ 

    Scalar   color  = CV_RGB(255,255,255); // text color 
    IplImage*  BprojectIpl = &IplImage(Bproject); 
    CvMemStorage* storage  = cvCreateMemStorage(0); 
    CvSeq*   contours = 0; 
    int    numCont  = 0; 
    int    contAthresh = 45; 

    numCont= cvFindContours(BprojectIpl, storage, &contours, sizeof(CvContour), 
        CV_RETR_EXTERNAL, CV_CHAIN_APPROX_SIMPLE, cvPoint(0,0)); 

    cvSet(BprojectIpl, cvScalar(0,0,0)); 
    for(; contours != 0; contours = contours->h_next) 
     { 

      if ((cvContourArea(contours, CV_WHOLE_SEQ) > contAthresh)){ 
       cvDrawContours(BprojectIpl, contours, color, color, -1, CV_FILLED, 8); 
      } 
     } 
} 
1

Dla Państwa przeciwko wektora, trzeba dodać przestrzeń tak:

vector<vector<cv::Point> > v; 

Bardzo subtelny i głupie, ale działa.

+0

FYI Point2d ulega awarii i punkt działa –