OpenCV 二、视频文件的逐帧读取和任意帧读取

2023-10-17 04:30

本文主要是介绍OpenCV 二、视频文件的逐帧读取和任意帧读取,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文主要介绍在OpenCV中如何以逐帧方式和任意帧方式读取一个视频文件。

一、视频信息的读取

OpenCV中,VideoCapture类用于视频文件的读取,其方法get用于视频信息的获取。

比如获取,视频的宽高,帧数,原始视频的帧频。

VideoCapture cap;
cap.open("./test.mp4");if (!cap.isOpened())//如果视频不能正常打开则返回return 0;int frameRate = static_cast<int>(cap.get(CV_CAP_PROP_FPS));  //帧率 x frames/s
int totalFrames = static_cast<int>(cap.get(CV_CAP_PROP_FRAME_COUNT)); //总帧数
int width = static_cast<int>(cap.get(CV_CAP_PROP_FRAME_WIDTH));  //帧宽度
int height = static_cast<int>(cap.get(CV_CAP_PROP_FRAME_HEIGHT)); //帧高度cout << "视频宽度=" << width << endl;
cout << "视频高度=" << height << endl;
cout << "视频总帧数=" << totalFrames << endl;
cout << "帧率=" << frameRate << endl;

二、视频的逐帧去读

OpenCV中,从一个视频文件中按顺序逐帧获取图像是非常简单的,这里提供三种方法:

1、流操作 >> 方法

2、read()方法

3、grap()和retrieve()方法

   其实,read()方法就是将grab和retrieve整合到了一个调用函数中而已。

VideoCapture cap;
cap.open("./test.mp4");if (!cap.isOpened())//如果视频不能正常打开则返回return 0;Mat frame;double t = 0, fps = 0;while (1)
{t = (double)cv::getTickCount();//方法1://cap >> frame;//方法2://cap.read(frame);//方法3:cap.grab();cap.retrieve(frame);if (frame.empty())//如果某帧为空则退出循环break;t = ((double)cv::getTickCount() - t) / cv::getTickFrequency();fps = 1.0 / t;cout << " 帧频是: " << fps << endl;}

 

三、视频的任意帧获取

视频的任意位置获取,需要首先设置任意帧的位置,

VideoCaputure 通过其方法set设置要获取帧的位置,具体有以下几种方法:

set(CAP_PROP_POS_MSEC, 毫秒为单位的时间位置)

set(CAP_PROP_POS_FRAMES , 任意帧的索引位置)

set(CAP_PROP_POS_AVI_RATIO  , 任意帧的位置在整个视频中的位置比例, 数值为0-1)

 

比如:下面的例子是以6帧的间隔读取视频,不过亲测,读取速度较慢!

int timeStame = 0;while (1){timeStame += 6;t = (double)cv::getTickCount();cap.set(CAP_PROP_POS_FRAMES, timeStame);cap.read(frame);t = ((double)cv::getTickCount() - t) / cv::getTickFrequency();fps = 1.0 / t;cout << " 帧频是: " << fps << endl;//cap >> frame;//等价于cap.read(frame);if (frame.empty())//如果某帧为空则退出循环break;}

 

 

 

 

 

 

 

 

这篇关于OpenCV 二、视频文件的逐帧读取和任意帧读取的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/222954

相关文章

opencv图像处理之指纹验证的实现

《opencv图像处理之指纹验证的实现》本文主要介绍了opencv图像处理之指纹验证的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、简介二、具体案例实现1. 图像显示函数2. 指纹验证函数3. 主函数4、运行结果三、总结一、

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

解决Java中基于GeoTools的Shapefile读取乱码的问题

《解决Java中基于GeoTools的Shapefile读取乱码的问题》本文主要讨论了在使用Java编程语言进行地理信息数据解析时遇到的Shapefile属性信息乱码问题,以及根据不同的编码设置进行属... 目录前言1、Shapefile属性字段编码的情况:一、Shp文件常见的字符集编码1、System编码

利用Python实现添加或读取Excel公式

《利用Python实现添加或读取Excel公式》Excel公式是数据处理的核心工具,从简单的加减运算到复杂的逻辑判断,掌握基础语法是高效工作的起点,下面我们就来看看如何使用Python进行Excel公... 目录python Excel 库安装Python 在 Excel 中添加公式/函数Python 读取

详解如何使用Python提取视频文件中的音频

《详解如何使用Python提取视频文件中的音频》在多媒体处理中,有时我们需要从视频文件中提取音频,本文为大家整理了几种使用Python编程语言提取视频文件中的音频的方法,大家可以根据需要进行选择... 目录引言代码部分方法扩展引言在多媒体处理中,有时我们需要从视频文件中提取音频,以便进一步处理或分析。本文

通过Python脚本批量复制并规范命名视频文件

《通过Python脚本批量复制并规范命名视频文件》本文介绍了如何通过Python脚本批量复制并规范命名视频文件,实现自动补齐数字编号、保留原始文件、智能识别有效文件等功能,听过代码示例介绍的非常详细,... 目录一、问题场景:杂乱的视频文件名二、完整解决方案三、关键技术解析1. 智能路径处理2. 精准文件名

Python如何实现读取csv文件时忽略文件的编码格式

《Python如何实现读取csv文件时忽略文件的编码格式》我们再日常读取csv文件的时候经常会发现csv文件的格式有多种,所以这篇文章为大家介绍了Python如何实现读取csv文件时忽略文件的编码格式... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍我们再日常读取csv文件的时候经常

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

Java如何获取视频文件的视频时长

《Java如何获取视频文件的视频时长》文章介绍了如何使用Java获取视频文件的视频时长,包括导入maven依赖和代码案例,同时,也讨论了在运行过程中遇到的SLF4J加载问题,并给出了解决方案... 目录Java获取视频文件的视频时长1、导入maven依赖2、代码案例3、SLF4J: Failed to lo

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j