亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

OpenCV實現人臉檢測

2020-01-26 13:49:11
字體:
來源:轉載
供稿:網友

前段日子,寫了個人臉檢測的小程序,可以檢測標記圖片、視頻、攝像頭中的人臉。效果還行吧,用的是opencv提供人臉庫。至于具體的人臉檢測原理,找資料去啃吧。

環境:VS2013+OPENCV2.4.10+Win8.1

這里寫圖片描述

一、基于對話框的MFC

首先,新建一個基于對話框的MFC應用程序,命名為myFaceDetect(取消“安全開發周期(SDL)檢查”勾選,我自己習慣取消這個)。

這里寫圖片描述 

放置Button,設置Button的ID和Caption。
圖片按鈕――ID:IDC_FACEDETECT
視頻按鈕――ID:IDC_FACEV
攝像頭按鈕――ID:IDC_FACEC

二、添加消息響應函數

為圖片按鈕、視頻按鈕、攝像頭按鈕,在類向導中添加消息響應函數。
在圖片按鈕上右鍵,選擇類向導。在CMyFaceDetectDlg類(對話框類)下選中BN_CLICKED消息,點擊添加處理程序。其余兩個按鈕,按同樣操作,添加消息響應函數。
完成上述操作后,獲得對應三個按鈕的消息響應函數。

這里寫圖片描述
這里寫圖片描述

void CMyFaceDetectDlg::OnClickedFacedetect()//圖片按鈕void CMyFaceDetectDlg::OnClickedFacev()//視頻按鈕void CMyFaceDetectDlg::OnClickedFacec()//攝像頭按鈕

三、人臉檢測實現

首先,將OpenCV2.4.10+VS2013環境的配置完成,這個網上有許多教程。這是我以前寫的一篇配置教程:Visual Studio 2013+OpenCV2.4.10環境搭建教程

對話框類的頭文件:MyFaceDetectDlg.h

// MyFaceDetectDlg.h : 頭文件//#pragma once#include <opencv2/objdetect/objdetect.hpp>#include <opencv2/highgui/highgui.hpp>#include <opencv2/ml/ml.hpp>#include <opencv.hpp>#include "afxwin.h"using namespace cv;// CMyFaceDetectDlg 對話框class CMyFaceDetectDlg : public CDialogEx{// 構造public:  CMyFaceDetectDlg(CWnd* pParent = NULL); // 標準構造函數// 對話框數據  enum { IDD = IDD_MYFACEDETECT_DIALOG };  protected:  virtual void DoDataExchange(CDataExchange* pDX);  // DDX/DDV 支持// 實現protected:  HICON m_hIcon;  HICON m_catIcon;//程序的小貓圖標。如果想用默認的圖片,可以將其注釋掉。  // 生成的消息映射函數  virtual BOOL OnInitDialog();  afx_msg void OnPaint();  afx_msg HCURSOR OnQueryDragIcon();  DECLARE_MESSAGE_MAP()public:  afx_msg void OnClickedFacedetect();public:  CascadeClassifier cascade;//級聯分類器  Mat image;//圖片  double scale;//縮小比例??s小圖片可以加快檢測速度,當然加快檢測速度還有其他的方法。public:  void detectAndDraw(Mat& img, CascadeClassifier& cascade, double scale);//添加的實現人臉檢測的函數,核心函數  CButton m_btn;//為了美化按鈕添加對象,可以注釋掉。  afx_msg void OnClickedFacev();  afx_msg void OnClickedFacec();  afx_msg void OnBnClickedCancel();};

對話框類的實現:MyFaceDetectDlg.cpp

