七、OpenCV中的视频的读写

文章目录

一、视频的播放

cpp 复制代码
#include <opencv2/opencv.hpp>
#include <iostream>

using namespace cv;
using namespace std;

int main() {
    // 打开默认摄像头(0 表示第一个摄像头)
    VideoCapture cap(0);
    if (!cap.isOpened()) {
        cerr << "无法打开摄像头!" << endl;
        return -1;
    }

    // 获取摄像头帧率
    double fps = cap.get(CAP_PROP_FPS);
    cout << "Camera FPS: " << fps << endl;

    Mat frame;
    int imgCount = 0;

    while (true) {
        cap >> frame; // 捕获一帧
        if (frame.empty()) {
            cerr << "无法获取摄像头图像!" << endl;
            break;
        }

        imshow("Camera", frame);

        int key = waitKey(30);
        if (key == 27) { // ESC 退出
            break;
        } else if (key == 32) { // 空格键拍照
            string filename = "photo_" + to_string(imgCount++) + ".jpg";
            imwrite(filename, frame);
            cout << "已保存: " << filename << endl;
        }
    }

    cap.release();
    destroyAllWindows();
    return 0;
}

二、打开摄像头,并拍照

cpp 复制代码
#include <opencv2/opencv.hpp>
#include <iostream>

using namespace cv;
using namespace std;

int main() {
    // 打开默认摄像头(0 表示第一个摄像头)
    VideoCapture cap(0);
    if (!cap.isOpened()) {
        cerr << "无法打开摄像头!" << endl;
        return -1;
    }

    // 获取摄像头帧率
    double fps = cap.get(CAP_PROP_FPS);
    cout << "Camera FPS: " << fps << endl;

    Mat frame;
    int imgCount = 0;

    while (true) {
        cap >> frame; // 捕获一帧
        if (frame.empty()) {
            cerr << "无法获取摄像头图像!" << endl;
            break;
        }

        imshow("Camera", frame);

        int key = waitKey(30);
        if (key == 27) { // ESC 退出
            break;
        } else if (key == 32) { // 空格键拍照
            string filename = "photo_" + to_string(imgCount++) + ".jpg";
            imwrite(filename, frame);
            cout << "已保存: " << filename << endl;
        }
    }

    cap.release();
    destroyAllWindows();
    return 0;
}

三、人脸检测 + 自动拍照(检测到人脸时保存照片)

cpp 复制代码
#include <opencv2/opencv.hpp>
#include <iostream>

using namespace cv;
using namespace std;

int main() {
    // 加载人脸分类器(OpenCV 自带的 XML 文件)
    CascadeClassifier face_cascade;
    if (!face_cascade.load("haarcascade_frontalface_default.xml")) {
        cerr << "无法加载人脸检测模型!" << endl;
        return -1;
    }

    // 打开摄像头
    VideoCapture cap(0);
    if (!cap.isOpened()) {
        cerr << "无法打开摄像头!" << endl;
        return -1;
    }

    Mat frame, gray;
    while (true) {
        cap >> frame;
        if (frame.empty()) break;

        // 转灰度图(检测人脸时建议用灰度图)
        cvtColor(frame, gray, COLOR_BGR2GRAY);
        equalizeHist(gray, gray); // 直方图均衡化,提高检测效果

        // 检测人脸
        vector<Rect> faces;
        face_cascade.detectMultiScale(
            gray, faces,
            1.1,        // 缩放因子
            3,          // 最小邻居数
            0,          // 标志位
            Size(30, 30) // 最小检测目标
        );

        // 在原图上画矩形框
        for (size_t i = 0; i < faces.size(); i++) {
            rectangle(frame, faces[i], Scalar(0, 255, 0), 2); // 绿色框
        }

        imshow("Face Detection", frame);

        // 按 ESC 退出
        if (waitKey(30) == 27) break;
    }

    cap.release();
    destroyAllWindows();
    return 0;
}
相关推荐
Daydream.V1 天前
基于Opencv和Dlib的人脸换脸实现
人工智能·opencv·计算机视觉·仿射变换·换脸·视频换脸·图片换脸
Westward-sun.1 天前
背景建模详解与OpenCV实现:从原理到代码实战
人工智能·opencv·计算机视觉
学习永无止境@1 天前
Sobel边缘检测的MATLAB实现
图像处理·opencv·算法·计算机视觉·fpga开发
纤纡.1 天前
基于 OpenCV 与 MediaPipe/Dlib 的计算机视觉实战:手势识别、仿射变换与 AI 换脸全解析
人工智能·opencv·计算机视觉
qq_385999081 天前
Win7 64 位 + MinGW64 + CMake + OpenCV
opencv
Westward-sun.1 天前
OpenCV实战:摄像头实时文档扫描与透视矫正
人工智能·opencv·计算机视觉
不懒不懒1 天前
《从仿射变换到实时手势识别:构建完整换脸与手势交互系统的全流程指南》
人工智能·opencv·计算机视觉
sali-tec1 天前
C# 基于OpenCv的视觉工作流-章46-矩形卡尺
图像处理·人工智能·opencv·算法·计算机视觉
Gary jie2 天前
OpenClaw4月更新的梦境记忆巩固系统
人工智能·深度学习·opencv·目标检测·机器学习·长短时记忆网络
Westward-sun.2 天前
OpenCV 实战:基于 SIFT 算法实现指纹图像验证
人工智能·opencv·计算机视觉