J'essaie de détecter les quatre points que vous pouvez voir au centre de cette image : Celui-ci est converti en png, j'utilise en fait un format ppm (après conversion à partir de la sortie brute de l'appareil photo). L'image traitée est disponible aquí
Je suis nouveau à opencv et j'ai donc un énorme problème pour détecter ces points. Voici le meilleur résultat que j'ai obtenu jusqu'à présent :
Comme vous pouvez le voir, j'ai détecté 3 des points, mais à part cela, beaucoup d'autres éléments de l'image sont reconnus comme des cercles.
Et voici le code :
IplImage* img;
if((img = cvLoadImage( "photos/img-000012.ppm", 1)) == 0 )
{
perror("cvLoadImage");
return 1;
}
cvNamedWindow( "Image view", 1 );
cvShowImage( "Image view", img );
// cvWaitKey(0);
IplImage* gray = cvCreateImage( cvGetSize(img), 8, 1 ); // allocate a 1 channel byte image
CvMemStorage* storage = cvCreateMemStorage(0);
cvCvtColor( img, gray, CV_BGR2GRAY );
cvShowImage( "Image view", gray );
// cvWaitKey(0);
cvSmooth( gray, gray, CV_GAUSSIAN, 3, 3, 0, 0 );
cvShowImage( "Image view", gray );
cvWaitKey(0);
CvSeq* circles = cvHoughCircles(gray, storage, CV_HOUGH_GRADIENT,
4, // inverse ratio of the accumulator resolution
1, // minimum distance between circle centres
100, // higher threshold value for Canny
20, // accumulator threshold for the circle centers; smaller->more false circles
1, // minimum radius
10 ); // maximum radius
printf("circles == %d\n", circles->total);
int i;
for (i = 0; i < circles->total; i++) {
float *p = (float*)cvGetSeqElem(circles, i);
CvPoint center = cvPoint(cvRound(p[0]),cvRound(p[1]));
CvScalar val = cvGet2D(gray, center.y, center.x);
if (val.val[0] < 1) continue;
printf("%d %d %d\n", cvRound(p[0]),cvRound(p[1]), cvRound(p[2]));
cvCircle(img, center, cvRound(p[2]), CV_RGB(0,255,0), 1, CV_AA, 0);
}
cvShowImage( "Image view", img );
cvWaitKey(0);
Avez-vous une idée sur la manière de résoudre ce problème ? Je vous en serais très reconnaissant. Je pense qu'il est assez facile pour un œil humain de repérer les points, j'espère donc pouvoir les détecter à l'aide d'un ordinateur.