欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用 Python 和 OpenCV 實現(xiàn)攝像頭人臉檢測并截圖功能

 更新時間:2024年11月13日 10:46:53   作者:燕鵬01  
在現(xiàn)代應(yīng)用中,人臉檢測是一項非常重要的技術(shù),廣泛應(yīng)用于安全監(jiān)控、身份驗證等領(lǐng)域,本文詳細(xì)介紹了如何使用 Python 和 OpenCV 庫實現(xiàn)攝像頭人臉檢測并截圖,并通過具體的代碼示例展示了整個過程,感興趣的朋友一起看看吧

概述

在現(xiàn)代應(yīng)用中,人臉檢測是一項非常重要的技術(shù),廣泛應(yīng)用于安全監(jiān)控、身份驗證等領(lǐng)域。本文將詳細(xì)介紹如何使用 Python 和 OpenCV 庫實現(xiàn)攝像頭人臉檢測并截圖,并通過具體的代碼示例來展示整個過程。

環(huán)境準(zhǔn)備

在開始編寫代碼之前,確保已經(jīng)安裝了 OpenCV 庫。可以使用以下命令安裝:

pip install opencv-python

代碼詳解

# -*- coding: utf-8 -*-
# import 進(jìn)openCV的庫
import cv2
import os
import time
# 調(diào)用攝像頭檢測人臉并截圖
def camera(window_name, path_name):
    # Linux 不顯示圖形界面
    cv2.namedWindow(window_name)
    # 視頻來源,來自USB攝像頭
    cap = cv2.VideoCapture(0)
    # 告訴OpenCV使用人臉識別分類器
    classfier = cv2.CascadeClassifier(os.getcwd()+"/haarcascade_frontalface_alt.xml")
    # 識別出人臉后要畫的邊框的顏色,RGB格式, color是一個不可增刪的數(shù)組
    color = (0, 255, 0)
    num = 0
    while cap.isOpened():
        ok, frame = cap.read()  # 讀取一幀數(shù)據(jù)
        if not ok:
            break
        # 將當(dāng)前楨圖像轉(zhuǎn)換成灰度圖像
        grey = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
        # 人臉檢測,1.2和2分別為圖片縮放比例和需要檢測的有效點(diǎn)數(shù)
        faceRects = classfier.detectMultiScale(grey, scaleFactor=1.2, minNeighbors=3, minSize=(32, 32))
        if len(faceRects) > 0:  # 大于0則檢測到人臉
            for faceRect in faceRects:  # 單獨(dú)框出每一張人臉
                x, y, w, h = faceRect
                num = num + 1
                # 將當(dāng)前幀保存為圖片
                img_name = "%s/%d.jpg" % (path_name, num)
                image = frame[y - 10: y + h + 10, x - 10: x + w + 10]
                cv2.imwrite(img_name, image, [int(cv2.IMWRITE_PNG_COMPRESSION), 9])
                # 延遲 60s,不要太頻繁的發(fā)送,知道來了就可以了
                # time.sleep(60)
                # 畫出矩形框
                cv2.rectangle(frame, (x - 10, y - 10), (x + w + 10, y + h + 10), color, 2)
                # 顯示當(dāng)前捕捉到了多少人臉圖片了
                font = cv2.FONT_HERSHEY_SIMPLEX
                cv2.putText(frame, 'num:%d/1000' % (num), (x + 30, y + 30), font, 1, (255, 0, 255), 4)
        # 顯示圖像 Linux 下注釋掉即可
        cv2.imshow(window_name, frame)
        c = cv2.waitKey(10)
        if c & 0xFF == ord('q'):
            break
    # 釋放攝像頭并銷毀所有窗口
    cap.release()
    cv2.destroyAllWindows()
if __name__ == '__main__':
    camera("watchdog", os.getcwd()+"/face")

代碼解析

1. 導(dǎo)入必要的模塊

# -*- coding: utf-8 -*-
# import 進(jìn)openCV的庫
import cv2
import os
import time
  • # -*- coding: utf-8 -*-:指定文件編碼為 UTF-8。
  • import cv2:導(dǎo)入 OpenCV 庫,用于圖像處理和人臉檢測。
  • import os:導(dǎo)入 os 模塊,用于文件路徑操作。
  • import time:導(dǎo)入 time 模塊,用于延遲操作。

