检测面部并在OpenCV中保存检测到的面部

时间:2012-02-16 16:19:10

标签: c opencv image-processing computer-vision face-detection

我正在尝试检测图像中的脸部并尝试将检测到的脸部保存为OpenCV中的图像。

在下面的detectfaces函数中遇到一些问题。

#include "stdafx.h"

#include <stdio.h>
#include <cv.h>
#include <highgui.h>
#include <cxcore.h>

CvHaarClassifierCascade *cascade;
CvMemStorage            *storage;

void detectFaces( IplImage *img );

int _tmain(int argc, _TCHAR* argv[])
{
  //CvCapture *capture;
  IplImage  *img;//*out;
  int       key = 0;
  char      *filename = "C:/OpenCV2.1/data/haarcascades/haarcascade_frontalface_alt.xml";

  cascade = ( CvHaarClassifierCascade* )cvLoad( filename, 0, 0, 0 );
  storage = cvCreateMemStorage( 0 );
  img     = cvLoadImage("Yurico.png");

  assert( cascade && storage && img );

  cvNamedWindow( "video:", 1 );
  //cvNamedWindow( "video1:", 1 );
  //out = detectFaces( img );
  detectFaces( img );
  cvWaitKey( 0 );
  //cvShowImage( "video", out );
  cvDestroyWindow( "video:" );
  //cvDestroyWindow( "video1:" );
  cvReleaseImage( &img );
  cvReleaseHaarClassifierCascade( &cascade );
  cvReleaseMemStorage( &storage );

  return 0;
}

void detectFaces( IplImage *img )
{
    int i;
     CvRect *r;
    CvSeq *faces = cvHaarDetectObjects(
            img,
            cascade,
            storage,
            1.1,
            3,
            0 /*CV_HAAR_DO_CANNY_PRUNNING*/,
            cvSize( 40, 40) );

    for( i = 0 ; i < ( faces ? faces->total : 0 ) ; i++ ) {
        CvRect *r = ( CvRect* )cvGetSeqElem( faces, i );
        cvRectangle( img,
                     cvPoint( r->x, r->y ),
                     cvPoint( r->x + r->width, r->y + r->height ),
                     CV_RGB( 255, 0, 0 ), 1, 8, 0 );
    }

    //cvShowImage( "video:", img );
    cvSetImageROI(img, CvRect *r);

    IplImage *img2 = cvCreateImage(cvGetSize(img), 
                              img->depth, 
                               img->nChannels);

    cvSaveImage("Lakshmen.jpg",img2); 
}

说错误:

 Error  1   error C2664: 'cvSetImageROI' : cannot convert parameter 2 from 'CvRect *' to 'CvRect'   c:\users\hp\documents\visual studio 2010\projects\facedetect\facedetect\facedetect.cpp  67  1   facedetect

想要将感兴趣的区域保存到另一个图像中。任何更正或改进确实告诉我..

3 个答案:

答案 0 :(得分:2)

你需要传递一个CvRect而不是一个CvRect *,所以你不需要r之前的指针(*)。 因为它已经是一个cvRect你应该写:

 cvSetImageROI(img, &r);

答案 1 :(得分:2)

cvSetImageROI()cvRect作为第二个参数,并将其用作输入参数将图像剪切到该区域。

换句话说,您需要创建一个包含有效信息的cvRect。您可以在调用函数之前执行此操作,也可以内联:

cvSetImageROI(img_corr, cvRect(x_pos, y_pos, width, height));

我还注意到,在您的代码中,您在同一函数内的至少3个不同位置创建CvRect* r;。不好的做法!提示:在您要使用它们时,在代码中创建变量,而不是在此之前。

答案 2 :(得分:0)

只需将CvRect *r替换为r=(CvRect*)cvGetSeqElem( faces,i),然后在for循环后写两行

cvSetImageROI(img, cvRect(r->x,r->y,r->width,r->height));
cvSaveImage("C1.jpg",img);