现在的位置: 首页 > 综合 > 正文

opencv 学习笔记-入门(4)

2013年02月26日 ⁄ 综合 ⁄ 共 1602字 ⁄ 字号 评论关闭

一、256色转灰度图
    算法介绍(
百度百科)


    什么叫灰度图?任何颜色都有红、绿、蓝三原色组成,假如原来某点的颜色为RGB(R,G,B),那么,我们可以通过下面几种方法,将其转换为灰度:      1.浮点算法:Gray=R*0.3+G*0.59+B*0.11      2.整数方法:Gray=(R*30+G*59+B*11)/100     3.移位方法:Gray =(R*28+G*151+B*77)>>8;      4.平均值法:Gray=(R+G+B)/3;      5.仅取绿色:Gray=G;       通过上述任一种方法求得Gray后,将原来的RGB(R,G,B)中的R,G,B统一用Gray替换,形成新的颜色RGB(Gray,Gray,Gray),用它替换原来的RGB(R,G,B)就是灰度图了。

灰度分为256阶。所以,用灰度表示的图像称作灰度图。

    程序实现:    ok,知道了什么叫灰度图,下面,咱们就来实现此256色灰度图。这个Convert256toGray(),即是将256色位图转化为灰度图:

变换效果(以下若无特别说明,图示的右边部分都是为某一算法变换之后的效果):

这是自己的实现如有问题,希望指出:

#include "stdafx.h"
#include "iostream"
#include "opencv/cv.h"
#include "opencv/highgui.h"
using namespace std;

//int His[his];
void Convert256toGray(const CvArr * srcarr, CvArr *dstarr);

int main()
{
	IplImage *srcarr = NULL;
	IplImage *dstarr = NULL;
	srcarr = cvLoadImage("E:\\c++\\OPENCV_1\\lena.jpg", 1);
	dstarr = cvCreateImage( cvSize( srcarr->width, srcarr->height ), srcarr->depth, srcarr->nChannels );
	Convert256toGray( srcarr, dstarr );
//	cvCvtColor( srcarr, dstarr, CV_RGBA2GRAY );
	cvNamedWindow("Exmple", CV_WINDOW_AUTOSIZE);
	cvShowImage("Exmple", dstarr);
	cvWaitKey(0);
   
	cvReleaseImage(&srcarr);
	cvReleaseImage(&dstarr);
	cvDestroyWindow("Exmple");
	cin.get();
	cin.get();
	return 0;
}


void Convert256toGray(const CvArr * srcarr, CvArr *dstarr)
{
	CvMat sstub, *src = cvGetMat( srcarr, &sstub );
	CvMat dstub, *dst = cvGetMat( dstarr, &dstub );

	CvSize size = cvGetSize(src);

	for ( int y = 0; y < size.height; y++ )
	{
		uchar* sptr = src->data.ptr + src->step*y;
		uchar *Dataout = dst->data.ptr + dst->step*y;
		for ( int x = 0; x < size.width; x++, Dataout+=3, sptr+=3)
		{
			Dataout[1] = ( sptr[1] * 30 + sptr[2] * 59 + sptr[3] * 11 ) / 100;
			Dataout[2] = ( sptr[1] * 30 + sptr[2] * 59 + sptr[3] * 11 ) / 100;
			Dataout[3] = ( sptr[1] * 30 + sptr[2] * 59 + sptr[3] * 11 ) / 100;
		}
	}

抱歉!评论已关闭.