《学习OpenCV》练习题第四章第三题b
#include <highgui.h>
#include <cv.h>
#include "opencv_libs.h" /*
*《学习OpenCV》第四章第三题b
* 完成时间:1:36 3/31 星期日 2013
*/ /* 矩形框 */
CvRect rect; bool draw = false; // 标记是否在画 IplImage* img;
IplImage * temp;
IplImage * original; bool draw_hist = false; IplImage* getHistImage(IplImage* image, CvHistogram* image_hist,
CvSize image_size, CvScalar value)
{
// 计算直方图
cvCalcHist( &image, image_hist, , NULL );
// 新建一幅3通道的图像
IplImage* dst = cvCreateImage(image_size, IPL_DEPTH_8U, ); cvSet( dst, cvScalarAll() ); float max_value = ;
cvGetMinMaxHistValue( image_hist, NULL, &max_value, NULL, NULL );
double bin_width = (double)dst->width/;
double bin_unith = (double)dst->height/max_value; // 高度比例 for(int i = ; i < ; i++)
{
// 获得矩形左上角和右下角坐标
CvPoint p0 = cvPoint( i + bin_width, dst->height );
CvPoint p1 = cvPoint( (i+) * bin_width,
dst->height - cvGetReal1D(image_hist->bins, i) * bin_unith );
// 画实心矩形
cvRectangle( dst, p0, p1, value, -, , );
} return dst;
} void draw_rect(IplImage* img, CvRect rect)
{
cvRectangle( img,
cvPoint( rect.x, rect.y ),
cvPoint( rect.x + rect.width, rect.y + rect.height),
cvScalar( 0x00, 0x00, 0xff) );
printf("draw\n"); // 在这里处理直方图
// 设置感兴趣区域
cvSetImageROI( img, rect);
IplImage* src_rect = cvCreateImage (
cvSize( rect.width, rect.height ),
img->depth, img->nChannels );
cvCopy(img, src_rect );
cvResetImageROI( img ); IplImage* r_img = cvCreateImage( cvGetSize( src_rect),
src_rect->depth, );
IplImage* g_img = cvCreateImage( cvGetSize( src_rect),
src_rect->depth, );
IplImage* b_img = cvCreateImage( cvGetSize( src_rect),
src_rect->depth, );
IplImage* gray_img = cvCreateImage( cvGetSize( src_rect),
src_rect->depth, ); // 分离RGB分量
cvSplit( src_rect, r_img, g_img, b_img, NULL);
cvShowImage( "red", r_img);
cvShowImage( "green", g_img);
cvShowImage( "blue", b_img); // 灰度转换
cvCvtColor( src_rect, gray_img, CV_BGR2GRAY);
int size = ;
float range[] = {, };
float* ranges[] = {range};
// 创建直方图
CvHistogram * r_hist = cvCreateHist( , &size, CV_HIST_ARRAY, ranges, );
CvHistogram * g_hist = cvCreateHist( , &size, CV_HIST_ARRAY, ranges, );
CvHistogram * b_hist = cvCreateHist( , &size, CV_HIST_ARRAY, ranges, );
CvHistogram * gray_hist = cvCreateHist( , &size, CV_HIST_ARRAY, ranges, ); // 直方图尺寸
CvSize image_size = cvSize( , ); IplImage* r_dst = getHistImage(r_img, r_hist, image_size, cvScalar(0x00, 0x00, 0xff));
IplImage* g_dst = getHistImage(g_img, g_hist, image_size, cvScalar(0x00, 0xff, 0x00));
IplImage* b_dst = getHistImage(b_img, b_hist, image_size, cvScalar(0xff, 0x00, 0x00));
IplImage* gray_dst = getHistImage( gray_img, gray_hist, image_size, cvScalar() ); // 把四个直方图在一幅图片上显示出来
IplImage* dst = cvCreateImage( cvSize( image_size.width * , image_size.height * ), , );
cvSetZero( dst );
// 拷贝红色分量直方图
CvRect r_rect = cvRect( , , image_size.width, image_size.height);
cvSetImageROI(dst, r_rect);
cvCopy( r_dst, dst);
// 拷贝绿色分量直方图
CvRect g_rect = cvRect(image_size.width, , image_size.width, image_size.height );
cvSetImageROI( dst, g_rect);
cvCopy( g_dst, dst);
// 蓝色分量
CvRect b_rect = cvRect(, image_size.height, image_size.width, image_size.height );
cvSetImageROI(dst, b_rect);
cvCopy( b_dst, dst );
// 灰度分量
CvRect gray_rect = cvRect( image_size.width, image_size.height,
image_size.width, image_size.height );
cvSetImageROI( dst, gray_rect);
cvCopy( gray_dst, dst); cvResetImageROI( dst ); cvShowImage( "src", src_rect);
cvShowImage( "dst", dst ); cvWaitKey(); cvDestroyAllWindows();
cvReleaseImage( &r_img );
cvReleaseImage(&g_img);
cvReleaseImage(&b_img);
cvReleaseImage(&gray_img);
cvReleaseImage(&r_dst);
cvReleaseImage(&g_dst);
cvReleaseImage(&b_dst);
cvReleaseImage(&gray_dst);
cvReleaseImage(&src_rect);
cvReleaseImage(&dst);
} // 鼠标回调函数
void my_mouse_callback( int event, int x, int y, int flags, void* param)
{
IplImage* image = (IplImage*) param; switch( event )
{
case CV_EVENT_MOUSEMOVE:
{
if(draw)
{
rect.width = x - rect.x;
rect.height = y - rect.y;
} draw_hist = false;
}
break;
case CV_EVENT_LBUTTONDOWN:
{
draw = true;
rect = cvRect( x, y, , );
draw_hist = false;
}
break;
case CV_EVENT_LBUTTONUP:
{
draw = false;
draw_hist = true;
if(rect.width < )
{
rect.x += rect.width;
rect.width *= -;
}
if(rect.height < )
{
rect.y += rect.height;
rect.height *= -;
}
// draw
draw_rect(image, rect);
}
break;
// 在右键按下时清除
case CV_EVENT_RBUTTONDOWN:
cvCopyImage(original, img);
printf("clear.\n");
break;
}
} int main()
{
img = cvLoadImage( "lena.bmp", ); rect = cvRect( -, -, , ); // 副本
temp = cvCloneImage( img );
original = cvCloneImage(img); cvNamedWindow("draw rect");
cvSetMouseCallback("draw rect", my_mouse_callback, (void*)img); while()
{
cvCopyImage(img, temp); if(draw_hist)
{
draw_rect( temp , rect );
} cvShowImage( "draw rect", temp); if(cvWaitKey() == )
break;
}
cvReleaseImage(&img);
cvReleaseImage(&temp);
cvDestroyAllWindows(); return ;
}
运行结果:

