《数字图像处理入门》第5章(无水印).doc

  1. 1、本文档共32页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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)

文档评论(0)

xcs88858 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档