opencv视频文件的读取,处理与保存

文章目录

      • opencv视频文件的读取,处理与保存
        • 一、视频文件的读取:
          • 1、cv::VideoCapture是OpenCV库中用于处理视频输入的类,它提供了一种简单的方法来从摄像头,视频文件、或图像序列中读取帧;
            • (1)打开摄像头:
            • (2)打开视频文件:
            • (3)打开网络摄像头:
            • (4)打开图像序列:
          • 2、cv::VideoCapture类的常用方法:
            • (1)capture.get():用于获取视频的属性,比如帧数、帧率等:
            • (2)capture.set(int propId, double value):用于设置视频的属性,比如设置视频的帧率、帧大小等属性;
            • (3)capture.read(cv::Mat& frame):用于读取视频的一帧,将其存储在 `cv::Mat` 对象中;
            • (4)capture.release():用于释放 `VideoCapture` 对象所占用的资源,一般在你已经完成了对视频流的操作后调用它;
        • 二、对视频帧进行处理:
        • 三、保存处理后的视频:
          • 1、cv::VideoWriter 是opencv中用于将图像帧序列保存为视频文件的类,它可以将处理过的帧写入一个视频文件,也可以将视频流输出到摄像头或网络;
            • (1)创建一个 cv::VideoWriter 对象:
          • 2、cv::VideoWriter类的常用方法:
            • (1)cv::VideoWriter::open():用于打开一个视频文件或设备以便写入视频帧;
            • (2)cv::VideoWriter::write():用于将一帧图像写入视频文件;
            • (3)cv::VideoWriter::isOpened():用于检查VideoWriter对象是否成功打开,如果成功打开了视频文件或者设备,该方法将返回true,否则返回false;
            • (4)cv::VideoWriter::release():用于释放VideoWriter对象所占用的资源,一般在你已经完成了对视频的写入操作后调用它;

opencv视频文件的读取,处理与保存

一、视频文件的读取:
1、cv::VideoCapture是OpenCV库中用于处理视频输入的类,它提供了一种简单的方法来从摄像头,视频文件、或图像序列中读取帧;
(1)打开摄像头:
cv::VideoCapture capture(int index)参数解释:
index:打开指定编号的摄像头,编号0表示默认摄像头,如果你的计算机连接了多个摄像头,你可以使用不同的编号来选择不同的摄像头;
(2)打开视频文件:
cv::VideoCapture capture(const std::string& filename)参数解释:
filename:打开指定的视频文件,你需要提供视频文件的路径和名称作为参数;
(3)打开网络摄像头:
cv::VideoCapture capture(const std::string& apiKey, const std::string& deviceId)参数解释:
用于打开网络摄像头,需要提供相应的API密钥和设备ID;
(4)打开图像序列:
cv::VideoCapture capture(const std::string& pattern, int api)参数解释:
用于打开图像序列,需要提供文件名模式(通配符)和相应的API;
2、cv::VideoCapture类的常用方法:
(1)capture.get():用于获取视频的属性,比如帧数、帧率等:
capture.get(int propId)参数解释:
propId:是一个整数参数,用于指定你想获取的属性类型(cv::CAP_PROP_FRAME_COUNT:获取视频的帧数;cv::CAP_PROP_FPS:获取视频的帧率(每秒帧数);cv::CAP_PROP_FRAME_WIDTH:视频帧的宽度;cv::CAP_PROP_FRAME_HEIGHT:视频帧的高度;
)

示例:

#include <opencv2\opencv.hpp>
#include <iostream>
#include <demo.h>using namespace cv;
using namespace std;int main() {// 初始化一个cv::VideoCapture对象,打开视频文件VideoCapture capture("C:\\cpp\\image\\cayenne.mp4");if (!capture.isOpened()) {std::cerr << "Error: 无法打开视频文件." << std::endl;return -1;}// 调用cv::VideoCapture类的get()方法,获取视频宽度,高度,帧数,帧率int frameWidth = capture.get(cv::CAP_PROP_FRAME_WIDTH);int frameHeight = capture.get(cv::CAP_PROP_FRAME_HEIGHT);int frameCount = capture.get(cv::CAP_PROP_FRAME_COUNT);double fps = capture.get(cv::CAP_PROP_FPS);std::cout << "frame width:" << frameWidth << std::endl;std::cout << "frame height:" << frameHeight << std::endl;std::cout << "Number of Frames:" << frameCount << std::endl;std::cout << "FPS:" << fps << std::endl;capture.release(); // 释放VideoCapture对象
}
(2)capture.set(int propId, double value):用于设置视频的属性,比如设置视频的帧率、帧大小等属性;
capture.set(int propId, double value)参数解释:
propId:指定了你想设置的属性类型;
value:要设置的值;

