- 1、本文档共32页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
《数字图像处理入门》第5章(无水印)
第5章 直方图修正和彩色变换
这一章,我们主要和调色板打交道。先从最简单的反色讲起。
5.1 反色
反色(invert)就是形成底片效果。例如,图5.2为图5.1反色后的结果。
图5.1???? 原图
图5.2???? 图5.1反色后的结果 反色有时是很有用的,比如,图5.1中黑色区域占绝大多数,这样打印起来很费墨,我们可以先进行反色处理后再打印。
反色的实际含义是将R、G、B值反转。若颜色的量化级别是256,则新图的R、G、B值为255减去原图的R、G、B值。这里针对的是所有图,包括真彩图、带调色板的彩色图(又称为伪彩色图)、和灰度图。针对不同种类有不同的处理。
先看看真彩图。我们知道真彩图不带调色板,每个象素用3个字节,表示R、G、B三个分量。所以处理很简单,把反转后的R、G、B值写入新图即可。
再来看看带调色板的彩色图,我们知道位图中的数据只是对应调色板中的一个索引值,我们只需要将调色板中的颜色反转,形成新调色板,而位图数据不用动,就能够实现反转。
灰度图是一种特殊的伪彩色图,只不过调色板中的R、G、B值 都是一样的而已。所以反转的处理和上面讲的一样。
这里,我想澄清一个概念。过去我们讲二值图时,一直都说成黑白图。二值位图一定是黑白的吗?答案是不一定。我们安装Windows95时看到的那幅setup.bmp是由蓝色和黑色组成的,但它实际上是二值图。原来,它的调色板中的两种颜色是黑与蓝,而不是黑与白。所以说二值图也可以是彩色的,只不过一般情况下是黑白图而已。
下面的程序实现了反色,注意其中真彩图和调色板位图处理时的差别。
BOOL Invert(HWND hWnd)
{
?????? DWORD ??????????????????????????? OffBits,BufSize;
LPBITMAPINFOHEADER??? lpImgData;
?????? LPSTR??????????? ?????? lpPtr;
?????? HLOCAL???????????? ????? hTempImgData;
?????? LPBITMAPINFOHEADER??? lpTempImgData;
?????? LPSTR????????????? ???? lpTempPtr;
?????? HDC??????????????? ???? hDc;
?????? HFILE????????????? ????? hf;
?????? LONG?????????????? ???? x,y;
?? ? LOGPALETTE???????? ??? *pPal;
?? ? HPALETTE??????? ??????? hPrevPalette=NULL;
?????? HLOCAL???????????? ????? hPal;
?????? DWORD????????????? ??? i;
?????? unsigned char????? ??????? Red,Green,Blue;
?????? OffBits=bf.bfOffBits-sizeof(BITMAPFILEHEADER);
?????? BufSize=OffBits+bi.biHeight*LineBytes; //新开缓冲区的大小
?????? if((hTempImgData=LocalAlloc(LHND,BufSize))==NULL)
{
MessageBox(hWnd,Error alloc memory!,Error Message,MB_OK|
MB_ICONEXCLAMATION);
return FALSE;
}
lpImgData=(LPBITMAPINFOHEADER)GlobalLock(hImgData);???
?????? lpTempImgData=(LPBITMAPINFOHEADER)LocalLock(hTempImgData);
?????? //拷贝头信息
memcpy(lpTempImgData,lpImgData,BufSize);
?????? hDc=GetDC(hWnd);
?????? if(NumColors!=0){ //NumColors不为0说明是带调色板的
lpPtr=(char *)lpImgData+sizeof(BITMAPINFOHEADER);
//指向原图数据
lpTempPtr=(char *)lpTempImgData+sizeof(BITMAPINFOHEADER);
//指向新图数据
//为新调色板分配内存
hPal=LocalAlloc(LHND,sizeof(LOGPALETTE)+
NumColors*sizeof(PALETTEENTRY)
您可能关注的文档
最近下载
- 初中语文人教八年级上册(统编2023年更新)句子成分划分 教案.docx VIP
- Spark大数据技术实战教程全套教学课件.pptx
- 2024.3.25-深基坑土方开挖专家论证版施工方案,附计算书!115页Word可下载!.docx
- 不同意调岗解除劳动合同通知书.docx VIP
- 《为家乡写人物(风物)“志”》课件--统编版高中语文必修上册.pptx
- 整本书阅读优质课《格林童话》导读课课件.pptx VIP
- 【精品】金融工程第七版课后习题答案(中文.pdf
- 2024年秋人教版七年级英语上册全册课件:Unit 3.pptx VIP
- 圆管涵结构计算-新规范.xls VIP
- 典型作业风险辨识防范手册(变电分册).pdf
文档评论(0)