2010-06-21 12 views
8

Je suis en train d'utiliser la fonction findContours dans OpenCV, mais VS 2008 donne une erreur en disant:OpenCV problème de la fonction findContours

OpenCV Erreur: Mauvais indicateur (paramètre ou champ de structure) (type non reconnu ou UNSUPPORT tableau ed ) en fonction inconnue, fichier ........ \ ocv \ opencv \ src \ cxcore \ cxarr ay.cpp, ligne 2476

Cette application a demandé au Runtime de le terminer de façon inhabituelle. Veuillez contacter l'équipe d'assistance de l'application pour plus d'informations. Appuyez sur n'importe quelle touche pour continuer. . .

Voici le code:

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); 

Merci à l'avance

+0

Voici les déclarations correctes: Mat_ > originalimage; Mat_ > resultimage; vecteur > v; – user123668

Répondre

3

FindContours accepte seule image binaire. Autrement dit, toute image qui est sortie de cvThreshold cvAdapiveThreshold cvCanny

essayer d'ajouter cette déclaration avant cv :: findContours

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

puis appelez findcontours avec resultingImage. Si cela fonctionne, vous devriez entrer les bons paramètres dans cvThreshold (100 est juste un exemple). Vérifiez la référence à cet égard.

EDIT: resultImage doit être une image monocanal !!

3

J'ai eu le même problème (ou au moins un problème similaire) avec cette fonction. Je n'étais pas capable de le réparer, j'ai donc utilisé l'ancienne fonction cvFindContours de style C à la place. J'ai inclus une fonction exemple dans laquelle j'ai utilisé la fonction cvFindContours pour nettoyer une image blob. Ce n'est peut-être pas la solution la plus rapide, mais au moins cela fonctionne.

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

Pour votre vecteur v, vous devez ajouter un espace comme ceci:

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

très subtile et muet, mais cela fonctionne.

+0

Accidents FYI Point2d et travaux de Point –