2. 定義 camera 函數(shù)

def camera(window_name, path_name):
  • def camera(window_name, path_name)::定義一個名為 camera 的函數(shù),參數(shù) window_name 是窗口名稱,path_name 是保存截圖的路徑。

3. 創(chuàng)建窗口

    # Linux 不顯示圖形界面
    cv2.namedWindow(window_name)
  • cv2.namedWindow(window_name):創(chuàng)建一個窗口,用于顯示視頻流。在 Linux 下可以注釋掉這行代碼以不顯示圖形界面。

4. 打開攝像頭

    # 視頻來源,來自USB攝像頭
    cap = cv2.VideoCapture(0)
  • cv2.VideoCapture(0):打開默認(rèn)攝像頭。參數(shù) 0 表示默認(rèn)攝像頭。

5. 加載人臉識別分類器

    # 告訴OpenCV使用人臉識別分類器
    classfier = cv2.CascadeClassifier(os.getcwd()+"/haarcascade_frontalface_alt.xml")
  • cv2.CascadeClassifier(...):加載預(yù)訓(xùn)練的 Haar 級聯(lián)分類器,用于檢測人臉。
  • os.getcwd()+"/haarcascade_frontalface_alt.xml":指定分類器文件的路徑。

6. 設(shè)置邊框顏色

    # 識別出人臉后要畫的邊框的顏色,RGB格式, color是一個不可增刪的數(shù)組
    color = (0, 255, 0)
  • color = (0, 255, 0):定義邊框顏色為綠色。

7. 主循環(huán)

    num = 0
    while cap.isOpened():
        ok, frame = cap.read()  # 讀取一幀數(shù)據(jù)
        if not ok:
            break
        # 將當(dāng)前楨圖像轉(zhuǎn)換成灰度圖像
        grey = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
        # 人臉檢測,1.2和2分別為圖片縮放比例和需要檢測的有效點(diǎn)數(shù)
        faceRects = classfier.detectMultiScale(grey, scaleFactor=1.2, minNeighbors=3, minSize=(32, 32))
        if len(faceRects) > 0:  # 大于0則檢測到人臉
            for faceRect in faceRects:  # 單獨(dú)框出每一張人臉
                x, y, w, h = faceRect
                num = num + 1
                # 將當(dāng)前幀保存為圖片
                img_name = "%s/%d.jpg" % (path_name, num)
                image = frame[y - 10: y + h + 10, x - 10: x + w + 10]
                cv2.imwrite(img_name, image, [int(cv2.IMWRITE_PNG_COMPRESSION), 9])
                # 延遲 60s,不要太頻繁的發(fā)送,知道來了就可以了
                # time.sleep(60)
                # 畫出矩形框
                cv2.rectangle(frame, (x - 10, y - 10), (x + w + 10, y + h + 10), color, 2)
                # 顯示當(dāng)前捕捉到了多少人臉圖片了
                font = cv2.FONT_HERSHEY_SIMPLEX
                cv2.putText(frame, 'num:%d/1000' % (num), (x + 30, y + 30), font, 1, (255, 0, 255), 4)
        # 顯示圖像 Linux 下注釋掉即可
        cv2.imshow(window_name, frame)
        c = cv2.waitKey(10)
        if c & 0xFF == ord('q'):
            break
  • num = 0:初始化計數(shù)器。
  • while cap.isOpened()::進(jìn)入無限循環(huán),實時讀取攝像頭圖像。
  • ok, frame = cap.read():從攝像頭讀取一幀圖像。
  • if not ok::檢查讀取是否成功,如果失敗則退出循環(huán)。
  • grey = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY):將圖像轉(zhuǎn)換為灰度圖像。
  • faceRects = classfier.detectMultiScale(grey, scaleFactor=1.2, minNeighbors=3, minSize=(32, 32)):檢測圖像中的人臉。
  • if len(faceRects) > 0::檢查是否檢測到人臉。
  • for faceRect in faceRects::遍歷檢測到的每個人臉。
  • x, y, w, h = faceRect:獲取人臉的位置和大小。
  • num = num + 1:增加計數(shù)器。
  • img_name = "%s/%d.jpg" % (path_name, num):生成保存圖像的文件名。
  • image = frame[y - 10: y + h + 10, x - 10: x + w + 10]:裁剪人臉區(qū)域并擴(kuò)大邊界。
  • cv2.imwrite(img_name, image, [int(cv2.IMWRITE_PNG_COMPRESSION), 9]):保存圖像。
  • cv2.rectangle(frame, (x - 10, y - 10), (x + w + 10, y + h + 10), color, 2):在圖像上繪制矩形框。
  • font = cv2.FONT_HERSHEY_SIMPLEX:設(shè)置字體樣式。
  • cv2.putText(frame, 'num:%d/1000' % (num), (x + 30, y + 30), font, 1, (255, 0, 255), 4):在圖像上顯示當(dāng)前捕捉到的人臉數(shù)量。
  • cv2.imshow(window_name, frame):顯示帶有矩形標(biāo)記的圖像。
  • c = cv2.waitKey(10):等待 10 毫秒,等待用戶按鍵。
  • if c & 0xFF == ord('q')::按 ‘q’ 鍵退出循環(huán)。

