OpenCV如何检查是否已找到面部

时间:2016-05-04 17:23:39

标签: c++ opencv computer-vision

感谢阅读,我修改了OpenCV的级联分类器来检测静态图像上的面部。我现在正试图弄清楚程序是否找到了一张脸(然后在输入图像的眼睛和嘴周围显示了圆圈),但我不知道该怎么做。

供参考,这是我的显示功能,是用于面部检测的OpenCV教程的修改版本。

非常感谢任何提示甚至高级别的解释

void detectAndDisplay( Mat frame )
{
   std::cout << "detectAndDisplay called" << endl;

   std::vector<Rect> faces;
   Mat frame_gray;

   cvtColor( frame, frame_gray, CV_BGR2GRAY );
   equalizeHist( frame_gray, frame_gray );

   //-- Detect faces
   face_cascade.detectMultiScale( frame_gray, faces, 1.1, 2, 0|CV_HAAR_SCALE_IMAGE, Size(30, 30) );

   for( size_t i = 0; i < faces.size(); i++ )
   {
      Point center( faces[i].x + faces[i].width*0.5, faces[i].y + faces[i].height*0.5 );
      ellipse( frame, center, Size( faces[i].width*0.5, faces[i].height*0.5), 0, 0, 360, Scalar( 255, 0, 255 ), 4, 8, 0 );

      Mat faceROI = frame_gray( faces[i] );
      std::vector<Rect> eyes;

      //-- In each face, detect eyes
      eyes_cascade.detectMultiScale( faceROI, eyes, 1.1, 2, 0 |CV_HAAR_SCALE_IMAGE, Size(30, 30) );

      for( size_t j = 0; j < eyes.size(); j++ )
      {
          Point center( faces[i].x + eyes[j].x + eyes[j].width*0.5, faces[i].y + eyes[j].y + eyes[j].height*0.5 );
          int radius = cvRound( (eyes[j].width + eyes[j].height)*0.25 );
          circle( frame, center, radius, Scalar( 255, 0, 0 ), 4, 8, 0 );
      }
 }
   //-- Show what you got
   imshow( window_name, frame );
 }

0 个答案:

没有答案