- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数字图像处理MFC显示BMP图片解析
【数字图像处理】一.MFC详解显示BMP格式图片 标签: 图像处理BMP格式详解BMP图片显示MFC2014-01-14 19:315250人阅读评论(8)收藏举报本文章已收录于:分类: MFC图像知识(11) 作者同类文章X数字图像处理(6) 作者同类文章X版权声明:本文为博主原创文章,转载请注明CSDN博客源地址!共同学习,一起进步~本文主要是讲述《数字图像处理》系列栏目中的第一篇文章.主要详细介绍了BMP图片格式,同时使用C++和MFC显示BMP格式,主要结合自己的《数字图像处理》课程和以前的项目叙述讲解.一.BMP图片格式定义BMP文件格式是Windows操作系统推荐和支持的标准图像文件格式,是一种将内存或显示器的图像数据不经过压缩而直接按位存盘的文件格式,故称位图(bitmap),其扩展名为BMP.BMP图像通常有4个部分组成:位图文件头、位图信息头、颜色表、位图数据.如下图所示:第一部分为位图文件头BITMAPFILEHEADER.位图文件头结构长度固定为14个字节,包含文件的类型、大小、位图文件保留字、位图数据距文件头的偏移量.其中WORD为无符号16位整数(2byte),DWORD为无符号32位整数(4byte).具体结构体定义如下://位图文件头typedefstructtagBITMAPFILEHEADER {WORD bfType; //位图文件的类型,必须为BM 0x424d 表示.bmp DWORD bfSize; //位图文件的大小,以字节为单位 包括该14字节 WORD bfReserved1; //位图文件保留字,必须为0 WORD bfReserved2; //位图文件保留字,必须为0 DWORD bfOffBits; //位图数据距文件头的偏移量,以字节为单位 即前三部分和} BITMAPFILEHEADER;第二部分为位图信息头BITMAPINFOHEADER,该结构也固定为40个字节,用于说明位图的尺寸、宽高、像素、分辨率、颜色表等信息.具体结构定义如下://位图信息头typedefstructtagBITMAPINFOHEADER {DWORD biSize; //本结构所占用字节数 40字节LONG biWidth; //位图的宽度,以像素为单位LONG biHeight; //位图的高度,以像素为单位WORD biPlanes; //目标设备的级别,必须为1WORD biBitCount; //每个像素所需的位数,必须是1(双色)、 //4(16色)、8(256色)或24(真彩色)之一DWORD biCompression; //位图压缩类型,必须是 0(BI_RGB不压缩)、 //1(BI_RLE8压缩类型)或2(BI_RLE压缩类型)之一DWORD biSizeImage; //位图的大小,以字节为单位LONG biXPelsPerMeter; //位图水平分辨率,每米像素数LONG biYPelsPerMeter; //位图垂直分辨率,每米像素数DWORD biClrUsed; //位图实际使用的颜色表中的颜色数DWORD biClrImportant; //位图显示过程中重要的颜色数 } BITMAPINFOHEADER;第三部分为颜色表或调色板(Palette).有些位图需要调色板,有些位图如真彩色图(biBitCount=24)不需要调色板,它们的BITMAPINFOHEADER后面直接是位图数据.调色板实际是一个数组,共有biClrUsed个元素(如果该值为零,则有2的biBitCount次幂个元素).数组中每个元素的类型是一个RGBQUAD结构,占4字节.定义如下://位图颜色表typedefstructtagRGBQUAD{ BYTE rgbBlue; //蓝色的亮度(值范围为0~255) BYTE rgbGreen; //绿色的亮度(值范围为0~255) BYTE rgbRed; //红色的亮度(值范围为0~255) BYTE
文档评论(0)