示例:

cv::VideoCapture capture(0); // 打开默认摄像头if (!capture.isOpened()) {std::cerr << "Error: 无法打开摄像头." << std::endl;return -1;
}capture.set(cv::CAP_PROP_FRAME_WIDTH, 1280);
capture.set(cv::CAP_PROP_FRAME_HEIGHT, 720);
capture.set(cv::CAP_PROP_FPS, 30);capture.release(); // 释放VideoCapture对象
(3)capture.read(cv::Mat& frame):用于读取视频的一帧,将其存储在 cv::Mat 对象中;

示例:

cv::VideoCapture capture("video_file.mp4");if (!capture.isOpened()) {std::cerr << "Error: 无法打开视频文件." << std::endl;return -1;
}cv::Mat frame;
capture.read(frame);// 在这里可以对 frame 进行处理capture.release(); // 释放VideoCapture对象
(4)capture.release():用于释放 VideoCapture 对象所占用的资源,一般在你已经完成了对视频流的操作后调用它;
二、对视频帧进行处理:

循环遍历视频的每一帧,可以在循环内部对每一帧进行处理在这里,我注释掉了处理部分,你可以根据需要添加各种图像处理操作,比如滤波、边缘检测等;

代码示例:

#include <opencv2\opencv.hpp>
#include <iostream>
#include <demo.h>using namespace cv;
using namespace std;int main() {// 打开视频文件VideoCapture capture("C:\\cpp\\image\\cayenne.mp4");// 检查视频是否成功打开if (!capture.isOpened()) {std::cerr << "Error: 无法打开视频文件." << std::endl;return -1;}// 获取视频的帧数和帧率int frameCount = capture.get(cv::CAP_PROP_FRAME_COUNT);double fps = capture.get(cv::CAP_PROP_FPS);// 创建一个VideoWriter对象来保存处理后的视频cv::VideoWriter outVideo("outVideo.mp4", capture.get(CAP_PROP_FOURCC), fps, cv::Size(capture.get(cv::CAP_PROP_FRAME_WIDTH), capture.get(cv::CAP_PROP_FRAME_HEIGHT)));// 循环处理视频的每一帧for (int i = 0; i < frameCount; ++i) {cv::Mat frame;capture >> frame; // 读取一帧if (frame.empty()) {break;}// 在这里可以对frame进行处理,比如进行滤波、边缘检测等// 例如:cv::cvtColor(frame, frame, cv::COLOR_BGR2GRAY);// 将处理后的帧写入输出视频文件outVideo << frame;}// 释放VideoCapture和VideoWriter对象capture.release();outVideo.release();std::cout << "视频处理完成." << std::endl;
}
三、保存处理后的视频:
1、cv::VideoWriter 是opencv中用于将图像帧序列保存为视频文件的类,它可以将处理过的帧写入一个视频文件,也可以将视频流输出到摄像头或网络;
(1)创建一个 cv::VideoWriter 对象:

函数原型:

