栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

OpenCV利用背景建模检测运动物体

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

OpenCV利用背景建模检测运动物体

本文实例为大家分享了OpenCV利用背景建模检测运动物体的具体代码,供大家参考,具体内容如下

#include  
#include  
 
int main( int argc, char** argv ){ 
 
  IplImage* pframe = NULL; 
  IplImage* pFrImg = NULL; 
  IplImage* pBkImg = NULL; 
 
  CvMat* pframeMat = NULL; 
  CvMat* pFrMat = NULL; 
  CvMat* pBkMat = NULL; 
 
  CvCapture* pCapture = NULL; 
 
  int nFrmNum = 0; 
 
  cvNamedWindow("video", 1); 
  cvNamedWindow("background",1); 
  cvNamedWindow("foreground",1); 
 
  cvMoveWindow("video", 30, 0); 
  cvMoveWindow("background", 360, 0); 
  cvMoveWindow("foreground", 690, 0); 
  //打开视频文件 
  if( !(pCapture = cvCaptureFromFile("video.avi")) ){ 
 
    fprintf(stderr, "Can not open video file video.avin"); 
    return -2; 
  } 
 
  //逐帧读取视频 
  while(pframe = cvQueryframe( pCapture )){ 
 
    nFrmNum++; 
 
    // 第一帧需要申请内存并初始化 
    if(nFrmNum == 1){ 
 
      pBkImg = cvCreateImage(cvSize(pframe->width, pframe->height), 
    IPL_DEPTH_8U,1); 
      pFrImg = cvCreateImage(cvSize(pframe->width, pframe->height), 
    IPL_DEPTH_8U,1); 
      pBkMat = cvCreateMat(pframe->height, pframe->width, CV_32FC1); 
      pFrMat = cvCreateMat(pframe->height, pframe->width, CV_32FC1); 
      pframeMat = cvCreateMat(pframe->height, pframe->width, CV_32FC1); 
 
      // 转换为单通道图像再处理 
      cvCvtColor(pframe, pBkImg, CV_BGR2GRAY); 
      cvCvtColor(pframe, pFrImg, CV_BGR2GRAY); 
 
      cvConvert(pFrImg, pframeMat); 
      cvConvert(pFrImg, pFrMat); 
      cvConvert(pFrImg, pBkMat); 
    }else{ 
 
      cvCvtColor(pframe, pFrImg, CV_BGR2GRAY); 
      cvConvert(pFrImg, pframeMat); 
 
      // 高斯滤波平滑图像 
      cvSmooth(pframeMat, pframeMat, CV_GAUSSIAN, 3, 0, 0); 
 
      // 当前帧与背景图相减 
      cvAbsDiff(pframeMat, pBkMat, pFrMat); 
 
      // 二值化背景图 
      cvThreshold(pFrMat, pFrImg, 60, 255.0, CV_THRESH_BINARY); 
 
      //进行形态学滤波,去除噪声. 效果不好,将行车都作为噪声去除了 
      //cvErode(pFrImg, pFrImg, 0, 1); 
      //cvDilate(pFrImg, pFrImg, 0, 1); 
 
      // 更新背景 
      cvRunningAvg(pframeMat, pBkMat, 0.003, 0); 
      // 将背景转换为图像格式,用于显示 
      cvConvert(pBkMat, pBkImg); 
 
      cvShowImage("video", pframe); 
      cvShowImage("background", pBkImg); 
      cvShowImage("foreground", pFrImg); 
 
      if( cvWaitKey(2) >= 0 ) 
 break; 
    } 
  } 
 
  cvDestroyWindow("video"); 
  cvDestroyWindow("background"); 
  cvDestroyWindow("foreground"); 
 
  cvReleaseImage(&pFrImg); 
  cvReleaseImage(&pBkImg); 
 
  cvReleaseMat(&pframeMat); 
  cvReleaseMat(&pFrMat); 
  cvReleaseMat(&pBkMat); 
 
  return 0; 
} 

效果图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/63063.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号