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帧求视频的平均图像,如下:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值