1.1-学习Opencv与MFC混合编程之---利用画图函数,生成视频,并写入视频文件
源代码地址:http://download.csdn.net/detail/nuptboyzhb/3961674
写视频文件
Ø 新建菜单项,Learning OpenCV——> OpenCVr入门——>写视频文件
Ø 菜单项设置如下
Ø 建立类向导
Ø 编辑代码
voidCCVMFCView::OnMyWriteVedio()
{
// TODO: Add your command handler codehere
CStringcsAVI="AVI Files(*.avi)|*.avi|";
CStringcsFilter=csAVI;
CStringname[]={"","avi",""};
CStringstrFileName;
CStringstrExtension;
CFileDialogFileDlg(false,NULL,NULL,OFN_HIDEREADONLY,csFilter);
// 文件存盘对话框
if(FileDlg.DoModal()==IDOK ) { // 选择了文件名
strFileName= FileDlg.m_ofn.lpstrFile;
if(FileDlg.m_ofn.nFileExtension == 0) { // 无文件后缀
strExtension= name[FileDlg.m_ofn.nFilterIndex];
strFileName= strFileName + '.' + strExtension;
// 加文件后缀
}
int width = 1000, height = 700;
//-----------------------------------------------------
CvVideoWriter *vw;
vw= cvCreateVideoWriter (strFileName,-1,25, cvSize(width,height),1); //-1可以
//-----------------------------------------------------
int line_type = CV_AA; // changeit to 8 to see non-antialiased graphics
int i;
CvPoint pt1,pt2,pt_zhb;
double angle;
CvSize sz;
CvPoint ptt[6];
CvPoint* pt[2];
int arr[2];
CvFont font;
CvRNG rng;
int width3 = width*3, height3 =height*3;
CvSize text_size;
int ymin = 0;
// Load the source image
IplImage* image = cvCreateImage(cvSize(width,height), 8, 3 );
IplImage* image2;
// Create a window
cvNamedWindow(wndnamed, 1 );
cvZero( image );
cvShowImage(wndnamed,image);
cvWriteFrame(vw,image);
rng = cvRNG((unsigned)-1);
pt[0] = &(ptt[0]);
pt[1] = &(ptt[3]);
arr[0] = 3;
arr[1] = 3;
m_ImageType=-3;
for (i = 0; i< NUMBER; i++)
{
pt1.x=cvRandInt(&rng) %width3 - width;
pt1.y=cvRandInt(&rng) %height3 - height;
pt2.x=cvRandInt(&rng) %width3 - width;
pt2.y=cvRandInt(&rng) %height3 - height;
cvLine( image, pt1, pt2,random_color(&rng), cvRandInt(&rng)%10, line_type, 0 );
cvShowImage(wndnamed,image);
cvWriteFrame (vw,image);
cvWaitKey(DELAY);
}
for (i = 0; i< NUMBER; i++)
{
pt1.x=cvRandInt(&rng) %width3 - width;
pt1.y=cvRandInt(&rng) %height3 - height;
pt2.x=cvRandInt(&rng) %width3 - width;
pt2.y=cvRandInt(&rng) %height3 - height;
cvRectangle( image,pt1,pt2, random_color(&rng), cvRandInt(&rng)%10-1, line_type, 0 );
cvShowImage(wndnamed,image);
cvWriteFrame (vw,image);
cvWaitKey(DELAY);
}
for (i = 0; i< NUMBER; i++)
{
pt1.x=cvRandInt(&rng) %width3 - width;
pt1.y=cvRandInt(&rng) %height3 - height;
sz.width=cvRandInt(&rng)%200;
sz.height=cvRandInt(&rng)%200;
angle =(cvRandInt(&rng)%1000)*0.180;
cvEllipse( image, pt1, sz,angle, angle - 100, angle + 200,
random_color(&rng),cvRandInt(&rng)%10-1, line_type, 0 );
cvShowImage(wndnamed,image);
cvWriteFrame (vw,image);
cvWaitKey(DELAY);
}
for (i = 0; i< NUMBER; i++)
{
pt[0][0].x=cvRandInt(&rng)% width3 - width;
pt[0][0].y=cvRandInt(&rng)% height3 - height;
pt[0][1].x=cvRandInt(&rng)% width3 - width;
pt[0][1].y=cvRandInt(&rng)% height3 - height;
pt[0][2].x=cvRandInt(&rng)% width3 - width;
pt[0][2].y=cvRandInt(&rng)% height3 - height;
pt[1][0].x=cvRandInt(&rng)% width3 - width;
pt[1][0].y=cvRandInt(&rng)% height3 - height;
pt[1][1].x=cvRandInt(&rng)% width3 - width;
pt[1][1].y=cvRandInt(&rng)% height3 - height;
pt[1][2].x=cvRandInt(&rng)% width3 - width;
pt[1][2].y=cvRandInt(&rng)% height3 - height;
cvPolyLine( image, pt, arr,2, 1, random_color(&rng), cvRandInt(&rng)%10, line_type, 0 );
cvShowImage(wndnamed,image);
cvWriteFrame (vw,image);
cvWaitKey(DELAY);
}
for (i = 0; i< NUMBER; i++)
{
pt[0][0].x=cvRandInt(&rng)% width3 - width;
pt[0][0].y=cvRandInt(&rng)% height3 - height;
pt[0][1].x=cvRandInt(&rng)% width3 - width;
pt[0][1].y=cvRandInt(&rng)% height3 - height;
pt[0][2].x=cvRandInt(&rng)% width3 - width;
pt[0][2].y=cvRandInt(&rng)% height3 - height;
pt[1][0].x=cvRandInt(&rng)% width3 - width;
pt[1][0].y=cvRandInt(&rng)% height3 - height;
pt[1][1].x=cvRandInt(&rng)% width3 - width;
pt[1][1].y=cvRandInt(&rng)% height3 - height;
pt[1][2].x=cvRandInt(&rng)% width3 - width;
pt[1][2].y=cvRandInt(&rng)% height3 - height;
cvFillPoly( image, pt, arr,2, random_color(&rng), line_type, 0 );
cvShowImage(wndnamed,image);
cvWriteFrame (vw,image);
cvWaitKey(DELAY);
}
for (i = 0; i< NUMBER; i++)
{
pt1.x=cvRandInt(&rng) %width3 - width;
pt1.y=cvRandInt(&rng) %height3 - height;
cvCircle( image, pt1,cvRandInt(&rng)%300, random_color(&rng),
cvRandInt(&rng)%10-1,line_type, 0 );
cvShowImage(wndnamed,image);
cvWriteFrame (vw,image);
cvWaitKey(DELAY);
}
for (i = 1; i< NUMBER; i++)
{
pt1.x=cvRandInt(&rng) %width3 - width;
pt1.y=cvRandInt(&rng) %height3 - height;
cvInitFont( &font,cvRandInt(&rng) % 8,
(cvRandInt(&rng)%100)*0.05+0.1,(cvRandInt(&rng)%100)*0.05+0.1,
(cvRandInt(&rng)%5)*0.1,cvRound(cvRandInt(&rng)%10), line_type );
cvPutText( image, "Ilove zjq!", pt1, &font, random_color(&rng));
cvShowImage(wndnamed,image);
cvWriteFrame(vw,image);
cvWaitKey(DELAY);
}
cvInitFont( &font, CV_FONT_HERSHEY_COMPLEX,3, 3, 0.0, 5, line_type );
cvGetTextSize( "OpenCVforever!", &font, &text_size, &ymin );
pt1.x = (width -text_size.width)/2-80;
pt1.y = (height +text_size.height)/2-100;
image2 = cvCloneImage(image);
pt_zhb.x=pt1.x;
pt_zhb.y=pt1.y+300;
for( i = 0; i < 255; i++ )
{
cvSubS( image2,cvScalarAll(i), image, 0 );
cvPutText( image,"OpenCV forever!", pt1, &font, CV_RGB(255,i,i));
cvPutText( image,"Made By ZhengHB!", pt_zhb, &font, CV_RGB(255,i,i));
cvShowImage(wndnamed,image);
cvWriteFrame(vw,image);
cvWaitKey(DELAY);
}
// Wait for a key stroke; the samefunction arranges events processing
cvReleaseVideoWriter (&vw);
cvWaitKey(0);
cvReleaseImage(&image);
cvReleaseImage(&image2);
cvDestroyWindow(wndnamed);
}
}
from:http://blog.csdn.net/nupt123456789/article/details/7100125
1.1-学习Opencv与MFC混合编程之---利用画图函数,生成视频,并写入视频文件的更多相关文章
- 1.1.7-学习Opencv与MFC混合编程之---为画图工具添加工具栏
源代码:http://download.csdn.net/detail/nuptboyzhb/3961701 哎,其实里面有很多图片的,本来看起开很明了的,资源连接里有详细的文档,比下面的看的舒服的多 ...
- 1.1.4-学习Opencv与MFC混合编程之---画图工具 画椭圆
源代码地址:http://download.csdn.net/detail/nuptboyzhb/3961690 1. 增加‘椭圆’菜单项,设置属性,添加类向导: 2. 编辑消息处理函数, ...
- 1.0.x-学习Opencv与MFC混合编程之---视频运动检测
源代码地址: http://download.csdn.net/detail/nuptboyzhb/3961668 版本1.0.x新增内容 视频运动检测 Ø 新建菜单项,Learning OpenCV ...
- 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.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.3-学习Opencv与MFC混合编程之---画图工具 通过对话框进行工具的参数设置 画曲线 绘图校正
源代码:http://download.csdn.net/detail/nuptboyzhb/3961688 l 对话框 1.“插入”->“资源”->“对话框” 2.对话框属性如下: 双击 ...
随机推荐
- hdu4597 Play Game(DFS)
转载请注明出处:http://blog.csdn.net/u012860063 题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=4597 题意 Alic ...
- [Swust OJ 1094]--中位数(巧用set,堆排序)
题目链接:http://acm.swust.edu.cn/problem/1094/ Time limit(ms): 1000 Memory limit(kb): 32768 中位数(又称中值,英 ...
- String "+" 的补充说明---行粒度
String 中“+” 的操作的补充说明 在使用“+”的时候,会创建一个StringBuilder对象,然后invokevirtual append()操作 “+”操作创建StringBuilder的 ...
- Tcl语言笔记之一
1,一个TCL脚本可以包含一个或多个命令.命令之间必须用换行符或分号隔开 2,置换 substitution %set y x+100 // ...
- QuartusII 中采用门级原语
QuartusII 中采用门级原语 默认的是前面第一个 为output 后面所有信号为输入 图中的工程实现的是 一个二选一多路选择器
- vim常用操作技巧与配置
vi是linux与unix下的常用文本编辑器,其运行稳定,使用方便,本文将分两部分对其常用操作技巧和配置进行阐述,其中参考了网上的一些文章,对作者表示感谢 PART1 操作技巧 说明: 以下的例子中 ...
- Spring IOC三种注入方式(接口注入、setter注入、构造器注入)(摘抄)
IOC ,全称 (Inverse Of Control) ,中文意思为:控制反转, Spring 框架的核心基于控制反转原理. 什么是控制反转?控制反转是一种将组件依赖关系的创建和管理置于程序外部的技 ...
- GIT分支操作常用命令
切换分支:git checkout name 撤销修改:git checkout -- file 删除文件:git rm file 查看状态:git status 添加记录:git add file ...
- 第五章:输入输出(IO)管理
I/O设备概念: 指计算机内部除中央处理器和内存之外的全部设备,通常也称为外部设备. I/O设备分类: ·按交互对象分类: ·人机交互设备 ·与计算机或其它电子设备交互的设备 ·计算机间的同信 ...
- Swift编程语言学习11—— 枚举全局变量、局部变量与类型属性
全局变量和局部变量 计算属性和属性监视器所描写叙述的模式也能够用于全局变量和局部变量,全局变量是在函数.方法.闭包或不论什么类型之外定义的变量,局部变量是在函数.方法或闭包内部定义的变量. 前面章节提 ...