开始正式写东西 python是比 c++简单多了hh

一. 图片人脸检测

opencv里面已经提供好了人脸分类模型 下载地址:https://github.com/opencv/ope... 可全部下载到本地 下载的xml.zip 别忘了解压

实现思路,主要包括三方面内容:
(1)图像变为灰度图像(降低计算强度)
(2)在图像上画矩形
(上述两方面内容就直接利用opencv提供的函数接口就行了)
(3)利用OpenCV训练好的人脸分类模型查找人脸

import cv2

filepath = "./8.jpg"
img = cv2.imread(filepath)  # 读取图片
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)  # 转换灰色

# OpenCV人脸识别分类器
# 先拿到分类器classifier
classifier = cv2.CascadeClassifier(
    "D://opencv-python//opencv-github//haarcascade_frontalface_default.xml")
color = (0, 255, 0)  # 定义绘制颜色
# 调用识别人脸detectMultiScale  gray是输入图像 scaleFactor图像缩放比例 
# minNeighbors特征检测点周边有多少有效点被同时检测 可以避免遗漏 minSize是特征检测点的最小尺寸
faceRects = classifier.detectMultiScale(gray,
                                        scaleFactor=1.2,
                                        minNeighbors=3,
                                        minSize=(32, 32))
if len(faceRects):  # 大于0则是说明检测到人脸
    for faceRect in faceRects:  # 单独框出每一张人脸
        x, y, w, h = faceRect
        # 框出人脸
        cv2.rectangle(img, (x, y), (x + h, y + w), color, 2)
        # 左眼
        cv2.circle(img, (x + w // 4, y + h // 4 + 30), min(w // 8, h // 8),
                   color)
        # 右眼
        cv2.circle(img, (x + 3 * w // 4, y + h // 4 + 30), min(w // 8, h // 8),
                   color)
        # 嘴巴
        cv2.rectangle(img, (x + 3 * w // 8, y + 3 * h // 4),
                      (x + 5 * w // 8, y + 7 * h // 8), color)

cv2.imshow("image", img)  # 显示图像
c = cv2.waitKey(10)

cv2.waitKey(0)

image.png

image.png
我大威少不配被检测呗 hhh 下面单独把威少拎出来 还是没检测出来
image.png
再试一个斜的侧脸 都没检测出来
image.png
看来 opencv这个训练的还是有缺陷

二.视频人脸检测

基于视频检测的也是在图片检测的基础上进行的 调用电脑摄像头 把摄像信息逐帧分解成图片,然后检测出图片中人脸位置

# -*- coding:utf-8 -*-
# OpenCV版本的视频检测
import cv2


# 图片识别方法封装
def discern(img):
    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    cap = cv2.CascadeClassifier(
        "D://opencv-python//opencv-github//haarcascade_frontalface_default.xml"
    )
    faceRects = cap.detectMultiScale(gray,
                                     scaleFactor=1.2,
                                     minNeighbors=3,
                                     minSize=(50, 50))
    if len(faceRects):
        for faceRect in faceRects:
            x, y, w, h = faceRect
            cv2.rectangle(img, (x, y), (x + h, y + w), (0, 255, 0), 2)  # 框出人脸
    cv2.imshow("Image", img)


# 获取摄像头0表示第一个摄像头
cap = cv2.VideoCapture(0)
while (1):  # 逐帧显示
    ret, img = cap.read()
    # cv2.imshow("Image", img)
    discern(img)
    if cv2.waitKey(1) & 0xFF == ord('q'):
        break
cap.release()  # 释放摄像头
cv2.destroyAllWindows()  # 释放窗口资源

8c06e193e8b424576ba27f6b50fe8222_video-jiance.gif
这不是我 是写程序的大佬hh 我自己也试了 效果可以的

学习自:
https://github.com/vipstone/f...
https://github.com/vipstone/f...


胡子老爷爷
1 声望2 粉丝

种一棵树最好的时间是十年前,其次是现在!