当前位置 : 主页 > 编程语言 > c语言 >

opencv利用视频的前n帧求平均图像

来源:互联网 收集:自由互联 发布时间:2021-05-12
本文实例为大家分享了opencv利用视频的前n帧求平均图像的具体代码,供大家参考,具体内容如下 自己写的哈,可以用该小程序对视频求解平均模型。 //OpenCV中如何累加多幅图像并取平

本文实例为大家分享了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++)//统计背景模型
 {
  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帧求视频的平均图像,如下:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。

网友评论