《学习OpenCV》课后习题解答8
题目:(P126)
本章完整讲述了基本的输入/输出编程以及OpenCV的数据结构。下面的练习是基于前面的知识做一些应用,为后面大程序的实现提供帮助。
a.创建一个程序实现以下功能:(1)从视频文件中读入数据;(2)讲读入数据转换为灰度图;(3)对图像做Canny边缘检测。将三个过程的处理结果显示到不同的窗口中,每个窗口根据其内容合理命名。
b. 将所有三个步骤实现显示在一个图像中。提示:创建一个新的图像,其高度与原始图像相同,宽度为原来视频帧的3倍,将3幅图像分别复制到新的图像中:可使用指针;或者更巧妙地创建三个图像头,三个图像头分别指向图像数据的开始处,1/3处和2/3处,然后使用函数cvCopy()复制。
c.在图像的三个不同部分写上合适的文字标签。
解答a:
#include<cv.h>
#include<highgui.h>
int main(int argc, char** argv)
{
cvNamedWindow("WIN1", CV_WINDOW_AUTOSIZE);
cvNamedWindow("WIN2", CV_WINDOW_AUTOSIZE);
cvNamedWindow("WIN3", CV_WINDOW_AUTOSIZE);
CvCapture* capture = cvCreateFileCapture(argv[1]);
if (!capture) { return -1; }
IplImage* frame;
IplImage* frame1;
IplImage* frame2;
IplImage* frame3;
while (1) {
frame = cvQueryFrame(capture);
if (!frame)break;
frame1 = frame;
frame2 = cvCreateImage(cvGetSize(frame), frame->depth, 1);
frame3 = cvCreateImage(cvGetSize(frame), frame->depth, 1);
cvCvtColor(frame, frame2, CV_BGR2GRAY);//转换成灰度图
cvCanny(frame2,frame3,10,100);//进行Canny边缘检测。
cvShowImage("WIN1", frame1);
cvShowImage("WIN2", frame2);
cvShowImage("WIN3", frame3);
char c = cvWaitKey(33);
if (c == 27)break;
}
cvReleaseCapture(&capture);
cvDestroyWindow("WIN1");
cvDestroyWindow("WIN2");
cvDestroyWindow("WIN3");
}
解答b:
#include "cv.h"
#include "highgui.h"
int main(int argc, char** argv)
{
//根据要求首先定义4个不同的窗口,用于处理后图像的显示
cvNamedWindow("sourceImg");
cvNamedWindow("grayImg");
cvNamedWindow("cannyImg");
cvNamedWindow("newImg");
CvCapture *capture = cvCreateFileCapture(argv[1]);
if (!capture)return -1;
IplImage *sourceImg = cvQueryFrame(capture);
int width = sourceImg->width;
int heigth = sourceImg->height;
IplImage *grayImg = cvCreateImage(cvGetSize(sourceImg), sourceImg->depth, 1);
IplImage *cannyImg = cvCreateImage(cvGetSize(sourceImg), sourceImg->depth, 1);
//创建一个新的图像,用来保存上述3个图像(本代码的核心思想所在)
IplImage *newImg = cvCreateImage(cvSize(3 * sourceImg->width, sourceImg->height), sourceImg->depth, sourceImg->nChannels);
cvZero(newImg);
while ((sourceImg = cvQueryFrame(capture)) != NULL)
{
//从彩色图像转换成灰度图像
cvCvtColor(sourceImg, grayImg, CV_BGR2GRAY);
//Canny推荐的上下阈值比为2:1到3:1之间,这里使用了3:1,可自行修改highThresh:lowThresh的比例
cvCanny(grayImg, cannyImg, 10, 30, 3);
//运行发现,灰度和canny图像翻转了,所以通过重新定义图像原点
//origin为0表示顶左结构,origin为1表示底左结构
grayImg->origin = 1;
cannyImg->origin = 1;
//载入原图像到目标图像
cvSetImageROI(newImg, cvRect(0, 0, sourceImg->width, sourceImg->height));
//由于读入的是视频文件,并且原视频帧和处理后的视频帧通道数可能不同,所以此处需要手动设置通道数
newImg->nChannels = sourceImg->nChannels;
cvCopy(sourceImg, newImg);
cvResetImageROI(newImg);
cvSetImageROI(newImg, cvRect(sourceImg->width, 0, sourceImg->width, sourceImg->height));
newImg->nChannels = 1;
cvCopy(grayImg, newImg);
cvResetImageROI(newImg);
cvSetImageROI(newImg, cvRect(2 * (sourceImg->width), 0, sourceImg->width, sourceImg->height));
newImg->nChannels = 1;
cvCopy(cannyImg, newImg);
cvResetImageROI(newImg);
cvShowImage("sourceImg", sourceImg);
cvShowImage("grayImg", grayImg);
cvShowImage("cannyImg", cannyImg);
cvShowImage("newImg", newImg);
cvWaitKey(33);
}
cvReleaseImage(&grayImg);
cvReleaseImage(&cannyImg);
cvReleaseImage(&newImg);
cvReleaseCapture(&capture);
cvDestroyWindow("sourceImg");
cvDestroyWindow("grayImg");
cvDestroyWindow("cannyImg");
cvDestroyWindow("newImg");
return 0;
}
解答c:就是利用cvPutText函数在图像上添加文字,代码略了。。。
《学习OpenCV》课后习题解答8的更多相关文章
- 機器學習基石(Machine Learning Foundations) 机器学习基石 作业三 课后习题解答
今天和大家分享coursera-NTU-機器學習基石(Machine Learning Foundations)-作业三的习题解答.笔者在做这些题目时遇到非常多困难,当我在网上寻找答案时却找不到,而林 ...
- 《学习OpenCV》课后习题解答6
题目:(P104) 使用cvCmp()创建一个掩码.加载一个真实的图像.使用cvsplit()将图像分割成红,绿,蓝三个单通道图像. a.找到并显示绿图. b.克隆这个绿图两次(分别命名为clone1 ...
- 《学习OpenCV》课后习题解答5
题目:(P104) 为一个图像创建多个图像头.读取一个大小至少为100*100的图像.另创建两个图像头并设置它们的origion,depth,nChannels和widthStep属性同之前读取的图像 ...
- 《学习OpenCV》课后习题解答4
题目:(P104) 练习使用感兴趣区域(ROI).创建一个210*210的单通道图像并将其归0.在图像中使用ROI和cvSet()建立一个增长如金字塔状的数组.也就是:外部边界为0,下一个内部边界应该 ...
- 《学习OpenCV》课后习题解答3
题目:(P104) 创建一个大小为100*100的三通道RGB图像.将它的元素全部置0.使用指针算法以(20,5)与(40,20)为项点绘制一个绿色平面. 解答: #include "cv. ...
- 《学习OpenCV》课后习题解答2
题目:(P104) 创建一个拥有三个通道的二维字节类型矩阵,大小为100*100,并将所有值赋为0.通过函数cvPtr2D将指针指向中间的通道("绿色").以(20,5)与(40, ...
- 《学习OpenCV》课后习题解答9
题目:(P126) 创建一个程序,使其读入并显示一幅图像.当用户鼠标点击图像时,获取图像对应像素的颜色值(BGR),并在图像上点击鼠标处用文本将颜色值显示出来. 解答: 本题关键是会用cvGet2D获 ...
- 《学习OpenCV》课后习题解答7
题目:(P105) 创建一个结构,结构中包含一个整数,一个CvPoint和一个 CvRect:称结构体为"my_struct". a. 写两个函数:void Write_my_st ...
- 《学习OpenCV》课后习题解答1
题目:(P104) 下面这个练习是帮助掌握矩阵类型.创造一个三通道二维矩阵,字节类型,大小为100*100,并设置所有数值为0. a.在矩阵中使用cvCircle( CvArr* img, CvPoi ...
随机推荐
- JavaScript 基础(六) 数组方法 闭包
在一个对象中绑定函数,称为这个对象的方法.在JavaScript 中,对象的定义是这样的: var guagua = { name:'瓜瓜', birth:1990 }; 但是,如果我们给瓜瓜绑定一个 ...
- 【例题收藏】◇例题·6◇ 电压机制(voltage)
◆例题·6◆ 电压机制 周六日常模拟赛……已经不知道该说什么了(感觉做不出来的都是好题) ▷ 题目 (终于不用自己翻译英文题了╮(╯-╰)╭) [问题描述] 科学家在“无限神机”(Infinity M ...
- mysql修改登录密码三种方式
一.用SET PASSWORD命令 首先登录MySQL,使用mysql自带的那个客户端连接上mysql. 格式:mysql> set password for 用户名@localhost = ...
- Co. - Apple - MacBook Pro 快捷键
Mac 键盘快捷键:https://support.apple.com/zh-cn/HT201236 从windows转到mac的童鞋,可能删除键是心中的一个痛,以前习惯一按delete什么都消失,其 ...
- JDK7 新特性
JDK7新特性的目录导航: 二进制字面值 switch 语句支持 String try-with-resources catch 多个类型异常 字面值中使用下划线 类型推断 改进泛型类型可变参数 其它 ...
- 一、Linux知识体系结构图
参考: https://blog.csdn.net/Swing_Liu/article/details/79202479
- keil5 mdk使用ST-Link II下载出现cannot halt the core解决办法
在正常的程序里面,我添加了MB85RS16(spi flash)这个外设驱动代码后,使用ST-Link II下载就出现cannot halt the core. 这个现象之前出现过1次,但是解决办法忘 ...
- C语言实例解析精粹学习笔记——43(希尔排序)
实例说明: 用希尔排序方法对数组进行排序.由于书中更关注的实例,对于原理来说有一定的解释,但是对于第一次接触的人来说可能略微有些简略.自己在草稿纸上画了好久,后来发现网上有好多很漂亮的原理图. 下面将 ...
- red hat 7 启动过程(EFI)
不同版本的Linux系统的启动过程在某些地方是不一样的,现在先来介绍一下red hat 7 的启动过程(EFI). (加电→图形登录界面) 接通电源 按下电源键 EFI固件启动 初始化硬件 从EFI启 ...
- 「LibreOJ#516」DP 一般看规律
首先对于序列上一点,它对答案的贡献只有与它的前驱和后驱(前提颜色相同)构成的点对, 于是想到用set维护每个颜色,修改操作就是将2个set暴力合并(小的向大的合并),每次插入时更新答案即可 颜色数要离 ...