Opencv-视频的读取

0. 写在前面

此篇博文主要记录使用Opencv4系列对视频的读取功能。

1. 视频的读取

cv::VideoCapture类是读取视频的,cv::VideoCapture既支持视频问价的读取,也支持从视频捕获的文件中读取视频数据,像笔记本的自带摄像头,外接USB的摄像头等。

创建对象的方式有三种:

cpp 复制代码
//1. 从输入的文件名对应的文件中读取
cv::VideoCapture capture(const string& fileName);
//2. 从视频捕捉设备ID中读取
cv::VideoCapture capture(int device);
//3. 调用无参构造函数创建对象
cv::VideoCapture capture();

创建完VideoCapture类之后,还需要将视频中的图像取出来,读取到cv::Mat矩阵中,共有两种方式,一种是read,一种是>>操作。

cpp 复制代码
cv::VideoCapture cap;
cap.open("xxx/xxx/xxx.mp4");

//1. read 方式
Mat frame;
cap.read(frame);
//2. >> 方式
cap >> frame;

//获取 视频中的某些属性
retval = cap.get(gropId);
//gropId代表的数字属性:
1:cv2::CAP_PROP_POS_FRAMES       从0开始索引帧,帧位置
2: cv2::CAP_PROP_POS_AVI_RATIO    视频文件的相对位置(0表示开始,1表示结束)
3: cv2::CAP_PROP_FRAME_WIDTH      视频流的帧宽度
4: cv2::CAP_PROP_FRAME_HEIGHT     视频流的帧高度
5: cv2::CAP_PROP_FPS              帧率
6: cv2::CAP_PROP_FOURCC           编解码器四字符代码
7: cv2::CAP_PROP_FRAME_COUNT      视频文件的帧

Mat img;
int num = cap.get(cv2::CAP_PROP_FRAME_COUNT);
for(int 0 = 0;i < num - 1;i++)
{
    cap.read(img);
    //do something
    //...
}

cap.release();
相关推荐
liruiqiang0531 分钟前
机器学习 - 机器学习模型的评价指标
人工智能·机器学习·分类
嘘嘘出差2 小时前
DeepSeek渣机部署编程用的模型,边缘设备部署模型
前端·人工智能·python·深度学习·语言模型·自然语言处理·deepseek
vjmap2 小时前
用AI绘制CAD气温曲线图
人工智能·ai·gis·cad·dwg
LCG元2 小时前
本地部署DeepSeek集成VSCode创建自己的AI助手
ide·人工智能·vscode
智模睿脑君2 小时前
Streamlit快速构建大模型前端框架
人工智能·python·机器学习·语言模型·自然语言处理·前端框架·word2vec
apple-mapping3 小时前
tensorflow环境中已安装库
人工智能·python·tensorflow
人工智能学起来3 小时前
入选TPAMI2025!傅里叶变换+目标检测新突破!
人工智能·目标检测·计算机视觉
紫雾凌寒3 小时前
深度学习框架探秘|TensorFlow:AI 世界的万能钥匙
人工智能·深度学习·ai·tensorflow
匆匆整棹还3 小时前
数据仓库与数据挖掘记录 一
数据仓库·人工智能·数据挖掘