cv::VideoWriter writer(const String& filename, int fourcc, double fps, Size frameSize, bool isColor = true)参数解释:
filename:要保存的视频文件名或者设备地址;
fourcc:FourCC编码,指定视频编解码器的类型(cv::VideoWriter::fourcc('X','V','I','D'):Xvid编解码器;cv::VideoWriter::fourcc('M','J','P','G'):MJPEG编解码器;cv::VideoWriter::fourcc('M','P','4','V'):MPEG-4编解码器;cv::VideoWriter::fourcc('H','2','6','4'):H.264编解码器;
);
fps:帧率,即每秒显示的帧数;
frameSize:帧的大小,可以通过cv::Size类指定;
isColor:指定保存的视频是否为彩色,默认为true
2、cv::VideoWriter类的常用方法:
(1)cv::VideoWriter::open():用于打开一个视频文件或设备以便写入视频帧;
cv::VideoWriter::open(const String& filename, int fourcc, double fps, Size frameSize, bool isColor = true)参数解释:参数和构造函数类似;
filename:要保存的视频文件名或者设备地址;
fourcc:FourCC编码,指定视频编解码器的类型(cv::VideoWriter::fourcc('X','V','I','D'):Xvid编解码器;cv::VideoWriter::fourcc('M','J','P','G'):MJPEG编解码器;cv::VideoWriter::fourcc('M','P','4','V'):MPEG-4编解码器;cv::VideoWriter::fourcc('H','2','6','4'):H.264编解码器;
);
fps:帧率,即每秒显示的帧数;
frameSize:帧的大小,可以通过cv::Size类指定;
isColor:指定保存的视频是否为彩色,默认为true
(2)cv::VideoWriter::write():用于将一帧图像写入视频文件;
cv::VideoWriter::write(const Mat& image)参数解释:
image:要写入视频的帧,通常是一个cv::Mat对象;
(3)cv::VideoWriter::isOpened():用于检查VideoWriter对象是否成功打开,如果成功打开了视频文件或者设备,该方法将返回true,否则返回false;
(4)cv::VideoWriter::release():用于释放VideoWriter对象所占用的资源,一般在你已经完成了对视频的写入操作后调用它;

示例:

我们首先创建了一个 VideoWriter 对象,指定了视频文件的名称、FourCC编码、帧率和帧大小。接着,我们检查是否成功打开了文件。然后,我们创建了一个红色的帧(640x480 大小的纯红色图像)并将其写入视频文件10次。最后,我们释放了 VideoWriter 对象。

#include <opencv2\opencv.hpp>
#include <iostream>
#include <demo.h>using namespace cv;
using namespace std;int main() {Demo demo;// 初始化一个cv::VideoCapture对象,打开视频文件VideoCapture capture("C:\\cpp\\image\\cayenne.mp4");// 调用cv::VideoCapture类的get()方法,获取视频宽度,高度,帧数,帧率int frame_width = capture.get(CAP_PROP_FRAME_WIDTH);int frame_height = capture.get(CAP_PROP_FRAME_HEIGHT);int count = capture.get(CAP_PROP_FRAME_COUNT);double fps = capture.get(CAP_PROP_FPS);std::cout << "frame width:" << frame_width << std::endl;std::cout << "frame height:" << frame_height << std::endl;std::cout << "FPS:" << fps << std::endl;std::cout << "Number of Frames:" << count << std::endl;// 初始化一个cv::VideoWriter 对象,保存处理后的视频文件// capture.get(CAP_PROP_FOURCC):获取原视频的编解码器// Size(frame_width, frame_height):原视频的宽高VideoWriter writer("C:\\cpp\\image\\test.mp4", capture.get(CAP_PROP_FOURCC), fps, Size(frame_width, frame_height), true);Mat frame;while (true) {// 读取视频的一帧,将其存储在frame对象中capture.read(frame);// TODO: do something...// 对读取到的这帧图像,做flip()翻转处理flip(frame, frame, 1);if (frame.empty()) {break;}// 显示这帧图像imshow("frame", frame);// 对这帧图像,做色彩空间转换demo.colorSpace(frame);// 将这帧图像写入视频文件writer.write(frame);int c = waitKey(1);if (c == 27) { // 退出break;}}// releasecapture.release();writer.release();
}

做色彩空间转换 demo.colorSpace()函数如下:

