C++ 在窗口中显示检测到的人脸图像

C++ 在窗口中显示检测到的人脸图像,c++,opencv,storage,face-detection,C++,Opencv,Storage,Face Detection,如何在窗口中显示所有图像?我的人脸检测将产生不同大小的检测到的人脸图像。我是否应该保存所有检测到的图像,然后使用imread()读取,然后使用showmanyimage()显示?但这一步会占用我的存储空间。我需要另一个解决方案。请看下面的代码 #include <opencv2/imgproc/imgproc.hpp> #include <opencv2/highgui/highgui.hpp> #include "opencv2/objdetect.hpp" usin

如何在窗口中显示所有图像?我的人脸检测将产生不同大小的检测到的人脸图像。我是否应该保存所有检测到的图像,然后使用imread()读取,然后使用showmanyimage()显示?但这一步会占用我的存储空间。我需要另一个解决方案。请看下面的代码

#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/highgui/highgui.hpp>
#include "opencv2/objdetect.hpp"

using namespace cv;
using namespace std;

int showManyImages( const String& _winName, const vector<Mat>& _imgs );

int main( int argc, char** argv )
{
    string cascadeName = "haarcascade_frontalface_alt.xml";

    Mat img = imread(argv[1]);
    if( img.empty() )
    {
        printf( "Could not read input image file\n");
        return -1;
    }

    CascadeClassifier cascade;

    if( !cascade.load( cascadeName ) )
    {
        printf("ERROR: Could not load classifier cascade\n");
        return -1;
    }

    vector<Mat> imgs;
    vector<Rect> faces;
    cascade.detectMultiScale( img, faces, 1.3, 2, 0|CASCADE_SCALE_IMAGE, Size(30, 30) );

        for ( size_t i = 0; i < faces.size(); i++ )
        {
             if(i < 12)
             imgs.push_back(img(faces[i]));
        }

    showManyImages("Images", imgs);
    waitKey();
    return 0;
}

int showManyImages( const String& _winName, const vector<Mat>& _imgs )
{
    int nImg = (int)_imgs.size();

    Mat dispImg;

    int size;
    int x, y;

    // w - Maximum number of images in a row
    // h - Maximum number of images in a column
    int w, h;
    // scale - How much we have to resize the image
    float scale;
    int max;

    if (nImg <= 0)
    {
        printf("Number of arguments too small....\n");
        return -1;
    }
    else if (nImg > 12)
    {
        printf("Number of arguments too large....\n");
        return 1;
    }

    else if (nImg == 1)
    {
        w = h = 1;
        size = 300;
    }
    else if (nImg == 2)
    {
        w = 2;
        h = 1;
        size = 300;
    }
    else if (nImg == 3 || nImg == 4)
    {
        w = 2;
        h = 2;
        size = 300;
    }
    else if (nImg == 5 || nImg == 6)
    {
        w = 3;
        h = 2;
        size = 200;
    }
    else if (nImg == 7 || nImg == 8)
    {
        w = 4;
        h = 2;
        size = 200;
    }
    else
    {
        w = 4;
        h = 3;
        size = 150;
    }

    dispImg = Mat::zeros(Size(100 + size*w, 60 + size*h), CV_8UC3);

    for (int i= 0, m=20, n=20; i<nImg; i++, m+=(20+size))
    {
        x = _imgs[i].cols;
        y = _imgs[i].rows;

        max = (x > y)? x: y;
        scale = (float) ( (float) max / size );

        if (i%w==0 && m!=20)
        {
            m = 20;
            n += 20+size;
        }

        Mat imgROI = dispImg(Rect(m, n, (int)(x/scale), (int)(y/scale)));
        resize(_imgs[i], imgROI, Size((int)(x/scale), (int)(y/scale)));
    }

    imshow(_winName, dispImg);
    return 0;
}
#包括
#包括
#包括“opencv2/objdetect.hpp”
使用名称空间cv;
使用名称空间std;
int showManyImages(常量字符串和winName、常量向量和imgs);
int main(int argc,字符**argv)
{
字符串cascadeName=“haarcascade\u frontalface\u alt.xml”;
Mat img=imread(argv[1]);
if(img.empty())
{
printf(“无法读取输入图像文件\n”);
返回-1;
}
级联分类器级联;
如果(!cascade.load(cascadeName))
{
printf(“错误:无法加载分类器级联\n”);
返回-1;
}
向量imgs;
向量面;
检测多尺度(img,面部,1.3,2,0 |级联|尺度|图像,大小(30,30));
对于(size_t i=0;i
输入图像: 输出图像: