OpenCV 本身集成了 FFmpeg,因此对于视频是有解码和编码功能的。虽然其效率在本人看来还不能跟未被封装的FFmpeg相提并论,然用其来对视频进行解码得到图像,然后对图像进行处理并将得到的图像重新压缩成视频是非常方便的,下面将介绍将视频解码成图像并进行帧差法等操作的框架搭建,虽然没有介绍如何反向压缩成视频,但其操作也是非常类似的,不过需要注意的是在OpenCV2.1版本图像压缩成视频记得是有BUG的,最好还是用新的版本来进行学习。
#include <afxwin.h> #include <opencv2/opencv.hpp> using namespace cv; void MotionDetect(IplImage *frame1, IplImage *frame2)//两帧图像处理函数 { //在此加入图像处理代码 } void main() { IplImage *frame1 = NULL, *frame2 = NULL;//frame1为新的图像,frame2为frame1的前一张图像 CvCapture *capture = NULL; capture = cvCaptureFromAVI("1.avi");//打开视频 frame1 = cvQueryFrame(capture);//从摄像头或者文件中抓取并返回一帧 frame2 = cvCreateImage(cvGetSize(frame1), 8, 3); cvCopy(frame1, frame2); frame1 = cvQueryFrame(capture); while (frame1) { MotionDetect(frame1, frame2);//移动侦测 cvCopy(frame1, frame2); frame1 = cvQueryFrame(capture);//接着从视频中拷入图像 } cvReleaseImage(&frame2); }