本文实现了用滑动条控制视频的播放。s键用来单步执行,r键为播放模式。
代码如下:
#include<opencv2/opencv.hpp>
#include<iostream>
#include<fstream>
using namespace cv;
using namespace std;
int g_slider_position=0;
int g_run=1,g_dontset=0;
VideoCapture g_cap;
void onTrackbarSlide(int pos, void *)
{
g_cap.set(CV_CAP_PROP_POS_FRAMES,pos);
if(!g_dontset)
g_run=1;
g_dontset=0;
}
int main()
{
namedWindow("wan",WINDOW_AUTOSIZE);
g_cap.open("g:\\1.avi");
int frames = (int) g_cap.get(CV_CAP_PROP_FRAME_COUNT);
int tmpw = (int)g_cap.get(CV_CAP_PROP_FRAME_WIDTH);
int tmph = (int)g_cap.get(CV_CAP_PROP_FRAME_HEIGHT);
cout << "video has " << frames << "frames of dimensions(" << tmpw << ", " << tmph << ")." <<endl;
//创建滑动条
createTrackbar("position","wan",&g_slider_position,frames,onTrackbarSlide);
Mat frame;
while(1)
{
if(g_run!=0)
{
g_cap >>frame;
if(!frame.data)
break;
int current_pos=(int )g_cap.get(CV_CAP_PROP_POS_FRAMES);
g_dontset=1;
setTrackbarPos("position","wan",current_pos);
imshow("wan",frame);
g_run-=1;
}
char c = (char) waitKey(10);
if(c=='s')
{
g_run=1;
cout << "single step,run = " << g_run <<endl;
}
if(c=='r')
{
g_run=-1;
cout << "run mode, run = " << g_run << endl;
}
if(c==27)
break;
}
return 0;
}
运行效果如下: