庞峰Opencv学习(四)--颜色空间转换

  今天学习了一下,BGR和HSV颜色空间以及二者间的转换,感觉还是写了程序印象才更加深刻,记得也更牢吧。

  1. BGR空间相信大家都已经比较了解了,还是说一下HSV颜色空间吧。

  H代表Hue即色度:这里的H以一个360°的转盘呈现,0°代表红色,直径上的端点互为补色,即合成为白色。

  S代表Saturation即饱和度:通俗的来讲就是颜色纯不纯,数值越大表示颜色越纯。

  V代表Value即纯度:可以理解为亮度Brightness,数值越大颜色显得越亮。

  2. 函数进行一下介绍

    ConverScale:使用线性变换转换数组

    void cvConvertScale( const CvArr* src, CvArr* dst, double scale=1, double shift=0 );

    在颜色空间的转换中,由于CvShowImage()函数只对8位无符号型颜色深度图像进行显示,所以需要将HSV空间的深度进行转换,而从HSV向BGR空间转换时也有同样的问题,如下面代码所示

 3. 在8位无符号颜色深度的HSV空间中,H通道为0-180 S通道为0-1 V通道为0-255 在转换时需要特别注意,图2为从HSV空间通过单通道融合转换到BGR空间的图像,图3是在HSV空间通过CvCvtColor()函数复原的BGR图像。

#include "cv.h"
#include "cxcore.h"
#include "highgui.h"
#include "stdio.h"

void main()
{
	//进行RGB到HSV空间的转换
	IplImage* src = cvLoadImage("1.jpg");
	cvNamedWindow("src");
	cvShowImage("src",src);
	cvWaitKey(0);

	IplImage* hsv1 = cvCreateImage(cvGetSize(src),8,3);
	IplImage* h1 = cvCreateImage(cvGetSize(src),8,1);
	IplImage* s1 = cvCreateImage(cvGetSize(src),8,1);
	IplImage* v1 = cvCreateImage(cvGetSize(src),8,1);

	//进行RGB2HSV
	cvCvtColor(src,hsv1,CV_BGR2HSV);

	cvSplit(hsv1,h1,s1,v1,NULL);

	/*for(int y=0;y<h1->height;y++)
	{
		for (int x=0; x<h1->width;x++)
		{
			float hout = cvGetReal2D(h1,y,x);//由于8位最多保存255,所以这里只保存0-180
			printf("%f ",hout);
		}
	}*/
	/************************************************************************/
	/* 得出H(色度)通道的值都是0到180的浮点值,而s(饱和度)通道为0到1,V(亮度)通道为0-255                                                                  */
	/************************************************************************/

	//*****将H通道转换为0-360高精度输出*********
	IplImage* src_float = cvCreateImage(cvGetSize(src),IPL_DEPTH_32F,3);
	IplImage* hsv2 = cvCreateImage(cvGetSize(src),IPL_DEPTH_32F,3);
	IplImage* h2 = cvCreateImage(cvGetSize(src),IPL_DEPTH_32F,1);
	IplImage* s2 = cvCreateImage(cvGetSize(src),IPL_DEPTH_32F,1);
	IplImage* v2 = cvCreateImage(cvGetSize(src),IPL_DEPTH_32F,1);
	//进行8位无符号char向32位float转换
	cvConvertScale(src,src_float,1.0 ,0);
	cvCvtColor(src_float,hsv2,CV_RGB2HSV);

	cvSplit(hsv2,h2,s2,v2,NULL);
/*	for(int y=0;y<h2->height;y++)
	{
		for (int x=0; x<h2->width;x++)
		{
			float hout = cvGetReal2D(h2,y,x);//0-(<360)
			printf("%f ",hout);
		}
	}*/

	//进行HSV向RGB的转换
	IplImage* bgrMerge = cvCreateImage(cvGetSize(src),8,3);
	IplImage *b1 = cvCreateImage(cvGetSize(src),8,1);
	IplImage *g1 = cvCreateImage(cvGetSize(src),8,1);
	IplImage *r1 = cvCreateImage(cvGetSize(src),8,1);
	cvConvertScale(h2,b1,(1.0/360)*255,0);//0-(<360)->0-255
	cvConvertScale(s2,g1,255,0);
	cvConvertScale(v2,r1,1.0,0);

	cvMerge(b1,g1,r1,NULL,bgrMerge);

	cvNamedWindow("merge");
	cvShowImage("merge",bgrMerge);
	cvWaitKey(0);

	IplImage* bgrMerge2 = cvCreateImage(cvGetSize(src),8,3);
	cvCvtColor(hsv1,bgrMerge2,CV_HSV2BGR);

	cvNamedWindow("merge2");
	cvShowImage("merge2",bgrMerge2);
	cvWaitKey(0);

}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值