中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python opencv如何實現人眼/人臉識別以及實時打碼處理

發布時間:2021-04-17 15:02:28 來源:億速云 閱讀:304 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關Python opencv如何實現人眼/人臉識別以及實時打碼處理,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

系統環境:Windows 7 + Python 3.6.3 + opencv 3.4.2

一、系統、資源準備

要想達成該目標,需要滿足一下幾個條件:

  • 找一臺帶有攝像頭的電腦,一般筆記本即可;

  • 需配有Python3,并安裝NumPy包、opencv;

  • 需要有已經訓練好的分類器,用于識別視頻中的人臉、人眼等,如無分類器,可以點擊這里下載:haarcascades分類器

二、動手做

1、導入相關包、設置視頻格式、調用攝像頭、指定分類器

import numpy as np 
import cv2
 
fourcc = cv2.VideoWriter_fourcc("D", "I", "B", " ")
out = cv2.VideoWriter('frame_mosic.MP4',fourcc, 20.0, (640,480))
 
cv2.namedWindow("CaptureFace")
#調用攝像頭
cap=cv2.VideoCapture(0)
#人眼識別器分類器
classfier=cv2.CascadeClassifier("../haarcascades/haarcascade_eye_tree_eyeglasses.xml")

2、逐幀調用圖像,并實時處理

從攝像頭讀取一幀圖像后,先轉化為灰度圖像,然后利用指定的分類器識別出我們需要的內容,接著對該部分內容利用高斯噪聲進行覆蓋,以達成馬賽克的目的。

代碼如下:

while cap.isOpened():
 read,frame=cap.read()
 if not read:
  break
 #灰度轉換
 grey=cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY)
 #人臉檢測
 Rects = classfier.detectMultiScale(grey, scaleFactor = 1.2, minNeighbors = 3, minSize = (32, 32))
 if len(Rects) > 0:   
  for Rect in Rects: 
    x, y, w, h = Rect 
    # 打碼:使用高斯噪聲替換識別出來的人眼所對應的像素值
    frame[y+10:y+h-10,x:x+w,0]=np.random.normal(size=(h-20,w))
    frame[y+10:y+h-10,x:x+w,1]=np.random.normal(size=(h-20,w))
    frame[y+10:y+h-10,x:x+w,2]=np.random.normal(size=(h-20,w))
 
 cv2.imshow("CaptureFace",frame)
 if cv2.waitKey(5)&0xFF==ord('q'):
  break
 # 保存視頻
 out.write(frame)
#釋放相關資源
cap.release()
out.release()
cv2.destroyAllWindows()

3、觀察效果

代碼調用攝像頭并在窗口進行了顯示,可以實時觀察到圖像處理的效果,如圖:

Python opencv如何實現人眼/人臉識別以及實時打碼處理

并將結果保存為視頻,方便隨時查看:

Python opencv如何實現人眼/人臉識別以及實時打碼處理

完整代碼如下:

# -*- coding: utf-8 -*-
 
import numpy as np 
import cv2
 
fourcc = cv2.VideoWriter_fourcc("D", "I", "B", " ")
out = cv2.VideoWriter('frame_mosic.MP4',fourcc, 20.0, (640,480))
 
cv2.namedWindow("CaptureFace")
#調用攝像頭
cap=cv2.VideoCapture(0)
#人眼識別器分類器
classfier=cv2.CascadeClassifier("../haarcascades/haarcascade_eye_tree_eyeglasses.xml")
while cap.isOpened():
 read,frame=cap.read()
 if not read:
  break
 #灰度轉換
 grey=cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY)
 #人臉檢測
 Rects = classfier.detectMultiScale(grey, scaleFactor = 1.2, minNeighbors = 3, minSize = (32, 32))
 if len(Rects) > 0:   
  for Rect in Rects: 
    x, y, w, h = Rect 
    # 打碼:使用高斯噪聲替換識別出來的人眼所對應的像素值
    frame[y+10:y+h-10,x:x+w,0]=np.random.normal(size=(h-20,w))
    frame[y+10:y+h-10,x:x+w,1]=np.random.normal(size=(h-20,w))
    frame[y+10:y+h-10,x:x+w,2]=np.random.normal(size=(h-20,w))
 
 cv2.imshow("CaptureFace",frame)
 if cv2.waitKey(5)&0xFF==ord('q'):
  break
 # 保存視頻
 out.write(frame)
#釋放相關資源
cap.release()
out.release()
cv2.destroyAllWindows()

利用opencv提供Python接口,可以很方便的進行圖像、視頻處理方面的學習研究,實在是很方便。這里把近期所學做個簡單應用,后續再學習更深入的知識。

關于“Python opencv如何實現人眼/人臉識別以及實時打碼處理”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

恩平市| 吐鲁番市| 景泰县| 含山县| 济阳县| 巩留县| 仲巴县| 连江县| 光泽县| 安仁县| 泰兴市| 犍为县| 阿拉善盟| 揭西县| 伊金霍洛旗| 普安县| 桦川县| 南召县| 广水市| 礼泉县| 乌兰县| 乐都县| 青河县| 出国| 醴陵市| 仙游县| 合作市| 安平县| 红桥区| 徐闻县| 泰州市| 山丹县| 长顺县| 长海县| 眉山市| 武川县| 潼南县| 新乐市| 黔西县| 宝坻区| 淮北市|