void Demo::colorSpace(Mat &image) {Mat gray, hsv;// 转hsvcvtColor(image, hsv, COLOR_BGR2HSV);// 转灰度cvtColor(image, gray, COLOR_BGR2GRAY);// 显示这两张图imshow("HSV",hsv);imshow("GARY", gray);// 保存这两张图imwrite("C:\\cpp\\vs\\opencv\\hsv.png", hsv);imwrite("C:\\cpp\\vs\\opencv\\gray.png", gray);}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/147678.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

想要精通算法和SQL的成长之路 - 验证二叉搜索树和不同的二叉搜索树

想要精通算法和SQL的成长之路 - 验证二叉搜索树和不同的二叉搜索树 前言一. 验证二叉搜索树二. 不同的二叉搜索树三. 不同的二叉搜索树II 前言 想要精通算法和SQL的成长之路 - 系列导航 二叉搜索树的定义&#xff1a; 节点的左子树只包含 小于 当前节点的数。节点的右子树只包…

【前段基础入门之】=>CSS浮动

浮动的简介 在最初&#xff0c;浮动是用来实现文字环绕图片效果的&#xff0c;现在浮动是主流的页面布局方式之一。 元素浮动后的特点 &#x1f922; 脱离文档流。&#x1f60a; 不管浮动前是什么元素&#xff0c;浮动后&#xff1a;默认宽与高都是被内容撑开&#xff08;尽…

GRACE-FO L2产品的发布说明 - 版本UTCSR RL-06.1产品

数据更新日期&#xff1a;2023-5-11 0&#xff09;此说明取代了所有先前与UTCSR-RL06.1 GRACE-FO Level-2产品相关的旧版本发布说明。 1&#xff09;截止到本发布说明日期的GRACE-FO RL-06.1产品文件列表如下&#xff1a; 2&#xff09;通常情况下&#xff0c;每个日历月有四…

游戏逆向中的 NoClip 手段和安全应对方式

文章目录 墙壁边界寻找碰撞 NoClip 是一种典型的黑客行为&#xff0c;允许你穿过墙壁&#xff0c;所以 NoClip 又可以认为是避免碰撞体积的行为 墙壁边界 游戏中设置了碰撞体作为墙壁边界&#xff0c;是 玩家对象 和墙壁发生了碰撞&#xff0c;而不是 相机 玩家对象有他的 X…

从 0 到 1 ,手把手教你编写《消息队列》项目(Java实现) —— 核心类持久化存储

文章目录 一、持久化存储的方式与路径二、公共模块序列化 / 反序列化异常规定 三、持久化存储数据库数据管理文件数据管理读写规定新增 /删除规定内存中 Message 的规定存储规定代码编写 硬盘数据管理 一、持久化存储的方式与路径 交换机,队列,绑定关系,这些我们使用数据库来管…

警用装备管理系统|智装备DW-S304的主要功能

东识科技&#xff08;DONWIT&#xff09;警用装备管理系统DW-S304是依托互3D技术、云计算、大数据、RFID技术、数据库技术、AI、视频分析技术对RFID智能仓库进行统一管理、分析的信息化、智能化、规范化的系统。 在国外很早开始便使用警用装备管理系统对警用装备的管理使用进行…

Explain执行计划字段解释说明---select_type、table、patitions字段说明

1、select_type的类型有哪些 2、select_type的查询类型说明 1、SIMPLE 简单的 select 查询,查询中不包含子查询或者UNION 2、PRIMARY 查询中若包含任何复杂的子部分&#xff0c;最外层查询则被标记为Primary 3、DERIVED 在FROM列表中包含的子查询被标记为DERIVED(衍生)&…

基于ssm的互联网废品回收/基于web的废品资源利用系统

摘 要 本毕业设计的内容是设计并且实现一个基于SSM框架的互联网废品回收。它是在Windows下&#xff0c;以MYSQL为数据库开发平台&#xff0c;Tomcat网络信息服务作为应用服务器。互联网废品回收的功能已基本实现&#xff0c;主要包括用户、回收员、物品分类、回收物品、用户下单…

【Python 基础 2023 最新】第七课 Pandas

【Python 基础 2022 最新】第七课 Pandas 概述Pandas 是什么?Pandas 的应用场景安装 Pandas Pandas 数据结构Series 数组什么是 Series?Series 创建 Series 数组操作数据检索数据修改过滤Series 数组运算总结 什么是 DataFrameDataFrame 创建 DataFrame 操作数据检索筛选数据…

决策树C4.5算法的技术深度剖析、实战解读

目录 一、简介决策树&#xff08;Decision Tree&#xff09;例子&#xff1a; 信息熵&#xff08;Information Entropy&#xff09;与信息增益&#xff08;Information Gain&#xff09;例子&#xff1a; 信息增益比&#xff08;Gain Ratio&#xff09;例子&#xff1a; 二、算…

密码技术 (6) - 证书

一. 前言 前面介绍的公钥密码和数字签名&#xff0c;都无法解决一个问题&#xff0c;那就是判断自己获取的公钥是否期望的&#xff0c;不能确定公钥是否被中间攻击人掉包。所以&#xff0c;证书的作用是用来证明公钥是否合法的。本文介绍的证书就是解决证书的可靠性的技术。 二…

最新反编译小程序教程(支持分包一键反编译),反编译成功率高达99%

最新反编译小程序教程&#xff08;支持分包一键反编译&#xff09;&#xff0c;反编译成功率高达99% 优点&#xff1a; 1.支持多个分包以及主包一次性反编译&#xff1b; 2.使用wxappUnpacker无法进行解析的小程序包&#xff0c;一键反编译解析&#xff08;咱没有发现反编译失败…

使用ExLlamaV2在消费级GPU上运行Llama2 70B

Llama 2模型中最大也是最好的模型有700亿个参数。一个fp16参数的大小为2字节。加载Llama 270b需要140 GB内存(700亿* 2字节)。 只要我们的内存够大&#xff0c;我们就可以在CPU上运行上运行Llama 2 70B。但是CPU的推理速度非常的慢&#xff0c;虽然能够运行&#xff0c;速度我…

正点原子嵌入式linux驱动开发——TF-A移植

经过了之前的学习&#xff0c;除了TF-A的详细启动流程仍待更新&#xff0c;TF-A的使用和其对应的大致启动流程已经进行过了学习。但是当我们实际做产品时&#xff0c;硬件平台肯定会和ST官方的有区别&#xff0c;比如DDR容量会改变&#xff0c;自己的硬件没有使用到官方EVK开发…

[ruby on rails] postgres sql explain 优化

一、查看执行计划 sql User.all.to_sql # 不会实际执行查询 puts ActiveRecord::Base.connection.explain(sql)# 会实际执行查询&#xff0c;再列出计划 User.all.explain# 会实际执行查询&#xff0c;再列出计划 ActiveRecord::Base.connection.execute(EXPLAIN (ANALYZE, V…

EM聚类(下):用EM算法对王者荣耀英雄进行划分

⭐️⭐️⭐️⭐️⭐️欢迎来到我的博客⭐️⭐️⭐️⭐️⭐️ &#x1f434;作者&#xff1a;秋无之地 &#x1f434;简介&#xff1a;CSDN爬虫、后端、大数据领域创作者。目前从事python爬虫、后端和大数据等相关工作&#xff0c;主要擅长领域有&#xff1a;爬虫、后端、大数据…

Vscode 如何创建java项目,并添加包

创建java项目 添加包 先打开这个资源管理器中的javaProject&#xff0c;然后打开这个javaProject&#xff0c;点击里面的Reference Libraries,然后点击加号 选择要添加的包然后进行确认即可

《C和指针》笔记30:函数声明数组参数、数组初始化方式和字符数组的初始化

文章目录 1. 函数声明数组参数2. 数组初始化方式2.1 静态初始化2.2 自动变量初始化 2.2 字符数组的初始化 1. 函数声明数组参数 下面两个函数原型是一样的&#xff1a; int strlen( char *string ); int strlen( char string[] );可以使用任何一种声明&#xff0c;但哪个“更…

小狐狸ChatGPT付费创作系统V2.0.4智能问答小程序,修复一个pc版的bug

狸GPT付费体验系统是一款基于ThinkPHP框架开发的AI问答小程序&#xff0c;是基于国外很火的ChatGPT进行开发的Ai智能问答小程序。 当前全民热议ChatGPT&#xff0c;流量超级大&#xff0c;引流不要太简单&#xff01;一键下单即可拥有自己的GPT&#xff01;无限多开、免费更新不…

OpenCV实现视频的追踪(meanshift、Camshift)

目录 1&#xff0c;meanshift 1.1 算法流程 1.2 算法实现 1.3 代码实现 1.4 结果展示 1&#xff0c;meanshift 1.1 算法流程 1.2 算法实现 1.3 代码实现 import numpy as np import cv2 as cv# 读取视频 cap cv.VideoCapture(video.mp4)# 检查视频是否成功打开 if n…