OpenCV打开电脑摄像头进行人脸识别

一:VS创建解决方案

二:配置项目环境,在另外一篇文章中有提及到:VS2022与OpenCV4.5.5的配置-CSDN博客

三:解析代码

        1.获取摄像头数据显示在“读取视频”的界面上,其中 VideoCapture capture(0); 中的参数0代表默认摄像头。

	//使用opencv打开默认摄像头
    VideoCapture capture(0);

    while (true) {
        Mat frame;
        capture >> frame;
        imshow("读取视频", frame);
        waitKey(30);
    }

        2.加载Haar级联人脸检测器

    // 加载Haar级联人脸检测器
    cv::CascadeClassifier face_cascade;
    face_cascade.load("D:/opencv/opencv/build/etc/haarcascades/haarcascade_frontalface_alt.xml");

        3. 转化为灰度图像进行识别,然后将坐标存放在容器中用于绘制

        // 转换为灰度图像
        cv::Mat gray;
        cv::cvtColor(frame, gray, cv::COLOR_BGR2GRAY);

        // 检测人脸存放坐标
        std::vector<cv::Rect> faces;
        face_cascade.detectMultiScale(
            gray, faces, 1.1, 2, 0 | cv::CASCADE_SCALE_IMAGE, cv::Size(30, 30)
        );

        4.绘制显示识别结果(灰度图像识别,原始图像绘制)

         // 为每个人脸画框
        for (size_t i = 0; i < faces.size(); i++) {
            cv::rectangle(frame, faces[i], cv::Scalar(255, 0, 0), 2);
        }

        // 显示结果
        cv::imshow("Face Detection", frame);

        5.释放摄像头资源

    // 释放摄像头资源
    capture.release();
    cv::destroyAllWindows();

四:总代码

#include <iostream>
#include <opencv2/opencv.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/objdetect/objdetect.hpp>

using namespace std;
using namespace cv;

int main()
{
	//使用opencv打开默认摄像头
    VideoCapture capture(0);

    // 加载Haar级联人脸检测器
    cv::CascadeClassifier face_cascade;
    face_cascade.load("D:/opencv/opencv/build/etc/haarcascades/haarcascade_frontalface_alt.xml");

    cv::Mat frame;
    while (true) {
        capture >> frame; // 从摄像头读取一帧
        if (frame.empty()) {
            break; // 如果帧为空,则退出循环
        }

        // 转换为灰度图像
        cv::Mat gray;
        cv::cvtColor(frame, gray, cv::COLOR_BGR2GRAY);

        // 检测人脸存放坐标
        std::vector<cv::Rect> faces;
        face_cascade.detectMultiScale(
            gray, faces, 1.1, 2, 0 | cv::CASCADE_SCALE_IMAGE, cv::Size(30, 30)
        );

         // 为每个人脸画框
        for (size_t i = 0; i < faces.size(); i++) {
            cv::rectangle(frame, faces[i], cv::Scalar(255, 0, 0), 2);
        }

        // 显示结果
        cv::imshow("Face Detection", frame);

        // 按'q'退出循环
        if (cv::waitKey(10) == 'q') {
            break;
        }
    }

    // 释放摄像头资源
    capture.release();
    cv::destroyAllWindows();
    return 0;
}

        在总代码中有些头文件不是必须包含的,根据自己情况需求而定 。

在Python中,你可以利用OpenCV (Open Source Computer Vision Library) 和 face_recognition 这两个库来实现通过电脑摄像头进行人脸识别的功能。以下是简单的步骤: 1. 安装必要的库: - 首先,你需要安装`opencv-python`和`face_recognition`,可以使用pip命令进行安装: ``` pip install opencv-python face_recognition ``` 2. 导入所需模块: ```python import cv2 import face_recognition ``` 3. 打开摄像头并捕获视频流: ```python video_capture = cv2.VideoCapture(0) # 0通常代表内置摄像头,如果有多台,也可以用1、2等代替 ``` 4. 读取帧并预处理人脸数据: ```python while True: ret, frame = video_capture.read() if not ret: break small_frame = cv2.resize(frame, (0, 0), fx=0.25, fy=0.25) # 缩小图像便于处理 rgb_small_frame = small_frame[:, :, ::-1] # BGR转RGB,因为face_recognition需要RGB格式 face_locations = face_recognition.face_locations(rgb_small_frame) # 获取人脸位置 faces_encodings = face_recognition.face_encodings(rgb_small_frame, face_locations) # 计算人脸编码 ``` 5. 可选地,将获取到的人脸信息与已知的人脸进行匹配: ```python if len(face_encodings) > 0: known_faces = [] # 假设你有一个已知人脸列表 for encoding in faces_encodings: matches = face_recognition.compare_faces(known_faces, encoding) name = "Unknown" if True in matches: # 如果找到匹配的人脸 first_match_index = matches.index(True) name = known_face_names[first_match_index] cv2.putText(frame, name, (face_locations[0][0], face_locations[0][1]-10), cv2.FONT_HERSHEY_SIMPLEX, 0.9, (0, 255, 0), 2) cv2.imshow('Video', frame) if cv2.waitKey(1) & 0xFF == ord('q'): # 按下 'q' 键退出 break ``` 6. 最后别忘了关闭摄像头和窗口: ```python video_capture.release() cv2.destroyAllWindows() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值