opencv处理视频系列一:读取和显示视频(详细注释)
读取文件中视频,和之前说的读取文件中照片是一样的格式,就是用不同的类创建不同的对象,对象去连接一个借口,此时把视频看成批量图片,是一个道理。不懂批量处理的可以看我之前的博文。
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace cv;
using namespace std;
int main(int argc, char** argv)
{
//videocapture结构创建一个catture视频对象
VideoCapture capture;
//连接视频
capture.open("Bolt2.avi");
if (!capture.isOpened()) {
printf("could not load video data...\n");
return -1;
}
int frames = capture.get(CAP_PROP_FRAME_COUNT);//获取视频针数目(一帧就是一张图片)
double fps = capture.get(CAP_PROP_FPS);//获取每针视频的频率
// 获取帧的视频宽度,视频高度
Size size = Size(capture.get(CAP_PROP_FRAME_WIDTH), capture.get(CAP_PROP_FRAME_HEIGHT));
cout << frames << endl;
cout << fps << endl;
cout << size << endl;
// 创建视频中每张图片对象
Mat frame;
namedWindow("video-demo", WINDOW_AUTOSIZE);
// 循环显示视频中的每张图片
for (;;)
{
//将视频转给每一张张图进行处理
capture >> frame;
//省略对图片的处理
//视频播放完退出
if (frame.empty())break;
imshow("video-demo",frame);
//在视频播放期间按键退出
if (waitKey(33) >= 0) break;
}
//释放
capture.release();
return 0;
}
转载:https://blog.csdn.net/qq_43702097/article/details/105682794
查看评论