// MyFaceDetectDlg.cpp : 實現文件//#include "stdafx.h"#include "MyFaceDetect.h"#include "MyFaceDetectDlg.h"#include "afxdialogex.h"#include <string>#ifdef _DEBUG#define new DEBUG_NEW#endif// CMyFaceDetectDlg 對話框CMyFaceDetectDlg::CMyFaceDetectDlg(CWnd* pParent /*=NULL*/)  : CDialogEx(CMyFaceDetectDlg::IDD, pParent){  m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);  m_catIcon = AfxGetApp()->LoadIcon(IDI_ICON4);//加載自己的圖標(小貓~)  scale = 1.3;}void CMyFaceDetectDlg::DoDataExchange(CDataExchange* pDX){  CDialogEx::DoDataExchange(pDX);  DDX_Control(pDX, IDC_FACEDETECT, m_btn);}BEGIN_MESSAGE_MAP(CMyFaceDetectDlg, CDialogEx)  ON_WM_PAINT()  ON_WM_QUERYDRAGICON()  ON_BN_CLICKED(IDC_FACEDETECT, &CMyFaceDetectDlg::OnClickedFacedetect)  ON_BN_CLICKED(IDC_FACEV, &CMyFaceDetectDlg::OnClickedFacev)  ON_BN_CLICKED(IDC_FACEC, &CMyFaceDetectDlg::OnClickedFacec)  ON_BN_CLICKED(IDCANCEL, &CMyFaceDetectDlg::OnBnClickedCancel)END_MESSAGE_MAP()// CMyFaceDetectDlg 消息處理程序BOOL CMyFaceDetectDlg::OnInitDialog(){  CDialogEx::OnInitDialog();  // 設置此對話框的圖標。 當應用程序主窗口不是對話框時,框架將自動  // 執行此操作  //若不需要自己設置圖標,可以將后面所有m_catIcon改成m_hIcon  SetIcon(m_catIcon, TRUE);      // 設置大圖標。   SetIcon(m_catIcon, FALSE);   // 設置小圖標  //按鈕加載圖片背景  //HBITMAP hbmp1 = ::LoadBitmap(AfxGetInstanceHandle(), MAKEINTRESOURCE(IDB_BITMAP2));  //m_btn.SetBitmap(hbmp1);  // TODO: 在此添加額外的初始化代碼  return TRUE; // 除非將焦點設置到控件,否則返回 TRUE}// 如果向對話框添加最小化按鈕,則需要下面的代碼// 來繪制該圖標。 對于使用文檔/視圖模型的 MFC 應用程序,// 這將由框架自動完成。void CMyFaceDetectDlg::OnPaint(){  if (IsIconic())  {    CPaintDC dc(this); // 用于繪制的設備上下文    SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);    // 使圖標在工作區矩形中居中    int cxIcon = GetSystemMetrics(SM_CXICON);    int cyIcon = GetSystemMetrics(SM_CYICON);    CRect rect;    GetClientRect(&rect);    int x = (rect.Width() - cxIcon + 1) / 2;    int y = (rect.Height() - cyIcon + 1) / 2;    // 繪制圖標    dc.DrawIcon(x, y, m_catIcon);  }  else  {    /*改變對話框背景****若需要默認背景,可以刪除*/    CPaintDC dc(this);    CRect rect;    GetClientRect(&rect);    CDC dcBmp;    dcBmp.CreateCompatibleDC(&dc);    CBitmap bmpBackGround;    bmpBackGround.LoadBitmap(IDB_BITMAP4);    BITMAP m_bitmap;    bmpBackGround.GetBitmap(&m_bitmap);    CBitmap *pbmpOld = dcBmp.SelectObject(&bmpBackGround);    dc.StretchBlt(0, 0, rect.Width(), rect.Height(), &dcBmp, 0, 0, m_bitmap.bmWidth, m_bitmap.bmHeight, SRCCOPY);    /*********************************/    CDialogEx::OnPaint();      }}//當用戶拖動最小化窗口時系統調用此函數取得光標//顯示。HCURSOR CMyFaceDetectDlg::OnQueryDragIcon(){  return static_cast<HCURSOR>(m_catIcon);}void CMyFaceDetectDlg::OnClickedFacedetect(){  // TODO: 在此添加控件通知處理程序代碼  CString filename;  //打開對話框  CFileDialog OpenDlg(TRUE, NULL, NULL, OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT | OFN_NOCHANGEDIR,    _T("圖片 (*.jpg)|*.jpg|(*.*) |*.*|"), NULL);  if (OpenDlg.DoModal() != IDOK)  {    return;  }  filename = OpenDlg.GetPathName();//獲得文件路徑  /*CString轉換*string*/  USES_CONVERSION;  std::string tempName(W2A(filename));  image = imread(tempName);//讀取圖片  const String cascade_name = "./haarcascade_frontalface_alt2.xml";//加載人臉庫  if (!cascade.load(cascade_name))  {    MessageBox(_T("ERROR:Could not load cascade!"));    return;  }  if (!image.data)  {    MessageBox(_T("ERROR:Could not load image!"));    return;  }  namedWindow("人臉檢測", CV_WINDOW_AUTOSIZE);  detectAndDraw(image, cascade, scale);//調用人臉檢測函數  imshow("人臉檢測", image);  return;}void CMyFaceDetectDlg::detectAndDraw(Mat& img, CascadeClassifier& cascade, double scale){  /*程序核心函數,檢測標記人臉*/  int i = 0;  vector<Rect>faces;//定義一個容器,保存檢測結果  const static Scalar colors[] = {    CV_RGB(0, 0, 255),    CV_RGB(0, 128, 255),    CV_RGB(0, 255, 255),    CV_RGB(0, 255, 0),    CV_RGB(255, 128, 0),    CV_RGB(255, 255, 0),    CV_RGB(255, 0, 0),    CV_RGB(255, 0, 255)  };  Mat gray, smallImage(cvRound(img.rows / scale), cvRound(img.cols / scale), CV_8UC1);//用cvRound取整  cvtColor(img, gray, CV_BGR2GRAY);//轉化灰度圖  resize(gray, smallImage, smallImage.size(), 0, 0, INTER_LINEAR);//圖片尺度調整  equalizeHist(smallImage, smallImage);//直方圖均衡  cascade.detectMultiScale(smallImage, faces);//核心,檢測人臉  for (vector<Rect>::const_iterator r = faces.begin(); r != faces.end(); r++, i++)  {    //利用迭代器,標記出人臉位置。    Point center;    Scalar color = colors[i % 8];    int radius;    /*計算出原圖像中的圓心和半徑。公式很簡單,自己寫一下,就可以理解了*/    center.x = cvRound((r->x + r->width*0.5)*scale);    center.y = cvRound((r->y + r->height*0.5)*scale);    radius = cvRound((r->width + r->height)*0.25*scale);    /****************/    circle(img, center, radius, color, 3);  }}void CMyFaceDetectDlg::OnClickedFacev(){  // TODO: 在此添加控件通知處理程序代碼  //檢測視頻幀中的人臉  CString filename;  CFileDialog OpenDlg(TRUE, NULL, NULL, OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT | OFN_NOCHANGEDIR,    _T("視頻(*.avi)|*.avi|(*.*)|*.*|"), NULL);  if (OpenDlg.DoModal() != IDOK)  {    return;  }  /*CString轉換*string*/  filename = OpenDlg.GetPathName();  USES_CONVERSION;  std::string tempName(W2A(filename));  const String cascade_name = "./haarcascade_frontalface_alt2.xml";  if (!cascade.load(cascade_name))  {    MessageBox(_T("ERROR:Could not load cascade!"));    return;  }  VideoCapture capture(tempName);//打開視頻  if (!capture.isOpened())  {    MessageBox(_T("ERROR:Could not load Video!"));    return;  }  double rate = capture.get(CV_CAP_PROP_FPS);  bool stop(false);  int delay = 1000 / rate;  while (!stop)  {    if (!capture.read(image))//讀取視頻幀      break;    detectAndDraw(image, cascade, scale);    imshow("人臉檢測", image);    if (waitKey(delay) >= 0)      stop = true;  }  capture.release();  return;}void CMyFaceDetectDlg::OnClickedFacec(){  // TODO: 在此添加控件通知處理程序代碼  //檢測攝像頭中的人臉數據  const String cascade_name = "./haarcascade_frontalface_alt2.xml";  if (!cascade.load(cascade_name))  {    MessageBox(_T("ERROR:Could not load cascade!"));    return;  }  VideoCapture capture(0);//打開攝像頭  if (!capture.isOpened())  {    MessageBox(_T("ERROR:Could not load capture!"));    return;  }  //double rate = capture.get(CV_CAP_PROP_FPS);  //bool stop(false);  //int delay = 1000 / rate;  int k=0;  while (1)  {    if (!capture.read(image))      break;    detectAndDraw(image, cascade, scale);    imshow("人臉檢測", image);    k=waitkey(10);    if (k=27)//ESC鍵      break;  }  capture.release();  return;}void CMyFaceDetectDlg::OnBnClickedCancel(){  // TODO: 在此添加控件通知處理程序代碼  CDialogEx::OnCancel();}

