OpenCV VideoCapture类使用
来源:互联网 发布:淘宝天猫店要多少钱 编辑:程序博客网 时间:2024/05/18 01:58
opencv中通过VideoCaptrue类对视频进行读取操作以及调用摄像头,下面是该类的API。
1.VideoCapture类的构造函数:
C++: VideoCapture::VideoCapture()C++: VideoCapture::VideoCapture(const string& filename)
参数:
filename – 打开的视频文件名。
C++: bool VideoCapture::open(const string& filename)C++: bool VideoCapture::open(int device)参数:
filename – 打开的视频文件名。
C++: bool VideoCapture::isOpened()
功能:判断视频读取或者摄像头调用是否成功,成功则返回true。
功能:关闭视频文件或者摄像头。
2.VideoCapture::open
功能:打开一个视频文件或者打开一个捕获视频的设备(也就是摄像头)
device – 打开的视频捕获设备id ,如果只有一个摄像头可以填0,表示打开默认的摄像头。
通过对VideoCapture类的构造函数和open函数分析,可以发现opencv读入视频的方法一般有如下两种。比如读取当前目录下名为"dog.avi"的视频文件,那么这两种写法分别如下。
(1)先实例化再初始化:
VideoCapture capture;capture.open("dog.avi");
(2)在实例化的同时进行初始化:
VideoCapture("dog.avi");
3.VideoCapture::isOpened
4.VideoCapture::release
C++: void VideoCapture::release()
6.VideoCapture::retrieve
C++: VideoCapture& VideoCapture::operator>>(Mat& image)
功能:该函数结合VideoCapture::grab()和VideoCapture::retrieve()其中之一被调用,用于捕获、解码和返回下一个视频帧这是一个最方便的函数对于读取视频文件或者捕获数据从解码和返回刚刚捕获的帧,假如没有视频帧被捕获(相机没有连接或者视频文件中没有更多的帧)将返回false。
从上面的API中我们会发现获取视频帧可以有多种方法 :
// 方法一
// 方法二
// 方法三
// 方法四
capture >> frame;
C++: double VideoCapture::get(int propId)
功能:一个视频有很多属性,比如:帧率、总帧数、尺寸、格式等,VideoCapture的get方法可以获取这些属性。
参数:属性的ID。
属性的ID可以是下面的之一:
CV_CAP_PROP_POS_MSEC Current position of the video file in milliseconds or video capture timestamp.
5.VideoCapture::grab
C++: bool VideoCapture::grab()
功能:从视频文件或捕获设备中抓取下一个帧,假如调用成功返回true。(细节请参考opencv文档说明)
C++: bool VideoCapture::retrieve(Mat& image, int channel=0)
功能:解码并且返回刚刚抓取的视频帧,假如没有视频帧被捕获(相机没有连接或者视频文件中没有更多的帧)将返回false。
7.VideoCapture::read
C++: bool VideoCapture::read(Mat& image)
capture.read(frame); capture.grab(); capture.retrieve(frame);
8.VideoCapture::get
CV_CAP_PROP_POS_FRAMES 0-based index of the frame to be decoded/captured next.CV_CAP_PROP_POS_AVI_RATIO Relative position of the video file: 0 - start of the film, 1 - end of the film.CV_CAP_PROP_FRAME_WIDTH Width of the frames in the video stream.CV_CAP_PROP_FRAME_HEIGHT Height of the frames in the video stream.CV_CAP_PROP_FPS Frame rate.CV_CAP_PROP_FOURCC 4-character code of codec.CV_CAP_PROP_FRAME_COUNT Number of frames in the video file.CV_CAP_PROP_FORMAT Format of the Mat objects returned by retrieve() .CV_CAP_PROP_MODE Backend-specific value indicating the current capture mode.CV_CAP_PROP_BRIGHTNESS Brightness of the image (only for cameras).CV_CAP_PROP_CONTRAST Contrast of the image (only for cameras).CV_CAP_PROP_SATURATION Saturation of the image (only for cameras).CV_CAP_PROP_HUE Hue of the image (only for cameras).CV_CAP_PROP_GAIN Gain of the image (only for cameras).CV_CAP_PROP_EXPOSURE Exposure (only for cameras).CV_CAP_PROP_CONVERT_RGB Boolean flags indicating whether images should be converted to RGB.CV_CAP_PROP_WHITE_BALANCE Currently not supportedCV_CAP_PROP_RECTIFICATION Rectification flag for stereo cameras (note: only supported by DC1394 v 2.x backend currently)//Note: 如果查询的视频属性是VideoCapture类不支持的,将会返回0。//C++: bool VideoCapture::set(int propertyId, double value)//属性ID如下:CV_CAP_PROP_POS_MSEC Current position of the video file in milliseconds.CV_CAP_PROP_POS_FRAMES 0-based index of the frame to be decoded/captured next.CV_CAP_PROP_POS_AVI_RATIO Relative position of the video file: 0 - start of the film, 1 - end of the film.CV_CAP_PROP_FRAME_WIDTH Width of the frames in the video stream.CV_CAP_PROP_FRAME_HEIGHT Height of the frames in the video stream.CV_CAP_PROP_FPS Frame rate.CV_CAP_PROP_FOURCC 4-character code of codec.CV_CAP_PROP_FRAME_COUNT Number of frames in the video file.CV_CAP_PROP_FORMAT Format of the Mat objects returned by retrieve() .CV_CAP_PROP_MODE Backend-specific value indicating the current capture mode.CV_CAP_PROP_BRIGHTNESS Brightness of the image (only for cameras).CV_CAP_PROP_CONTRAST Contrast of the image (only for cameras).CV_CAP_PROP_SATURATION Saturation of the image (only for cameras).CV_CAP_PROP_HUE Hue of the image (only for cameras).CV_CAP_PROP_GAIN Gain of the image (only for cameras).CV_CAP_PROP_EXPOSURE Exposure (only for cameras).CV_CAP_PROP_CONVERT_RGB Boolean flags indicating whether images should be converted to RGB.CV_CAP_PROP_WHITE_BALANCE Currently unsupportedCV_CAP_PROP_RECTIFICATION Rectification flag for stereo cameras (note: only supported by DC1394 v 2.x backend currently)
#include <opencv2/core/core.hpp>#include <opencv2/highgui/highgui.hpp>int main(int argc,char* argv[]) cv::VideoCapture capture(argv[1]); if(!capture.isOpened()) std::cout<<"video not open."<<std::endl; return 1; } //获取当前视频帧率 double rate = capture.get(CV_CAP_PROP_FPS); //当前视频帧 cv::Mat frame; //每一帧之间的延时 //与视频的帧率相对应 int delay = 1000/rate; bool stop(false); while(!stop) if(!capture.read(frame)) std::cout<<"no video frame"<<std::endl; break; } //此处为添加对视频的每一帧的操作方法 int frame_num = capture.get(CV_CAP_PROP_POS_FRAMES); std::cout<<"Frame Num : "<<frame_num<<std::endl; if(frame_num==20) capture.set(CV_CAP_PROP_POS_FRAMES,10); } cv::imshow("video",frame); //引入延时 //也可通过按键停止 if(cv::waitKey(delay)>0) stop = true; } //关闭视频,手动调用析构函数(非必须) capture.release(); return 0;}
C++: VideoCapture::VideoCapture(int device)
功能:创建一个VideoCapture类的实例,如果传入对应的参数,可以直接打开视频文件或者要调用的摄像头。
device – 打开的视频捕获设备id ,如果只有一个摄像头可以填0,表示打开默认的摄像头。
9.VideoCapture::set
功能:设置VideoCapture类的属性,设置成功返回ture,失败返回false。
参数:第一个是属性ID,第二个是该属性要设置的值。
#include <iostream>#include <opencv2/core/core.hpp>#include <opencv2/highgui/highgui.hpp>int main(int argc,char* argv[]){ cv::VideoCapture capture(argv[1]); if(!capture.isOpened()) { std::cout<<"video not open."<<std::endl; return 1; } //获取当前视频帧率 double rate = capture.get(CV_CAP_PROP_FPS); //当前视频帧 cv::Mat frame; //每一帧之间的延时 //与视频的帧率相对应 int delay = 1000/rate; bool stop(false); while(!stop) { if(!capture.read(frame)) { std::cout<<"no video frame"<<std::endl; break; } //此处为添加对视频的每一帧的操作方法 int frame_num = capture.get(CV_CAP_PROP_POS_FRAMES); std::cout<<"Frame Num : "<<frame_num<<std::endl; if(frame_num==20) { capture.set(CV_CAP_PROP_POS_FRAMES,10); } cv::imshow("video",frame); //引入延时 //也可通过按键停止 if(cv::waitKey(delay)>0) stop = true; } //关闭视频,手动调用析构函数(非必须) capture.release(); return 0;}原文地址:
打开原文
- OpenCV VideoCapture类使用
- openCV VideoCapture类的使用例程
- OpenCV:使用VideoCapture类进行读取视频
- OpenCV:VideoCapture类
- Opencv videoio VideoCapture类
- OpenCV:使用VideoCapture类进行视频读取和显示
- OpenCV:使用VideoCapture类进行视频读取和显示
- OpenCV:使用VideoCapture类进行视频读取和显示-Mat
- OpenCV:使用VideoCapture类进行视频读取和显示
- opencv学习之VideoCapture类
- OpenCV -- VideoCapture
- 使用OpenCV VideoCapture获取Kinect图像
- opencv使用VideoCapture无法打开视频
- 【OpenCV开发】OpenCV:使用VideoCapture类进行视频读取和显示
- opencv视频操作基础---VideoCapture类
- Python安装使用VideoCapture类
- OpenCv学习笔记(五):使用VideoCapture类函数实现视频的播放
- 【拜小白opencv】17-使用VideoCapture类读取播放视频操作--简洁版
- Springboot学习笔记(五)JdbcTemplate
- android hotfix practise
- Unity实时获取麦克风音频,处理成可视化
- 大型高并发网站之查询性能优化(综合篇)
- forahead adder 超前进位加法器
- OpenCV VideoCapture类使用
- sed:s命令
- Java Excel POI
- 关于线性模型出现非正定矩阵的问题解释
- IDEA Maven Project 视图找不到解决
- ANSYS Products v18.1.1 Update Only Multilingual Win64 1DVD
- springboot环境的搭建
- TPLink路由器登陆密码怎么破解
- 纯电动汽车结构分类和整体认识