opencv利用視頻的前n幀求平均圖像
更新時間:2020年03月21日 06:51:52 作者:迷途中的前進
這篇文章主要為大家詳細介紹了opencv利用視頻的前n幀求平均圖像,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了opencv利用視頻的前n幀求平均圖像的具體代碼,供大家參考,具體內容如下
自己寫的哈,可以用該小程序對視頻求解平均模型。
//OpenCV中如何累加多幅圖像并取平均值
#include "cv.h"
#include "highgui.h"
int main(int argc,char *argv[])
{
int nframe = 50;//利用前nfram幀求解平均圖
CvCapture *capture = cvCreateFileCapture( "3.avi");
if (NULL==capture)
{
printf("沒有找到該視頻!\n");
return -1;
}
IplImage * Img=cvQueryFrame(capture);
cvNamedWindow("原圖",0);
//cvShowImage("原圖",Img);
IplImage * img_sum = cvCreateImage(cvGetSize(Img),IPL_DEPTH_32F,3);
cvZero(img_sum);
for(int i = 0;i <nframe;i++)//統(tǒng)計背景模型
{
cvAcc(Img,img_sum);
Img=cvQueryFrame(capture);
cvWaitKey(100);
cvShowImage("原圖",Img);
//printf(".");
}
IplImage * img_sum_gray = cvCreateImage(cvGetSize(Img),IPL_DEPTH_8U,3);
cvConvertScale(img_sum,img_sum_gray,1.0/nframe);
cvNamedWindow("img_sum_gray",0);
cvShowImage("img_sum_gray",img_sum_gray);
cvSaveImage("model.jpg",img_sum_gray);
cvWaitKey(0);
cvDestroyAllWindows();
cvReleaseImage(&img_sum);
cvReleaseImage(&img_sum_gray);
return 0;
}
利用前20幀求視頻的平均圖像,如下:

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:

