源代码地址: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.1.7-学习Opencv与MFC混合编程之---为画图工具添加工具栏

    源代码:http://download.csdn.net/detail/nuptboyzhb/3961701 哎,其实里面有很多图片的,本来看起开很明了的,资源连接里有详细的文档,比下面的看的舒服的多 ...

  2. 1.1.4-学习Opencv与MFC混合编程之---画图工具 画椭圆

    源代码地址:http://download.csdn.net/detail/nuptboyzhb/3961690 1.    增加‘椭圆’菜单项,设置属性,添加类向导: 2.    编辑消息处理函数, ...

  3. 1.0.x-学习Opencv与MFC混合编程之---视频运动检测

    源代码地址: http://download.csdn.net/detail/nuptboyzhb/3961668 版本1.0.x新增内容 视频运动检测 Ø 新建菜单项,Learning OpenCV ...

  4. 1.0.3-学习Opencv与MFC混合编程之---打开本地摄像头

    源代码:http://download.csdn.net/detail/nuptboyzhb/3961643 版本1.0.3新增内容 打开摄像头 Ø 新建菜单项,Learning OpenCV——&g ...

  5. 1.0.2-学习Opencv与MFC混合编程之---为播放AVI视频添加滑动条

    源代码地址:http://download.csdn.net/detail/nuptboyzhb/3961642 版本1.0.2新增内容 Ø  全局变量和函数的添加: 在CVMFCview.cpp文件 ...

  6. 1.0.1-学习Opencv与MFC混合编程之---播放AVI视频

    资源源代码:http://download.csdn.net/detail/nuptboyzhb/3961639 版本1.0.1新增内容 Ø  新建菜单项,Learning OpenCV——> ...

  7. 1.1.5-学习Opencv与MFC混合编程之---画图工具 输入文字和填充图像 修改光标

    源代码:http://download.csdn.net/detail/nuptboyzhb/3961696 输入文字 l 对话框 1.    插入,资源,选择对话框资源 2.    编辑对话框如下: ...

  8. 1.1.6-学习Opencv与MFC混合编程之---播放WAV音乐和 alpha融合功能

    源代码:http://download.csdn.net/detail/nuptboyzhb/3961698 Alpha融合菜单项 1.      增加alpha融合菜单项,修改相应的属性,建立类向导 ...

  9. 1.1.3-学习Opencv与MFC混合编程之---画图工具 通过对话框进行工具的参数设置 画曲线 绘图校正

    源代码:http://download.csdn.net/detail/nuptboyzhb/3961688 l 对话框 1.“插入”->“资源”->“对话框” 2.对话框属性如下: 双击 ...

随机推荐

  1. [每天一个Linux小技巧] gdb 下一次运行多个命令

    一般gdb运行的时候,我们仅仅能输入一个命令. 如: (gdb) c (gdb) bt 假设想运行多个命令怎么办? 能否像bash那样, 使用; 如 ls; ls 结论是不行. 但能够通过gdb 内建 ...

  2. C++静态成员函数和静态成员变量的探索

    静态数据成员属于类,非属于类对象,所以,定义位置就有了限制. 静态数据成员要实际地分配空间,故不能在类的声明中定义(只能声明数据成员).类声明只声明一个类的“尺寸和规格”,并不进行实际的内存分配,所以 ...

  3. HDU 3899 简单树形DP

    题意:一棵树,给出每个点的权值和每条边的长度, 点j到点i的代价为点j的权值乘以连接i和j的边的长度.求点x使得所有点到点x的代价最小,输出 虽然还是不太懂树形DP是什么意思,先把代码贴出来把. 这道 ...

  4. 开发快很重要——如果只看法语或者产品结果C++似乎很强大,但是参与这个C++的开发过程,就会感觉到这种痛苦(Google也是这个看法)

    开发快很重要——如果只看语法或者产品结果C++似乎很强大,但是参与这个C++的开发过程,就会感觉到这种痛苦,太慢了,太麻烦了,虽然在反复调试和优化之后,最后产品的结果可能还不错. Delphi的最大特 ...

  5. python IDE ulipad配置使用

    一直认为认为python自带的编辑器idle实在是太简陋了,连显示行号的功能都没有,也非常不好编辑.找了下windows平台下的Ide,发现ulipad很多人推荐使用,就开始安装了. 首先去官网: h ...

  6. 转:js包装DOM对象

    我们在日常的应用中,使用Javascript大多数时间都是在用DOM ,以致于很多人都有一种看法就是DOM==JS,虽然这种看法是错误的,但是也可以说明DOM的重要性. 这就导致了我们在写JS的时候, ...

  7. python模块学习---HTMLParser(解析HTML文档元素)

    HTMLParser是Python自带的模块,使用简单,能够很容易的实现HTML文件的分析. 本文主要简单讲一下HTMLParser的用法. 使用时需要定义一个从类HTMLParser继承的类,重定义 ...

  8. ICE之C/S通信原理

    /* 在ICE文档中只需要声明module名称,接口名称,方法名称 */ #ifndef SIMPLE_ICE #define SIMPLE_ICE module Demo{ //module名称 i ...

  9. 隐式意图-activity

    Intent intent = new Intent(); intent.setAction(Intent.ACTION_VIEW);//设置动作 intent.setData(Uri.parse(& ...

  10. session临时文件存储路径

    今天把本地的项目部署到外网时,遇到个问题,使用session_start()时,提示****目录下的这个文件不存在,网上查了查,说我的根目录不存在,然后在php.ini文件里看了下session.sa ...