三 運行程序

視頻和圖片都有測試,一般只要是正臉、清晰的都能檢測圖片。另外,需要將haarcascade_frontalface_alt2.xml文件復制到程序目錄下。
這里寫圖片描述 

將文件在目錄opencv/sources/data/haarcascades下。

這里寫圖片描述 

這里寫圖片描述

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
92福利视频午夜1000合集在线观看| 色吧影院999| 欧美日韩一区二区在线| 欧美激情网站在线观看| 尤物精品国产第一福利三区| 国产成+人+综合+亚洲欧美丁香花| 欧美激情一区二区久久久| 中文字幕免费国产精品| 欧美国产欧美亚洲国产日韩mv天天看完整| www国产精品视频| 欧美日韩亚洲激情| 精品久久久久久久中文字幕| 亚洲欧美中文日韩在线v日本| 亚洲女性裸体视频| 亚洲va欧美va在线观看| xxxx欧美18另类的高清| 国产精品女人久久久久久| 97在线视频精品| 日本久久中文字幕| 成人黄色av免费在线观看| 久久精品成人一区二区三区| 欧美日韩爱爱视频| 国产亚洲精品高潮| 欧美精品福利在线| 欧美一级黄色网| 裸体女人亚洲精品一区| 97国产精品久久| 国产精品欧美风情| 韩国精品美女www爽爽爽视频| 中文字幕视频在线免费欧美日韩综合在线看| 亚洲第一视频在线观看| 亚洲a在线播放| 日韩一区二区久久久| 欧美性猛交xxxx免费看| 亚洲精品久久久一区二区三区| 国产一区二区三区视频在线观看| 欧美日在线观看| 91亚洲va在线va天堂va国| 在线日韩第一页| 97超碰国产精品女人人人爽| 色综合久久中文字幕综合网小说| 亚洲欧洲日产国码av系列天堂| 欧美激情性做爰免费视频| 亚洲小视频在线观看| 亚洲区一区二区| 久久精品欧美视频| 欧美极品在线视频| 色妞色视频一区二区三区四区| 国产91精品久| 曰本色欧美视频在线| 日韩精品一二三四区| www.国产精品一二区| 亚洲精品资源在线| 国产亚洲人成网站在线观看| 欧美人与性动交| 粉嫩av一区二区三区免费野| 91九色视频在线| 国产精品香蕉在线观看| 精品亚洲一区二区三区四区五区| 亚洲成人久久久| 一区二区三区国产在线观看| 欧美成人黑人xx视频免费观看| 国产一区二区欧美日韩| 国产精品99久久久久久久久久久久| 欧美另类高清videos| 日韩中文字幕第一页| 久久福利视频导航| 亚洲精品视频网上网址在线观看| 久久久国产在线视频| 亚洲电影成人av99爱色| 成人妇女淫片aaaa视频| 欧洲成人午夜免费大片| 国产欧美中文字幕| 中文字幕不卡av| 成人a视频在线观看| 亚洲精品免费在线视频| 这里精品视频免费| 亚洲无av在线中文字幕| 国产精品自拍网| 久久亚洲欧美日韩精品专区| 欧美日韩国产中文字幕| 亚洲精品美女在线| 亚洲精品自在久久| 91福利视频在线观看| 久久久久国产一区二区三区| 国产精品高潮呻吟久久av黑人| 国产成人免费av电影| 国产午夜精品一区理论片飘花| 日韩精品视频在线观看免费| www国产亚洲精品久久网站| 亚洲91av视频| 福利二区91精品bt7086| 国产97在线|亚洲| 成人黄在线观看| 中文字幕日韩av综合精品| 色www亚洲国产张柏芝| 亚洲在线视频福利| 美日韩精品免费视频| 国产精品视频免费在线观看| 亚洲激情小视频| 日韩av中文字幕在线播放| 国产成人aa精品一区在线播放| 成人国产精品久久久久久亚洲| 精品国内产的精品视频在线观看| www国产亚洲精品久久网站| 91精品久久久久久久久中文字幕| 国产91在线播放九色快色| 欧美中文在线观看国产| 久久亚洲精品国产亚洲老地址| 国产精品福利无圣光在线一区| 国产精品久久77777| 在线免费观看羞羞视频一区二区| 久久九九国产精品怡红院| 国产丝袜视频一区| 国产剧情久久久久久| 国产精品欧美激情在线播放| 九九精品视频在线| 精品久久久久久久中文字幕| 欧美富婆性猛交| 一本色道久久88亚洲综合88| 91精品啪aⅴ在线观看国产| 欧美老女人性视频| 欧美最近摘花xxxx摘花| 久青草国产97香蕉在线视频| 国产亚洲成精品久久| 欧美亚洲另类制服自拍| 亚洲视频国产视频| 亚洲精品日韩欧美| 色婷婷**av毛片一区| 日韩中文av在线| 欧美成人手机在线| 5278欧美一区二区三区| 国产精品v片在线观看不卡| 欧美中文字幕在线播放| xx视频.9999.com| 欧美日韩成人在线观看| 狠狠久久亚洲欧美专区| 成人国产亚洲精品a区天堂华泰| 成人免费淫片视频软件| 久久人人爽人人爽人人片av高清| 欧美日韩在线免费观看| 欧美福利视频在线观看| 国产日本欧美在线观看| 欧美肥臀大乳一区二区免费视频| 国产精品视频中文字幕91| 成人有码视频在线播放| 国产在线a不卡| 欧美小视频在线观看| 欧美怡红院视频一区二区三区| 黑人与娇小精品av专区| 日韩精品视频在线观看免费| 日本精品视频在线| 亚洲毛片在线免费观看| 精品人伦一区二区三区蜜桃网站| 亚洲一区美女视频在线观看免费| 亚洲日韩欧美视频| 久久久久久久999精品视频| 日韩在线免费视频观看| 精品久久久久久久久久国产| 国产欧美日韩精品丝袜高跟鞋| 国产主播喷水一区二区| 91免费观看网站| 欧美人在线视频| 欧美日韩国产在线看|