`

OpenCV 实现颜色直方图

 
阅读更多

颜色直方图是在许多图像检索系统中被广泛采用的颜色特征。它所描述的是不同色彩在整幅图像中所占的比例,而并不关心每种色彩所处的空间位置,即无法描述图像中的对象或物体。颜色直方图特别适于描述那些难以进行自动分割的图像。

OpenCV对颜色直方图进行统计的代码如下所示,在图像检索,镜头分割等领域使用的还是比较多的。

 

#include <cv.h>
#include <highgui.h>
#include <iostream>
using namespace std;



int main( int argc, char** argv )
{
	IplImage * src= cvLoadImage("F:\\test3.jpg");

	IplImage* hsv = cvCreateImage( cvGetSize(src), 8, 3 );
	IplImage* h_plane = cvCreateImage( cvGetSize(src), 8, 1 );
	IplImage* s_plane = cvCreateImage( cvGetSize(src), 8, 1 );
	IplImage* v_plane = cvCreateImage( cvGetSize(src), 8, 1 );
	IplImage* planes[] = { h_plane, s_plane };

	/** H 分量划分为16个等级,S分量划分为8个等级 */
	int h_bins = 16, s_bins = 8;
	int hist_size[] = {h_bins, s_bins};

	/** H 分量的变化范围 */
	float h_ranges[] = { 0, 180 }; 

	/** S 分量的变化范围*/
	float s_ranges[] = { 0, 255 };
	float* ranges[] = { h_ranges, s_ranges };

	/** 输入图像转换到HSV颜色空间 */
	cvCvtColor( src, hsv, CV_BGR2HSV );
	cvCvtPixToPlane( hsv, h_plane, s_plane, v_plane, 0 );

	/** 创建直方图,二维, 每个维度上均分 */
	CvHistogram * hist = cvCreateHist( 2, hist_size, CV_HIST_ARRAY, ranges, 1 );
	/** 根据H,S两个平面数据统计直方图 */
	cvCalcHist( planes, hist, 0, 0 );

	/** 获取直方图统计的最大值,用于动态显示直方图 */
	float max_value;
	cvGetMinMaxHistValue( hist, 0, &max_value, 0, 0 );


	/** 设置直方图显示图像 */
	int height = 240;
	int width = (h_bins*s_bins*6);
	IplImage* hist_img = cvCreateImage( cvSize(width,height), 8, 3 );
	cvZero( hist_img );

	/** 用来进行HSV到RGB颜色转换的临时单位图像 */
	IplImage * hsv_color = cvCreateImage(cvSize(1,1),8,3);
	IplImage * rgb_color = cvCreateImage(cvSize(1,1),8,3);
	int bin_w = width / (h_bins * s_bins);
	for(int h = 0; h < h_bins; h++)
	{
		for(int s = 0; s < s_bins; s++)
		{
			int i = h*s_bins + s;
			/** 获得直方图中的统计次数,计算显示在图像中的高度 */
			float bin_val = cvQueryHistValue_2D( hist, h, s );
			int intensity = cvRound(bin_val*height/max_value);

			/** 获得当前直方图代表的颜色,转换成RGB用于绘制 */
			cvSet2D(hsv_color,0,0,cvScalar(h*180.f / h_bins,s*255.f/s_bins,255,0));
			cvCvtColor(hsv_color,rgb_color,CV_HSV2BGR);
			CvScalar color = cvGet2D(rgb_color,0,0);

			cvRectangle( hist_img, cvPoint(i*bin_w,height),
				cvPoint((i+1)*bin_w,height - intensity),
				color, -1, 8, 0 );
		}
	}

	cvNamedWindow( "Source", 1 );
	cvShowImage( "Source", src );

	cvNamedWindow( "H-S Histogram", 1 );
	cvShowImage( "H-S Histogram", hist_img );

	cvWaitKey(0);
}

 

原文地址:http://wiki.opencv.org.cn/index.php/图像颜色分布直方图

 

分享到:
评论

相关推荐

    opencv基于颜色直方图进行模板图像匹配检测的程序

    在这个特定的程序中,开发者利用OpenCV的功能实现了一种基于颜色直方图的图像匹配方法。颜色直方图是一种统计图像颜色分布的方法,它将图像的颜色空间分成多个区间(或 bin),然后计算每个区间内像素的数量,形成一...

    基于OpenCV的颜色直方图

    总之,理解和掌握OpenCV的颜色直方图是深入学习计算机视觉的基础,它能帮助你更好地理解图像的色彩特性,并在实际项目中实现各种图像处理效果。通过不断的实践和探索,你可以利用这些知识解决更复杂的问题,比如图像...

    基于OPENCV的计算图像颜色直方图代码

    OpenCV(开源计算机视觉库)是一个强大的跨平台库,提供了丰富的功能来处理图像和视频,包括计算颜色直方图。这个基于OpenCV和Visual C++(VC)的小程序就是用来实现这一功能的。 颜色直方图是通过统计图像中每个...

    opencv颜色直方图相关处理操作以及理解

    在OpenCV库中,颜色直方图是一种强大的图像分析工具,用于表示图像中不同颜色分布的情况。本篇文章将深入探讨颜色直方图的概念、创建过程以及如何在OpenCV中进行直方图操作,同时涉及数据读取和均值化等重要步骤。 ...

    基于opencv图像颜色直方图提取程序

    总结,这个基于OpenCV的程序通过以下步骤实现颜色直方图的提取: 1. 读取图像并转换为HSV色彩空间。 2. 统计H和S分量的直方图。 3. 计算直方图的最大值。 4. 创建直方图图像并根据直方图数据填充图像。 5. 可选地,...

    基于opencv的彩色图像直方图均衡

    在OpenCV中,直方图均衡化的实现主要依赖于`cv::equalizeHist()`函数。对于灰度图像,该函数可以直接使用;对于彩色图像,通常需要先将图像转换为灰度空间,如使用`cv::cvtColor()`函数将RGB图像转换为灰度图像,...

    颜色直方图匹配算法opencv实现

    在"pp8"文件中,很可能是包含了实现颜色直方图匹配的源代码或者示例项目。打开并分析这个文件,可以深入理解算法的实现细节。同时,为了更好地理解并运用这些知识,建议动手实践,根据给定的代码进行编译和运行,...

    利用OpenCV获得图像直方图

    你可以通过累加直方图值实现这个功能。 总的来说,OpenCV提供的图像直方图功能是图像分析和处理的重要部分,它可以帮助我们更好地理解和调整图像的特性。无论是灰度图像还是彩色图像,OpenCV都能提供有效的计算方法...

    OpenCV颜色直方图匹配程序

    本项目关注的是“OpenCV颜色直方图匹配程序”,它涉及到HSV色彩空间以及不同的匹配算法。HSV,全称为Hue(色调)、Saturation(饱和度)、Value(亮度),是一种更加符合人类视觉感知的颜色表示方式,常用于图像处理...

    opencv直方图计算

    - **颜色直方图**:对于彩色图像,可以分别计算每个颜色通道的直方图,或者计算RGB空间的整体直方图。 - **图像匹配与分类**:直方图相似度可以作为图像匹配的依据之一。 - **图像分割**:直方图阈值分割是常见的...

    opencv特征提取 颜色直方图、纹理

    在这个话题中,我们将深入探讨OpenCV中的特征提取,特别是颜色直方图和纹理分析。 **颜色直方图** 颜色直方图是表示图像中颜色分布的一种统计方法。在二维或三维空间中,它展示了图像中不同颜色出现的频率。在...

    OpenCv生成图像直方图

    2. **OpenCV实现**:在OpenCV中,可以使用 `cv::calcHist()` 函数生成二维直方图,只需设置合适的通道参数。例如,对于RGB图像,可以分别对R、G、B通道进行直方图计算,然后将结果合并。 3. **可视化**:二维直方图...

Global site tag (gtag.js) - Google Analytics