#include <highgui.h>
#include <cv.h> #pragma comment (lib,"opencv_calib3d231d.lib")
#pragma comment (lib,"opencv_contrib231d.lib")
#pragma comment (lib,"opencv_core231d.lib")
#pragma comment (lib,"opencv_features2d231d.lib")
#pragma comment (lib,"opencv_flann231d.lib")
#pragma comment (lib,"opencv_gpu231d.lib")
#pragma comment (lib,"opencv_haartraining_engined.lib")
#pragma comment (lib,"opencv_highgui231d.lib")
#pragma comment (lib,"opencv_imgproc231d.lib")
#pragma comment (lib,"opencv_legacy231d.lib")
#pragma comment (lib,"opencv_ml231d.lib")
#pragma comment (lib,"opencv_objdetect231d.lib")
#pragma comment (lib,"opencv_ts231d.lib")
#pragma comment (lib,"opencv_video231d.lib") /*
*《学习OpenCV》第四章第一题b部分
* 完成时间:19:24 3/10 星期日 2013
*/ int main()
{
char * file_path = "H:/TDDOWNLOAD/Video/1111.avi";
CvCapture * capture = ;
capture = cvCreateFileCapture(file_path); // 载入视频文件失败
if(capture == NULL)
{
printf("Can't load the video file, quit...\n");
return ;
} // 每一帧
IplImage * frame = cvQueryFrame(capture);;
// 灰度后的每一帧
IplImage * gray_frame = cvCreateImage( cvGetSize(frame), frame->depth, );
IplImage * gray_frame_3 = cvCreateImage(cvGetSize(frame), frame->depth, );
// 边缘检测后的每一帧
IplImage * canny_frame = cvCreateImage( cvGetSize(frame), frame->depth, );
IplImage * canny_frame_3 = cvCreateImage(cvGetSize(frame), frame->depth, );
// 聚合来的每一帧
IplImage * total_frame = cvCreateImage( cvSize(frame->width * , frame->height),
frame->depth, frame->nChannels); while()
{
// 从视频文件读入数据
frame = cvQueryFrame(capture);
if(!frame)
break; // 将读入数据转换为灰度图
cvCvtColor( frame, gray_frame, CV_RGB2GRAY );
cvCvtColor( gray_frame, gray_frame_3, CV_GRAY2BGR ); // 对图像做Canny边缘检测
cvCanny( gray_frame, canny_frame, , , );
cvCvtColor( canny_frame, canny_frame_3, CV_GRAY2BGR ); // 将三幅图像分别复制到新的图像中
cvSetImageROI( total_frame, cvRect(, , frame->width, frame->height));
cvCopy( frame, total_frame, );
cvResetImageROI(total_frame); cvSetImageROI( total_frame, cvRect(frame->width, , gray_frame->width, gray_frame->height));
cvCopy( gray_frame_3, total_frame, );
cvResetImageROI(total_frame); cvSetImageROI( total_frame, cvRect(frame->width*, , canny_frame->width, canny_frame->height));
cvCopy( canny_frame_3, total_frame, );
cvResetImageROI(total_frame); // 在图像的三个不同的部分写上合适的文字标签
CvFont textFont = cvFont( , );
cvInitFont( &textFont, CV_FONT_HERSHEY_SIMPLEX, 0.5f, 0.5f, , ); cvPutText( total_frame, "Frame", cvPoint( , ), &textFont, cvScalar( , , ) );
cvPutText( total_frame, "Frame_Gray", cvPoint( frame->width + , ), &textFont, cvScalar( , , ) );
cvPutText( total_frame, "Frame_Canny", cvPoint( frame->width * + , ), &textFont, cvScalar( , , ) ); // 显示图像
cvShowImage("total", total_frame); char c = cvWaitKey();
if(c == )
break;
}
cvReleaseImage( & gray_frame );
cvReleaseCapture(&capture);
cvDestroyAllWindows(); return ;
}

运行结果:

《学习OpenCV》练习题第四章第一题b&c的更多相关文章

  1. 《学习OpenCV》练习题第四章第一题a

    #include <highgui.h> #include <cv.h> #pragma comment (lib,"opencv_calib3d231d.lib&q ...

  2. 《学习OpenCV》练习题第五章第一题ab

    这道题是载入一幅带有有趣纹理的图像并用不同的模板(窗口,核)大小做高斯模糊(高斯平滑),然后比较用5*5大小的窗口平滑图像两次和用11*11大小的窗口平滑图像一次是否接近相同. 先说下我的做法,a部分 ...

  3. 《学习OpenCV》练习题第四章第二题

    #include <highgui.h> #include <cv.h> #pragma comment (lib,"opencv_calib3d231d.lib&q ...

  4. 《学习OpenCV》 第四章 习题六

    实现的是一个图像标签编辑器,其间遇到了些问题还未解决或者可能解决方法上不是最优,若你有更好的思路可以提供给我,大恩不言谢啦!!☆⌒(*^-゜)v. #include "stdafx.h&qu ...

  5. 《学习OpenCV》练习题第四章第八题ab

    这道题是利用OpenCV例子程序里自带的人脸检测程序,做点图像的复制操作以及alpha融合. 说明:人脸检测的程序我参照了网上现有的例子程序,没有用我用的OpenCV版本(2.4.5)的facedet ...

  6. 《学习OpenCV》练习题第四章第三题b

    #include <highgui.h> #include <cv.h> #include "opencv_libs.h" /* *<学习OpenCV ...

  7. 《学习OpenCV》练习题第四章第三题a

    #include <highgui.h> #include <cv.h> #include "opencv_libs.h" #pragma comment ...

  8. 《学习OpenCV》练习题第四章第七题abc

    题外话:一直是打算把这本书的全部课后编程题写完的,中间断了几个月,一直忙于其他事.现在开始补上. 这道题我不清楚我理解的题意是不是正确的,这道题可以练习用OpenCV实现透视变换(可以用于矫正在3维环 ...

  9. 《学习OpenCV》练习题第五章第二题abc

    代码: #include <stdio.h> #include <opencv/highgui.h> #include <opencv/cv.h> #include ...

随机推荐

  1. [原]最短路专题【基础篇】(updating...)

    hud1548 a strange lift  最短路/bfs  题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1548 题意:一个奇怪的电梯,每层楼的 ...

  2. 自动化mobile测试

    MicroFocus推出手机自动化测试工具 - Silk Mobilehttp://automationqa.com/forum.php?mod=viewthread&tid=1068& ...

  3. C#图片切割、图片压缩、缩略图生成

    C#图片切割.图片压缩.缩略图生成的实现代码 /// 图片切割函数  /// </summary>  /// <param name="sourceFile"&g ...

  4. PHP文件上传代码和逻辑详解

    文件上传的逐步完善------ [简单的上传:]   <form action="upload.php"  method="post"  enctype= ...

  5. 网络攻击之二:XSS(之一是SQL注入,前面有文章)

    学习了 http://www.oschina.net/question/565065_57506 (这里做了转载 http://blog.csdn.net/stilling2006/article/d ...

  6. C#基本数据类型

    在第一章我们了解了C#的输入.输出语句后,我这一节主要是介绍C#的基础知识,本节的内容也是后续章节的基础,好的开端等于成功的一半.在你阅读完本章后,你就有足够的C#知识编写简单的程序了.但还不能使用继 ...

  7. zoj 2105 Lifting the Stone

    题意   裸的计算几何  求多边形重心: #include<iostream> #include<stdio.h> #include<cstring> #inclu ...

  8. Excel 之查找与替换

    Excel查找与替换 1,一旦学会查找,替换就简单了. 2,查找下面有一个选项,里面有对查找的范围进行限制 3,你可以选中一个区域,然后再查找,查找只会在你选择的区域里面进行 4,查找只能找特定值,而 ...

  9. javamail模拟邮箱功能发送电子邮件-基础实战篇(javamail API电子邮件实例)

    引言: JavaMail 是一种可选的.能用于读取.编写和发送电子消息的包 JavaMail jar包下载地址:http://java.sun.com/products/javamail/downlo ...

  10. Java自动装箱拆箱

    一.装箱.拆箱定义 如果一个int型量被传递到需要一个Integer对象的地方,那么,编译器将在幕后插入一个对Integer构造方法的调用,这就叫做自动装箱.而如果一个Integer对象被放到需要in ...