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;
//创建写入对象,需要指定,帧率和视频宽高
VideoWriter writer;
//指定保存文件位置,编码器,帧率,宽高
writer.open("Bolt222.avi", VideoWriter::fourcc('M','J','P','G'), fps, size);
// 创建视频中每张图片对象
Mat frame, deal_frame;
//读取视频显示窗口
namedWindow("video-input", WINDOW_AUTOSIZE);
//存储视频显示窗口
namedWindow("video-output", WINDOW_AUTOSIZE);
// 循环显示视频中的每张图片
for (;;)
{
//将视频转给每一张张图进行处理
capture >> frame;
//省略对图片的处理
//视频播放完退出
if (frame.empty())break;
imshow("video-input",frame);
//实战处理图片
pyrDown(frame,deal_frame);
imshow("video-output",deal_frame);
writer << deal_frame;
//在视频播放期间按键退出
if (waitKey(33) >= 0) break;
}
//释放
capture.release();
writer.release();
return 0;
}