本文实例为大家分享了opencv利用视频的前n帧求平均图像的具体代码,供大家参考,具体内容如下
自己写的哈,可以用该小程序对视频求解平均模型。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
//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++) //统计背景模型 { 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帧求视频的平均图像,如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/ding977921830/article/details/51221524