8. 釋放資源

    # 釋放攝像頭并銷毀所有窗口
    cap.release()
    cv2.destroyAllWindows()
  • cap.release():釋放攝像頭資源。
  • cv2.destroyAllWindows():關(guān)閉所有 OpenCV 窗口。

9. 主程序入口

if __name__ == '__main__':
    camera("watchdog", os.getcwd()+"/face")
  • if __name__ == '__main__'::檢查是否直接運(yùn)行此腳本。
  • camera("watchdog", os.getcwd()+"/face"):調(diào)用 camera 函數(shù),傳入窗口名稱和保存截圖的路徑。

完整代碼

# -*- coding: utf-8 -*-
# import 進(jìn)openCV的庫
import cv2
import os
import time
# 調(diào)用攝像頭檢測人臉并截圖
def camera(window_name, path_name):
    # Linux 不顯示圖形界面
    cv2.namedWindow(window_name)
    # 視頻來源,來自USB攝像頭
    cap = cv2.VideoCapture(0)
    # 告訴OpenCV使用人臉識別分類器
    classfier = cv2.CascadeClassifier(os.getcwd()+"/haarcascade_frontalface_alt.xml")
    # 識別出人臉后要畫的邊框的顏色,RGB格式, color是一個不可增刪的數(shù)組
    color = (0, 255, 0)
    num = 0
    while cap.isOpened():
        ok, frame = cap.read()  # 讀取一幀數(shù)據(jù)
        if not ok:
            break
        # 將當(dāng)前楨圖像轉(zhuǎn)換成灰度圖像
        grey = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
        # 人臉檢測,1.2和2分別為圖片縮放比例和需要檢測的有效點(diǎn)數(shù)
        faceRects = classfier.detectMultiScale(grey, scaleFactor=1.2, minNeighbors=3, minSize=(32, 32))
        if len(faceRects) > 0:  # 大于0則檢測到人臉
            for faceRect in faceRects:  # 單獨(dú)框出每一張人臉
                x, y, w, h = faceRect
                num = num+1
                # 將當(dāng)前幀保存為圖片
                img_name = "%s/%d.jpg" % (path_name, num)
                image = frame[y - 10: y + h + 10, x - 10: x + w + 10]
                cv2.imwrite(img_name, image, [int(cv2.IMWRITE_PNG_COMPRESSION), 9])
                # 延遲 60s,不要太頻繁的發(fā)送,知道來了就可以了
                # time.sleep(60)
                # 畫出矩形框
                cv2.rectangle(frame, (x - 10, y - 10), (x + w + 10, y + h + 10), color, 2)
                # 顯示當(dāng)前捕捉到了多少人臉圖片了
                font = cv2.FONT_HERSHEY_SIMPLEX
                cv2.putText(frame, 'num:%d/1000' % (num), (x + 30, y + 30), font, 1, (255, 0, 255), 4)
        # 顯示圖像 Linux 下注釋掉即可
        cv2.imshow(window_name, frame)
        c = cv2.waitKey(10)
        if c & 0xFF == ord('q'):
            break
    # 釋放攝像頭并銷毀所有窗口
    cap.release()
    cv2.destroyAllWindows()
if __name__ == '__main__':
    camera("watchdog", os.getcwd()+"/face")

測試

  • 確保你的攝像頭正常工作。
  • 運(yùn)行腳本:
python3 face_detection.py
  • 打開攝像頭后,你會看到一個窗口顯示實時視頻流,并且在檢測到的人臉周圍繪制綠色矩形。
  • 按 ‘q’ 鍵退出程序。

總結(jié)

本文詳細(xì)介紹了如何使用 Python 和 OpenCV 庫實現(xiàn)攝像頭人臉檢測并截圖,并通過具體的代碼示例展示了整個過程。通過使用 cv2.VideoCapture 打開攝像頭,cv2.CascadeClassifier 加載預(yù)訓(xùn)練的 Haar 級聯(lián)分類器,cv2.cvtColor 轉(zhuǎn)換圖像顏色空間,cv2.rectangle 繪制矩形,cv2.imwrite 保存圖像,最終實現(xiàn)了在實時視頻流中檢測并保存人臉圖像的功能。

到此這篇關(guān)于使用 Python 和 OpenCV 實現(xiàn)攝像頭人臉檢測并截圖的文章就介紹到這了,更多相關(guān)Python OpenCV 人臉檢測內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 對Python3中列表乘以某一個數(shù)的示例詳解

    對Python3中列表乘以某一個數(shù)的示例詳解

    今天小編就為大家分享一篇對Python3中列表乘以某一個數(shù)的示例詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • 基于opencv實現(xiàn)手勢控制音量(案例詳解)

    基于opencv實現(xiàn)手勢控制音量(案例詳解)

    這篇文章主要介紹了基于opencv的手勢控制音量和ai換臉,通過定義了一個名為 handDetector 的類,用于檢測和跟蹤手部,結(jié)合實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08
  • Python爬蟲之UserAgent的使用實例

    Python爬蟲之UserAgent的使用實例

    今天小編就為大家分享一篇關(guān)于Python爬蟲之UserAgent的使用實例,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • flask session組件的使用示例

    flask session組件的使用示例

    這篇文章主要介紹了flask session組件的使用示例,詳細(xì)介紹內(nèi)置session以及第三方session組件的使用方法以及處理機(jī)制,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • Python基礎(chǔ)語法之容器詳解

    Python基礎(chǔ)語法之容器詳解

    這篇文章主要介紹了Python基礎(chǔ)語法之容器的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下,希望能夠給你帶來幫助
    2021-09-09
  • python升級pip及失敗處理方式

    python升級pip及失敗處理方式

    這篇文章主要介紹了python升級pip及失敗處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • python利用正則表達(dá)式搜索單詞示例代碼

    python利用正則表達(dá)式搜索單詞示例代碼

    正則表達(dá)式本身是一種小型的、高度專業(yè)化的編程語言,下面這篇文章主要給大家介紹了關(guān)于python利用正則表達(dá)式實現(xiàn)搜索單詞的相關(guān)資料,文中給出了詳細(xì)的示例代碼,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-09-09
  • 用Django寫天氣預(yù)報查詢網(wǎng)站

    用Django寫天氣預(yù)報查詢網(wǎng)站

    今天小編就為大家分享一篇關(guān)于用Django寫天氣預(yù)報查詢網(wǎng)站的文章,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • 新手如何快速入門Python(菜鳥必看篇)

    新手如何快速入門Python(菜鳥必看篇)

    下面小編就為大家?guī)硪黄率秩绾慰焖偃腴TPython(菜鳥必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • Python列表切片操作實例探究(提取復(fù)制反轉(zhuǎn))

    Python列表切片操作實例探究(提取復(fù)制反轉(zhuǎn))

    在Python中,列表切片是處理列表數(shù)據(jù)非常強(qiáng)大且靈活的方法,本文將全面探討Python中列表切片的多種用法,包括提取子列表、復(fù)制列表、反轉(zhuǎn)列表等操作,結(jié)合豐富的示例代碼進(jìn)行詳細(xì)講解
    2024-01-01

最新評論