不足:在源图像上用鼠标选择矩形区域的时候,无法实时地在图像上反映出来。
《学习OpenCV》练习题第四章第三题b的更多相关文章
- 《学习OpenCV》练习题第四章第三题a
#include <highgui.h> #include <cv.h> #include "opencv_libs.h" #pragma comment ...
- 《学习OpenCV》练习题第四章第八题ab
这道题是利用OpenCV例子程序里自带的人脸检测程序,做点图像的复制操作以及alpha融合. 说明:人脸检测的程序我参照了网上现有的例子程序,没有用我用的OpenCV版本(2.4.5)的facedet ...
- 《学习OpenCV》练习题第四章第七题abc
题外话:一直是打算把这本书的全部课后编程题写完的,中间断了几个月,一直忙于其他事.现在开始补上. 这道题我不清楚我理解的题意是不是正确的,这道题可以练习用OpenCV实现透视变换(可以用于矫正在3维环 ...
- OpenCV实现的高斯滤波探究_1(《学习OpenCV》练习题第五章第三题ab部分)
首先看下OpenCV 官方文档对于cvSmooth各个参数的解释: Smooths the image in one of several ways. C: void cvSmooth(const C ...
- 《学习OpenCV》 第四章 习题六
实现的是一个图像标签编辑器,其间遇到了些问题还未解决或者可能解决方法上不是最优,若你有更好的思路可以提供给我,大恩不言谢啦!!☆⌒(*^-゜)v. #include "stdafx.h&qu ...
- 《学习OpenCV》练习题第四章第一题b&c
#include <highgui.h> #include <cv.h> #pragma comment (lib,"opencv_calib3d231d.lib&q ...
- 《学习OpenCV》练习题第四章第二题
#include <highgui.h> #include <cv.h> #pragma comment (lib,"opencv_calib3d231d.lib&q ...
- 《学习OpenCV》练习题第四章第一题a
#include <highgui.h> #include <cv.h> #pragma comment (lib,"opencv_calib3d231d.lib&q ...
- 学习opencv中文版教程——第二章
学习opencv中文版教程——第二章 所有案例,跑起来~~~然而并没有都跑起来...我只把我能跑的都尽量跑了,毕竟看书还是很生硬,能运行能出结果,才比较好. 越着急,心越慌,越是着急,越要慢,越是陌生 ...
随机推荐
- 解决 iReport 生成 pdf 时显示不出中文的问题
有没有遇到这样的情况:在使用 iReport 做报表时,用pdf预览显示不出中文? 解决步骤是这样的: 1.加入jar包 下载两个jar包:itextasian.jar 和 itext-x.y.jar ...
- Android HTTPS(3) IOException: Hostname 解决方案
Common Problems with Hostname Verification As mentioned at the beginning of this article, there are ...
- JavaScript 类的定义和引用 JavaScript高级培训 自定义对象
在Java语言中,我们可以定义自己的类,并根据这些类创建对象来使用,在Javascript中,我们也可以定义自己的类,例如定义User类.Hashtable类等等. 一,概述 在Java语言中 ...
- .NET Framework 4.5 五个很棒的特性
转自http://news.cnblogs.com/n/192958/ 英文原文:Five Great .NET Framework 4.5 Features 简介 自 .NET 4.5 发布已经过了 ...
- 韦东山驱动视频笔记——3.字符设备驱动程序之poll机制
linux内核版本:linux-2.6.30.4 目的:我们在中断方式的按键应用程序中,如果没有按键按下,read就会永远在那等待,所以如果在这个程序里还想做其他事就不可能了.因此我们这次改进它,让它 ...
- QCon 2015 阅读笔记 - 移动开发最佳实践
所有ppt下载地址:http://pan.baidu.com/s/1mg9o4TM 下面是移动开发实践部分的阅读笔记. 移动开发网络性能优化实践 - 陈浩然 (携程) 携程是非常标准的移动App架构, ...
- .CO域名快被这帮搞IT的玩坏了……
鉴于近来国内访问Google的服务受阻,greatfire.org于前天推出了其基于亚马逊AWS的Google搜索镜像网站,地址是sinaapp.co.该网站随后因多家海外媒体的报道和众多微博大V的转 ...
- jquery事件学习笔记(转载)
一.页面载入1.ready(fn)当DOM载入就绪可以查询及操纵时绑定一个要执行的函数.这是事件模块中最重要的一个函数,因为它可以极大地提高web应用程序的响应速度. 简单地说,这个方法纯粹是对向wi ...
- Android Bitmap实战技巧
注:本文大量参考谷歌官方文档自http://developer.android.com/intl/zh-cn/training/displaying-bitmaps/index.html.如果你自学能 ...
- android adt自带eclipse无法设置ndk路径(找不到NDK配置)
分步阅读 到android sdk官网下载r23版本的adt时自带的eclipse没有设置ndk路径的地方,通过Install New Software 发现无法更新,那么如何解决这个问题呢? 方便他 ...