24位真彩色转为256灰度图

此代码实现了一个名为ConvertToGrayScale的函数,用于将24位真彩色位图转换为256级灰度图像。通过计算每个像素的红、绿、蓝分量的加权平均值来生成灰度值,并更新位图的INFOHEADER、调色板和像素数据。

/*************************************************************************
*
* 函数名称:
*  ConvertToGrayScale()
*
* 参数:
*  LPSTR lpDIB - ???ò??DIB????????

* 返回值:
*  BOOL - 成功返回TRUE,否则FALSE
*
* 说明:
*  将24位真彩色转为256灰度图像
************************************************************************/
BOOL WINAPI ConvertToGrayScale(LPSTR lpDIB) 
{

LPSTR lpDIBBits;                //指针DIB像素的指针
LPSTR lpNewDIBBits;            //指向DIB灰度图像(新图像)的开始处像素的指针
        LONG lLineBytes;
unsigned char * lpSrc;          //指向原图像像素点的指针
unsigned char * lpdest;        //指向目标图像的像素点的指针

        unsigned  char *ired,*igreen,*iblue;

        long lWidth;                    //图像的宽度和高度
long lHeight;

long i,j;          //循环变量

lWidth = ::DIBWidth(lpDIB);  //DIB宽度
lHeight = ::DIBHeight(lpDIB); //DIB 高度
RGBQUAD  *lpRGBquad;
lpRGBquad = (RGBQUAD *)&lpDIB[sizeof(BITMAPINFOHEADER)]; //INFOHEADER后为调色板
        if(::DIBNumColors(lpDIB) == 256)  //256色位图不作任何处理
{
return TRUE;
        }

if(::DIBNumColors(lpDIB) != 256)  //非256色位图将它灰度化
{
lLineBytes = WIDTHBYTES(lWidth*8*3);
lpdest=  new  BYTE[lHeight*lWidth];
lpDIBBits = (LPSTR)lpDIB + sizeof(BITMAPINFOHEADER);//指向DIB像素
for(i = 0;i < lHeight; i++)
for(j = 0;j < lWidth*3; j+=3)
{
ired  =  (unsigned  char*)lpDIBBits + lLineBytes * i + j + 2;
igreen =  (unsigned  char*)lpDIBBits + lLineBytes * i + j + 1;
iblue  =  (unsigned  char*)lpDIBBits + lLineBytes * i + j ;
lpdest[i*lWidth + j/3]  = (unsigned  char)((*ired)*0.299 + (*igreen)*0.588 + (*iblue)*0.114);
}

//需要做三件事:1修改INFOHEADER  2.增加调色板  3.修改原图像灰度值
LPBITMAPINFOHEADER  lpBI;
lpBI  =  (LPBITMAPINFOHEADER)lpDIB;
lpBI->biBitCount = 8;

//设置灰度调色板
for(i = 0;i < 256;i++)
{
lpRGBquad[i].rgbRed  = (unsigned char)i;
lpRGBquad[i].rgbGreen = (unsigned char)i;
lpRGBquad[i].rgbBlue  = (unsigned char)i;
lpRGBquad[i].rgbReserved = 0;
}

lpNewDIBBits= ::FindDIBBits(lpDIB);  //找到DIB(新的)像素的起始位置
lLineBytes=WIDTHBYTES(lWidth  *  8);
//修改灰度值
for(i = 0;i < lHeight; i++)
for(j = 0;j < lWidth; j++)
{
lpSrc = (unsigned  char*)lpNewDIBBits + lLineBytes * i+ j ;
*lpSrc=lpdest[i*lWidth+j];
}
delete  lpdest;
}
return true;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值