核心代码:
//将256色位图改为灰度位图
LPRGBQUAD lpquad = (LPRGBQUAD)(pDIB+sizeof(BITMAPINFOHEADER));
int Intensity = 0;
for(int k = 0; k < 256; k++)
{
Intensity = (int)(lpquad[k].rgbRed + lpquad[k].rgbGreen + lpquad[k].rgbBlue) / 3.0;
lpquad[k].rgbRed = Intensity;
lpquad[k].rgbGreen = Intensity;
lpquad[k].rgbBlue = Intensity;
}
主要原理:I = (R + G + B) / 3
在HSI颜色模型中,I分量表示密度(intensity,对应成象亮度和图像灰度),与图象的彩色信息无关[1]。
[1] 章毓晋. 1999. 图象工程上册——图象处理和分析. 清华大学出版社, 19