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

首頁 > 編程 > C > 正文

opencv實現圖片與視頻中人臉檢測功能

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

本文實例為大家分享了opencv實現人臉檢測功能的具體代碼,供大家參考,具體內容如下

第一章:反思與總結

上一篇博客我相信自己將人臉檢測中的AdaBoost算法解釋的非常清晰了,以及如何訓練人臉檢測的強分類器:人臉檢測中AdaBoost算法詳解。事后,自我感覺對這個人臉檢測還是不夠具體,所以自己抽了一下午的時間用opencv實現圖片與視頻中的人臉檢測,下面是我用vs2013加opencv4.9來實現的。做一下聲明,我的代碼是參考OpenCV實現人臉檢測的一個博客寫的,非常感謝這位博主,我學到了很多東西,下面是我一下午實踐的總結:

第二章:圖片中的人臉檢測

啥也不說,先上效果圖大笑:

下面是福利圖了,圖中有志玲姐姐(安靜):

可惜沒匹配上,很傷心~~~~

有人可能會問這么漂亮的背景圖是這么高的,下面是代碼~

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_hIcon);  }  else  {  /*改變對話框背景****若需要默認背景,可以刪除*/  CPaintDC dc(this);  CRect rect;  GetClientRect(&rect);  CDC dcBmp;  dcBmp.CreateCompatibleDC(&dc);  CBitmap bmpBackGround;  bmpBackGround.LoadBitmap(<span style="color:#FF6666;">IDB_BEIJING</span>);//IDB_BEIJING是背景的圖片ID,在資源視圖中插入資源,選擇BITMAP 
BITMAP m_bitmap; //上傳圖片(BMP)格式,將ID設為一致就好了 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(); }}

好了,下面進入正題,如何實現圖片中的人臉匹配,見代碼,后面有詳細解釋:

void CmyFaceDetectDlg::OnBnClickedFacedetect() {  // 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;//USES_CONVERSION是用來轉換類型的  //USES_CONVERSION它是在堆棧上分配空間的,也就是說你在你在函數未結束就不會被釋放掉。所有要注意不要在一個函數中用while循環執行它,不然??臻g就馬上會分配完(棧空間一般只有2M,很小)  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);//圖片尺度調整,將gray調整為smallImage.size大小,方法為INTER_LINEAR:局部像素的重采樣  equalizeHist(smallImage, smallImage);//直方圖均衡  cascade.detectMultiScale(smallImage, faces);//核心,檢測人臉  //const_iterator迭代器,是不能改變r所指向的元素的值的  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, 2);  } } 

注意我是在一個MFC的對話框中,這個界面圖中按下“圖片”button后的操作。

第三章:視頻中的人臉檢測

其實,和圖片中的原理是一樣的。因為視頻又一幀一幀的圖片組成,我們設定一個短的時間間隔,就可以更圖片一樣了。
先看效果吧:(說明,該視頻是一個女子在跳芭蕾舞,我截去3張圖片來達到以點概面的效果)

下面見代碼:

void CmyFaceDetectDlg::OnBnClickedFacev() {  // 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; }

第四章:總結

人臉匹配最總要的是如何生成匹配庫,也是檢測的方法的差別。庫的生成和機器學習密切相關,學習永無止境,努力吧!

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

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

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产欧美一区二区三区在线看| 欧美超级免费视 在线| 精品久久久一区二区| 九九精品视频在线观看| 国产精品色婷婷视频| 亚洲日本成人女熟在线观看| 亚洲香蕉av在线一区二区三区| 欧美风情在线观看| 亚洲综合精品一区二区| 亚洲视频在线观看| 亚洲欧美综合区自拍另类| 日韩av在线一区| 疯狂做受xxxx高潮欧美日本| 亚洲第一区第一页| 91精品一区二区| 66m—66摸成人免费视频| 国产精品最新在线观看| 亚洲一二在线观看| 欧美孕妇性xx| 隔壁老王国产在线精品| 欧美精品久久久久久久免费观看| 久久香蕉频线观| 国产综合香蕉五月婷在线| 精品国产欧美一区二区五十路| 国产精品白嫩初高中害羞小美女| 色香阁99久久精品久久久| 成人激情视频网| 国产精品久久久久久久久久久久久久| 91影视免费在线观看| 久久久久久久国产| 久久久久久av| 91在线观看欧美日韩| 国产97免费视| 中文字幕久久亚洲| 国产精品激情av电影在线观看| 欧美激情在线有限公司| 欧美成人精品三级在线观看| 最新日韩中文字幕| 成人亚洲激情网| 国产精品最新在线观看| 欧美美最猛性xxxxxx| 日韩在线观看免费全| yellow中文字幕久久| 亚洲人成亚洲人成在线观看| 久热精品在线视频| 欧美黑人巨大xxx极品| 免费99精品国产自在在线| 欧美激情影音先锋| 国产亚洲成精品久久| 热门国产精品亚洲第一区在线| 久久精品国产亚洲精品2020| 欧美日韩亚洲视频一区| 日韩成人在线网站| 亚洲天堂男人天堂女人天堂| 九九久久久久久久久激情| 日韩精品福利网站| 日韩性xxxx爱| 国产va免费精品高清在线| 亚洲毛片在线免费观看| 国产精品日韩欧美| 亚洲高清在线观看| 成人免费观看a| 国产精品久久久久久久av电影| 精品无码久久久久久国产| 亚洲第一区中文99精品| www.xxxx欧美| 国内精品400部情侣激情| 国产区亚洲区欧美区| 日本aⅴ大伊香蕉精品视频| 亚洲精品白浆高清久久久久久| 色老头一区二区三区| 国产成人午夜视频网址| xvideos亚洲人网站| 81精品国产乱码久久久久久| 欧美日韩精品在线视频| 久久手机免费视频| 亚洲成人久久电影| 亚洲成人久久久久| 日韩视频免费大全中文字幕| 国产专区精品视频| 91九色视频在线| 国产精品视频久久| 91网站免费观看| 中文字幕日韩欧美精品在线观看| 亚洲aaa激情| 欧美精品久久一区二区| 日韩av大片在线| 亚洲高清不卡av| 成人免费视频a| 亚洲性av网站| 久久天天躁狠狠躁夜夜av| 亚洲v日韩v综合v精品v| 久久国产精品网站| 欧美激情xxxxx| 国产综合视频在线观看| 亚洲最新av在线| 欧美中文字幕在线观看| 久久久久免费精品国产| 日韩欧美高清在线视频| 亚洲成人黄色网| 国产精品激情自拍| 91在线|亚洲| 欧美性xxxx极品hd欧美风情| 一区二区三区在线播放欧美| 国产亚洲精品美女久久久久| 国产精品成人一区| 在线看日韩欧美| 亚洲精美色品网站| 91美女片黄在线观| 777午夜精品福利在线观看| 国产盗摄xxxx视频xxx69| 国产精品网站大全| 国产日韩专区在线| 日本精品视频在线| 亚洲欧洲午夜一线一品| 国产69精品久久久| 自拍偷拍免费精品| 日韩av色在线| 麻豆乱码国产一区二区三区| 红桃av永久久久| 97精品国产97久久久久久免费| 成人免费观看49www在线观看| 国产精品成人aaaaa网站| 久久精品国产69国产精品亚洲| 国产一区二区欧美日韩| 精品日本美女福利在线观看| 中文字幕日韩av| 欧美成人性色生活仑片| 国产精品成人一区| 日韩av日韩在线观看| 国产成人极品视频| 国产日韩欧美中文在线播放| 亚洲xxxx做受欧美| 欧美亚洲伦理www| 国产精国产精品| 91av在线网站| 91精品中文在线| 欧美黑人性生活视频| 国产精品久久久久7777婷婷| 怡红院精品视频| 中文字幕亚洲国产| 欧美高清激情视频| 黑人巨大精品欧美一区二区免费| 性色av一区二区三区红粉影视| 日韩免费视频在线观看| 欧美一区二区三区免费视| 国产日韩欧美黄色| 国产精品亚洲片夜色在线| 精品久久久久久中文字幕一区奶水| 久久人人爽人人爽人人片av高请| 91精品久久久久久久久久久久久| 高跟丝袜一区二区三区| 国产精品视频免费观看www| 日韩美女福利视频| 欧美专区国产专区| 91社影院在线观看| 欧美一级成年大片在线观看| 亚洲女人天堂成人av在线| 日韩电影免费观看中文字幕| 亚洲视频在线免费观看| 这里只有视频精品| 日韩av综合中文字幕| 久久久精品国产| 亚洲精品福利在线|