opencv实现多图像读取并显示,sprintf_s函数,static_cast

代码接上次的人脸检测 文件名是file0001~4000 在scanf里用%04d

#include<opencv2/objdetect/objdetect.hpp> 
#include<opencv2/highgui/highgui.hpp> 
#include<opencv2/imgproc/imgproc.hpp> 
#include <iostream>
 #include <stdio.h>
 #include <stdlib.h>
using namespace cv;
using namespace std;
//人脸检测的类 
CascadeClassifier faceCascade;
int main()
{
 faceCascade.load("haarcascade_frontalface_alt2.xml");   //加载分类器,注意文件路径 
  int num =4000;
 char fileName[50];
 
 for (int j = 1; j<= num; j++)
 {
  sprintf_s(fileName, "D:\\123\\files\\file%04d.jpg", j);
  Mat img = imread(fileName);
  Mat imgGray;
  vector<Rect> faces;
  if (img.empty())
  {
   return 1;
  }
  if (img.channels() == 3)
  {
   cvtColor(img, imgGray, CV_RGB2GRAY);
  }
  else
  {
   imgGray = img;
  }
  faceCascade.detectMultiScale(imgGray, faces, 1.2, 6, 0, Size(0, 0));   //检测人脸 
  if (faces.size() > 0)
  {
   for (int i = 0; i < faces.size(); i++)
   {
    rectangle(img, Point(faces[i].x, faces[i].y), Point(faces[i].x + faces[i].width, faces[i].y + faces[i].height),
     Scalar(0, 255, 0), 1, 8);    //框出人脸位置 
   }
  }
  imshow("FacesOfPrettyGirl", img);
  waitKey(0);
  
 }
 waitKey(0);
 return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值