photoshop中对比度拉伸

来自:http://emowuyi.iteye.com/blog/1330951

这是《Delphi图像处理 -- Photoshop图像亮度/对比度调整》一文的C/C++版。

还是先简单介绍一下Photoshop图像亮度/对比度调整的原理:

一、对比度算法公式。

Photoshop对于对比度增量,是按给定值的正负分别处理的。

如果用newRGB表示图像像素新的R、G、B分量,RGB表示图像像素R、G、B分量,Threshold为给定的阀值,Contrast为对比度增量,当Contrast大于0时:

1) newRGB = RGB + (RGB - Threshold) * (1 / (1 - Contrast / 255) - 1)

其中,当Contrast等于255时(RGB - Threshold) * (1 / (1 - Contrast / 255) - 1)为无限(±),由于RGB最大最小值分别为255和0,因此,只能按Threshold来确定newRGB,即newRGB = RGB >= Threshold? 255 : 0,这实际就是设置图像阀值,图像由最多八种颜色组成,即红、黄、绿、青、蓝、紫及黑与白,在灰度图上也只有最多8条线。

当Contrast小于0时:

2) newRGB = RGB + (RGB - Threshold) * Contrast / 255

其中,当Contrast等于-255时,图像RGB各分量都等于阀值,图像呈全灰色,灰度图上只有1条线,即阀值灰度。

二、图像亮度调整。本文采用的是最常用的非线性亮度调整(Phoposhop CS3以下版本也是这种亮度调整方式,CS3及以上版本也保留了该亮度调整方式的选项)。

三、图像亮度/对比度综合调整算法。这个很简单,当亮度、对比度同时调整时,如果对比度大于0,现调整亮度,再调整对比度;当对比度小于0时,则相反,先调整对比度,再调整亮度。

下面是用BCB2007和GDI+位图数据写的Photoshop图像亮度/对比度调整全部代码,包括例子代码:

//---------------------------------------------------------------------------
FORCEINLINE
	INT CheckValue(INT value)
{
	return value <= 0? 0 : value >= 255? 255 : value;
}
//---------------------------------------------------------------------------
VOID BrightAndContrast(IplImage *data,IplImage *data1, INT bright, INT contrast, BYTE threshold)
{
	FLOAT cv = contrast <= -255? -1.0f : contrast / 255.0f;
	if (contrast > 0 && contrast < 255)
		cv = 1.0f / (1.0f - cv) - 1.0f;
	CvScalar threshss=cvAvg(data);
	threshold = threshss.val[0];
	BYTE values[256];
	BYTE values1[256];
	BYTE values2[256];
	for (INT i = 0; i < 256; i ++)
	{
		INT v = contrast > 0? CheckValue(i + bright) : i;
		INT v1=v;
		INT v2=v;
		if (contrast >= 255)
		{
			v = v >= threshss.val[0]? 255 : 0;
			v1 = v1 >= threshss.val[1]? 255 : 0;
			v2 = v2 >= threshss.val[2]? 255 : 0;
		}
		else
		{
			v = CheckValue(v + (INT)((v - threshss.val[0]) * cv + 0.5f));
			v1 = CheckValue(v1 + (INT)((v1 - threshss.val[1]) * cv + 0.5f));
			v2 = CheckValue(v2 + (INT)((v2 - threshss.val[2]) * cv + 0.5f));
		}
		values[i] = contrast < 0? CheckValue(v + bright) : v;
		values1[i] = contrast < 0? CheckValue(v1 + bright) : v1;
		values2[i] = contrast < 0? CheckValue(v2 + bright) : v2;
	}
	for (UINT y = 0; y < data->height; y ++)
	{
		for (UINT x = 0; x < data->width; x ++)
		{
			*(data1->imageData+y*data1->widthStep+x*data1->nChannels+0)=values[BYTE(*(data->imageData+y*data->widthStep+x*data->nChannels+0))];
			*(data1->imageData+y*data1->widthStep+x*data1->nChannels+1)=values1[BYTE(*(data->imageData+y*data->widthStep+x*data->nChannels+1))];
			*(data1->imageData+y*data1->widthStep+x*data1->nChannels+2)=values2[BYTE(*(data->imageData+y*data->widthStep+x*data->nChannels+2))];
		}
	}
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值