1.0.x-学习Opencv与MFC混合编程之---视频运动检测
源代码地址: http://download.csdn.net/detail/nuptboyzhb/3961668
版本1.0.x新增内容
视频运动检测
Ø 新建菜单项,Learning OpenCV——> OpenCVr入门——>视频运动检测
Ø 菜单项设置如下:

Ø 建立类向导
Ø 编辑代码
voidCCVMFCView::OnMyTestSport()
{
// TODO: Add your command handler codehere
//Alt+F8 整理代码
CvCapture* capture;
capture = cvCreateCameraCapture(0);//打开摄像头
if(capture==NULL)
{
MessageBox("未检测到摄像头,请检查摄像头安装是否正确");
}
else
{
CString WindowName1="摄像机";
IplImage *frame1 = 0;//第一帧
IplImage *frame2 = 0;//第二帧
IplImage *frame_sub= 0;//相减之后的帧
IplImage* pImg8u = NULL;//灰度图
//
assert(capture != NULL );//如果没有打开,中断
cvNamedWindow(WindowName1,CV_WINDOW_AUTOSIZE);
frame1= cvQueryFrame(capture);
frame_sub=cvCloneImage(frame1);
while(1)
{
frame2=cvQueryFrame(capture);
if(!frame2)
{
break;
}
cvAbsDiff(frame1,frame2,frame_sub);
frame1=cvCloneImage(frame2);
cvMoveWindow(WindowName1, 150, 200);
cvShowImage(WindowName1,frame_sub);
// 建立位图
pImg8u =cvCreateImage(cvGetSize(frame_sub),IPL_DEPTH_8U,1);
cvCvtColor(frame_sub,pImg8u,CV_BGR2GRAY); //彩色变灰阶
//--------------一下是计算直方图-----------------------------
IplImage *src;
IplImage *histimg = 0;
CvHistogram *hist = 0;
int hdims = 256; // 划分HIST的个数,越高越精确
src=cvCloneImage(pImg8u);
float hranges_arr[] ={0,255};
float* hranges =hranges_arr;
int bin_w;
float max_val;
int i;
cvNamedWindow("Histogram", 0 );
hist = cvCreateHist( 1,&hdims, CV_HIST_ARRAY, &hranges, 1 ); // 计算直方图
histimg= cvCreateImage( cvSize(320,200), 8, 3 );
cvZero( histimg );
cvCalcHist( &src, hist,0, 0 ); // 计算直方图
cvGetMinMaxHistValue( hist,0, &max_val, 0, 0 ); // 只找最大值
cvConvertScale(hist->bins, hist->bins,
max_val ? 255. /max_val : 0., 0 ); // 缩放 bin 到区间 [0,255]
cvZero( histimg );
bin_w = histimg->width /hdims; // hdims: 条的个数,则 bin_w 为条的宽度
// 画直方图
for( i = 0; i < hdims;i++ )
{
double val = (cvGetReal1D(hist->bins,i)*histimg->height/255 );
CvScalar color =CV_RGB(255,255,0); //(hsv2rgb(i*180.f/hdims);
cvRectangle(histimg, cvPoint(i*bin_w,histimg->height),
cvPoint((i+1)*bin_w,(int)(histimg->height- val)),
color, 1, 8,0 );
}
cvMoveWindow("Histogram",550, 200);
cvShowImage( "Histogram",histimg );
//------------------------------------------------------
char c = cvWaitKey(1);
if( c == 27 )
{
break;
}
}
cvReleaseCapture( &capture );
cvDestroyWindow(WindowName1);
cvDestroyWindow("Histogram");
}
}
from:http://blog.csdn.net/nupt123456789/article/details/7100114
1.0.x-学习Opencv与MFC混合编程之---视频运动检测的更多相关文章
- 1.0.3-学习Opencv与MFC混合编程之---打开本地摄像头
源代码:http://download.csdn.net/detail/nuptboyzhb/3961643 版本1.0.3新增内容 打开摄像头 Ø 新建菜单项,Learning OpenCV——&g ...
- 1.0.2-学习Opencv与MFC混合编程之---为播放AVI视频添加滑动条
源代码地址:http://download.csdn.net/detail/nuptboyzhb/3961642 版本1.0.2新增内容 Ø 全局变量和函数的添加: 在CVMFCview.cpp文件 ...
- 1.0.1-学习Opencv与MFC混合编程之---播放AVI视频
资源源代码:http://download.csdn.net/detail/nuptboyzhb/3961639 版本1.0.1新增内容 Ø 新建菜单项,Learning OpenCV——> ...
- 1.1-学习Opencv与MFC混合编程之---利用画图函数,生成视频,并写入视频文件
源代码地址:http://download.csdn.net/detail/nuptboyzhb/3961674 写视频文件 Ø 新建菜单项,Learning OpenCV——> OpenCVr ...
- 1.1.7-学习Opencv与MFC混合编程之---为画图工具添加工具栏
源代码:http://download.csdn.net/detail/nuptboyzhb/3961701 哎,其实里面有很多图片的,本来看起开很明了的,资源连接里有详细的文档,比下面的看的舒服的多 ...
- 1.1.5-学习Opencv与MFC混合编程之---画图工具 输入文字和填充图像 修改光标
源代码:http://download.csdn.net/detail/nuptboyzhb/3961696 输入文字 l 对话框 1. 插入,资源,选择对话框资源 2. 编辑对话框如下: ...
- 1.1.6-学习Opencv与MFC混合编程之---播放WAV音乐和 alpha融合功能
源代码:http://download.csdn.net/detail/nuptboyzhb/3961698 Alpha融合菜单项 1. 增加alpha融合菜单项,修改相应的属性,建立类向导 ...
- 1.1.4-学习Opencv与MFC混合编程之---画图工具 画椭圆
源代码地址:http://download.csdn.net/detail/nuptboyzhb/3961690 1. 增加‘椭圆’菜单项,设置属性,添加类向导: 2. 编辑消息处理函数, ...
- 1.1.3-学习Opencv与MFC混合编程之---画图工具 通过对话框进行工具的参数设置 画曲线 绘图校正
源代码:http://download.csdn.net/detail/nuptboyzhb/3961688 l 对话框 1.“插入”->“资源”->“对话框” 2.对话框属性如下: 双击 ...
随机推荐
- iOS 判断有无网络连接
众所周知,我们在开发APP时,涉及网络连接的时候,都会想着提前判断一下当前的网络连接状态,如果没有网络,就不再请求url,省去不必要的步骤,所以,这个如何判断?其实很简单. 前提:工程添加:Syste ...
- 如何设置gen_server在退出时执行相关操作
如果gen_server在监控树中不需要stop函数,gen_server会由其supervisor根据shutdown策略自动终止掉.如果要在进程终止之前执行清理,shutdown策略必须设定一个t ...
- Hibernate 多对一
Hibernate的many-to-one 关联. 具体看配置文件: <?xml version="1.0"?> <!DOCTYPE hibernate-mapp ...
- rotatelogs分割apache日志文件
rotatelogs 截断日志,进行配置.但是保存httpd.conf 之后,服务器报错: 日志文件: piped log program ' /usr/sbin/rotatelogs logs/py ...
- 【 D3.js 入门系列 — 4 】 如何使用比例尺( scale )
上一章中使用了一个很重要的概念 — 比例尺( scale ),本节将解说其使用方法. 1. 最大值和最小值 在介绍比例尺( scale )之前,先介绍两个经常和比例尺一起出现的函数,在[第3章]中也出 ...
- HDU 5025Saving Tang Monk BFS + 二进制枚举状态
3A的题目,第一次TLE,是因为一次BFS起点到终点状态太多爆掉了时间. 第二次WA,是因为没有枚举蛇的状态. 解体思路: 因为蛇的数目是小于5只的,那就首先枚举是否杀死每只蛇即可. 然后多次BFS, ...
- USB键盘数据解析
以前用过的一个嵌入式设备使用USB键盘作为输入.当时还研究了一下USB协议,现在都快忘得差不多了.这里整理一下当时找到的关于USB键盘数据方面的资料. 主机与USB键盘建立连接后,定时从键盘获取8字节 ...
- c# 数据库编程(利用DataSet 和 DataAdaper对象操作数据库--跨表操作)
上篇文章我们介绍了如何利用DataSet 和 DataAdaper对象来对单张表进行操作. 本文我们将介绍如何进行跨表操作. 我们通过具体例子方式进行演示,例子涉及到三张表. 1)student表(学 ...
- 海量数据处理算法—Bloom Filter
海量数据处理算法—Bloom Filter 1. Bloom-Filter算法简介 Bloom-Filter,即布隆过滤器,1970年由Bloom中提出.它可以用于检索一个元素是否在一个集合中. Bl ...
- java的new BufferedReader(new InputStreamReader(System.in))
流 JAVA /IO 基本小结 通过一行常见的代码讨论:new BufferedReader(new InputStreamReader(System.in)) /*** *** 看到这篇文章挺好的, ...