C++ OpenCV摄像头及视频操作类​VideoCapture介绍

前言

前面的文章我们做了对图片的一些处理,OpenCV里面还有对动态视频的处理,通过动态视频图像每一帧生成的Mat再对图像可以进行处理。接下来我们学习一下OpenCV打开摄像头和播放视频的基本操作。

VideoCapture类

opencv中通过VideoCaptrue类对视频进行读取操作以及调用摄像头,下面是该类的API。

1.VideoCapture类的构造函数:

VideoCapture::VideoCapture();  

VideoCapture::VideoCapture(const string& filename);  

VideoCapture::VideoCapture(int device);  

功能:创建一个VideoCapture类的实例,如果传入对应的参数,可以直接打开视频文件或者要调用的摄像头。

参数:
filename – 打开的视频文件名。

device – 打开的视频捕获设备id ,如果只有一个摄像头可以填0,表示打开默认的摄像头。 


2.VideoCapture::open

bool VideoCapture::open(const string& filename);  

bool VideoCapture::open(int device);  

功能:打开一个视频文件或者打开一个捕获视频的设备(也就是摄像头)

参数:
filename – 打开的视频文件名。

device – 打开的视频捕获设备id ,如果只有一个摄像头可以填0,表示打开默认的摄像头。

    通过对VideoCapture类的构造函数和open函数分析,可以发现opencv读入视频的方法一般有如下两种。比如读取当前目录下名为"dog.avi"的视频文件,那么这两种写法分别如下。

(1)先实例化再初始化:

VideoCapture capture; 

capture.open("dog.avi");  

(2)在实例化的同时进行初始化:

VideoCapture("dog.avi");


3.VideoCapture::isOpened

bool VideoCapture::isOpened();  

功能:判断视频读取或者摄像头调用是否成功,成功则返回true。


4.VideoCapture::release

void VideoCapture::release();  

功能:关闭视频文件或者摄像头。


5.VideoCapture::grab

bool VideoCapture::grab();  

功能:从视频文件或捕获设备中抓取下一个帧,假如调用成功返回true。(细节请参考opencv文档说明)


6.VideoCapture::retrieve

bool VideoCapture::retrieve(Mat& image, int channel=0);  

功能:解码并且返回刚刚抓取的视频帧,假如没有视频帧被捕获(相机没有连接或者视频文件中没有更多的帧)将返回false。


7.VideoCapture::read

VideoCapture& VideoCapture::operator>>(Mat& image);  

bool VideoCapture::read(Mat& image);  

功能:该函数结合VideoCapture::grab()和VideoCapture::retrieve()其中之一被调用,用于捕获、解码和返回下一个视频帧这是一个最方便的函数对于读取视频文件或者捕获数据从解码和返回刚刚捕获的帧,假如没有视频帧被捕获(相机没有连接或者视频文件中没有更多的帧)将返回false。

    从上面的API中我们会发现获取视频帧可以有多种方法 :

// 方法一   

capture.read(frame);   

  

// 方法二   

capture.grab();   

  

// 方法三  

capture.retrieve(frame);   

  

// 方法四  

capture >> frame;  


8.VideoCapture::get

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.  

  • 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 supported  

  • CV_CAP_PROP_RECTIFICATION Rectification flag for stereo cameras (note: only supported by DC1394 v 2.x backend currently)  

Note: 如果查询的视频属性是VideoCapture类不支持的,将会返回0。


9.VideoCapture::set

bool VideoCapture::set(int propertyId, double value)

功能:设置VideoCapture类的属性,设置成功返回ture,失败返回false。

参数:第一个是属性ID,第二个是该属性要设置的值。

属性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 unsupported  

  • CV_CAP_PROP_RECTIFICATION Rectification flag for stereo cameras (note: only supported by DC1394 v 2.x backend currently)  

 


-END-

长按下方二维码关注

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要使用C++OpenCV来访问摄像头,你需要进行以下步骤: 1. 安装OpenCV库:你需要下载OpenCV库并将其安装在你的计算机上。你可以在OpenCV官网上找到下载链接。 2. 引入OpenCV库:在你的C++代码中,你需要引入OpenCV库,这可以通过在代码中包含以下行实现: ``` #include <opencv2/opencv.hpp> ``` 3. 打开摄像头:要打开摄像头并获取视频流,你可以使用`cv::VideoCapture`。以下是示例代码: ```c++ cv::VideoCapture cap(0); // 0表示默认的摄像头,如果有多个摄像头,可以选择其他数字 if (!cap.isOpened()) { std::cout << "Cannot open camera" << std::endl; return -1; } ``` 4. 读取视频帧:要读取视频帧,请使用`cv::Mat`。以下是示例代码: ```c++ cv::Mat frame; cap.read(frame); // 读取帧 if (frame.empty()) { std::cout << "No frame" << std::endl; break; } ``` 5. 处理视频帧:你可以对读取的视频帧进行各种操作,例如显示帧、保存帧等。以下是示例代码: ```c++ cv::imshow("Camera", frame); // 显示帧 cv::waitKey(1); // 等待1毫秒,以便cv::imshow可以刷新窗口 ``` 完整的代码示例: ```c++ #include <opencv2/opencv.hpp> int main() { cv::VideoCapture cap(0); if (!cap.isOpened()) { std::cout << "Cannot open camera" << std::endl; return -1; } while (true) { cv::Mat frame; cap.read(frame); if (frame.empty()) { std::cout << "No frame" << std::endl; break; } cv::imshow("Camera", frame); cv::waitKey(1); } cap.release(); cv::destroyAllWindows(); return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Vaccae

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值