www.pudn.com > isee_code01231.zip > AdjustContrast.cpp


/******************************************************************** 
 
	AdjustContrast.cpp - ISee图像浏览器—图像处理模块图像亮度,对比 
	度调节实现代码文件 
 
    版权所有(C) VCHelp-coPathway-ISee workgroup 2000 all member's 
 
    这一程序是自由软件,你可以遵照自由软件基金会出版的GNU 通用许可证 
	条款来修改和重新发布这一程序。或者用许可证的第二版,或者(根据你 
	的选择)用任何更新的版本。 
 
    发布这一程序的目的是希望它有用,但没有任何担保。甚至没有适合特定 
	目地的隐含的担保。更详细的情况请参阅GNU通用许可证。 
 
    你应该已经和程序一起收到一份GNU通用许可证(GPL)的副本。如果还没有, 
	写信给: 
    The Free Software Foundation, Inc.,  675  Mass Ave,  Cambridge, 
    MA02139,  USA 
 
	如果你在使用本软件时有什么问题或建议,用以下地址可以与我们取得联 
	系: 
		http://isee.126.com 
		http://www.vchelp.net 
	或: 
		iseesoft@china.com 
 
	作者:马翔 
   e-mail:hugesoft@yeah.net 
 
   功能实现:亮度,对比度调节 
 
	文件版本: 
		Build 000123 
		Date  2000-12-3 
 
********************************************************************/ 
#include "stdafx.h" 
#include "Contrast.h" 
#include "AdjustContrast.h" 
 
//	亮度,对比度调节处理函数 
BOOL _fnCOM_AdjustContrast(LPIMAGEPROCSTR lpInfo,int Brightness,int Contrast) 
{ 
	CopyMemory(lpInfo->_pdbdata ,lpInfo->_psbdata ,lpInfo->sImageInfo.width*lpInfo->sImageInfo.height*(lpInfo->sImageInfo.bitperpix/8)); 
 
	LPBYTE pRed=(LPBYTE)lpInfo->_pdbdata; 
	LPBYTE pGrn=pRed+1, pBlu=pRed+2; 
	WORD skip=lpInfo->sImageInfo.bitperpix/8; 
 
	UINT i,j; 
	for(i=0;i<(UINT)lpInfo->sImageInfo.width;i++) 
	{ 
		for(j=0;j<(UINT)lpInfo->sImageInfo.height;j++) 
		{ 
			_fnSPE_ChangeBrightness(Brightness,pRed,pGrn,pBlu); 
			_fnSPE_ChangeContrast(Contrast,pRed,pGrn,pBlu); 
      		pRed+=skip; 
      		pGrn+=skip; 
      		pBlu+=skip; 
		} 
	} 
 
	return PROCERR_SUCCESS; 
}