你所能用到的BMP格式介绍(二)

合集下载

BMP图片文件详解

BMP图片文件详解

有一个长宽各为 200 个象素,颜色数为 16 色的彩色图,每一个象素都用 R,G,B 三个分 量表示,因为每个分量有 256 个级别,要用 8 位( bit),即一个字节(byte)来表示,所以每个象素需要用 3 个字节。整个图象要用 200*200*3, 约 120k 字节,可不是一个小数目呀! 如果我们用下面的方法, 就能省的多。 因为是一个 16 色图,也就是说这幅图中最多只有 16 种颜色,我们可以用一个表:表中的每 一行记录一种颜色的 R,G,B 值。这样当我们 表示一个象素的颜色时,只需要指出该颜色是在第几行,即该颜色在表中的索引值。举个例 子,如果表的第 0 行为 255,0,0(红色) ,那么当某个象素为
色时,只需要标明 0 即可。 让我们再来计算一下:16 种状态可以用 4 位(bit)表示,所以 一个象素要用半个字节。整个图象要用 200*2 00*0.5,约 20k 字节,再加上表占用的字节为 3*16=48 字节.整个占用的字节数约为前面的 1/6,省很多吧。 这 张 RGB 的 表 , 即 是 我 们 常 说 的 调 色 板 (Palette) , 另 一 种 叫 法 是 颜 色 查 找 表 LUT(LookUpTable),似乎更确切一些。Windows 位图中便用
biXPelsPerMeter 指定目标设备的水平分辨率,单位是每米的象素个数,关于分辨率的概念,我们将在打印部 分详细介绍。
biYPelsPerMeter 指定目标设备的垂直分辨率,单位同上。
biClrUsed 指定本图象实际用到的颜色数,如果该值为零,则用到的颜色数为 2 的 biBitCount 次方。
biSizeImage 指定实际的位图数据占用的字节数,其实也可以从以下的公式中计算出来:

BMP24位位图格式总结

BMP24位位图格式总结

图像BMP24位位图格式总结1、创建图片创建一张只有六个像素的图片(两行三列),每个像素的颜色RGB组合值如图1(示意图)所示:图12、windows系统下存储格式(使用WinHex打开)3、文件结构3.1 文件头(bmp file header),提供文件的格式、大小等信息,共14个字节,如图2所示。

图23.1.1 0-1字节(2个字节)0x42 0x4d = "BM",表示这是Windows支持的位图格式,如图3所示。

图33.1.2 2-5字节(4个字节),表示该bmp文件的大小,存储形式为图4所示,因为小端对齐形式存储,实际存储的16进制数为0x4e,转换为十进制为78,与我们直接查看此图片的属性所看到的文件大小一致。

注:对于arm,intel这种x86架构的复杂指令CPU,整数在内存中是倒着存放的,低地址放低位,高地址放高位,小端对齐,但对于unix服务器的CPU,更多是采用大端对齐的情况图43.1.3 6-9字节这是两个保留段,为0如图5所示。

图53.1.4 A-D字节如图6所示,存储数据为0x36,十进制为54,表示的意义为从文件头到位图数据需偏移54字节。

图63.2 位图信息头(bitmap information):提供图像数据的尺寸、位平面数、压缩方式、颜色索引等信息,40个字节,如图7所示。

图73.2.1 0E-11字节,如图8所示,存储数据为0x28,十进制为40,表示意义为:位图信息头的大小为40个字节。

图83.2.2 12-15字节,如图9所示,存储数据为0x03,十进制为3,表示意义为:图像宽为3个像素,与我们创建的图像一致。

图93.2.3 16-19字节,如图10所示,存储数据为0x02,十进制为2,表示意义为:图像高为2个像素,与我们创建的图像一致。

图103.2.4 1A-1B字节,如图11所示,存储数据为0x01,该值总为1,表示意义为位元面数。

bmp格式详解

bmp格式详解

Bmp格式详解更新请参见博客地址/%C1%B5%D0%C4hjb/blog/item/e3f29bd1ee9d651ca08bb742.html用UltraEdit打开一个24bit的bmp(对于一些头信息计算上需要注意的是,x86体系结构下是小端模式,即数据低位在低地址),其中的二进制数据由文件头、位图信息头、颜色信息(或称为色表、调色板等)和图形数据四部分组成。

前三个部分后续转载文中会有详细叙述,对于图形数据,有以下几个要点需要了解:(1)Windows规定图像文件中一个扫描行所占的字节数必须是4的倍数(即以字为单位),不足的以0填充。

比如7*7像素的图像,每一行原始是7*3=21字节数据,由于非4字节对齐故会补三字节的0x00数据,使得每行为24字节数据。

(2)所有的bmp数据扫描行是上下颠倒的。

也就是说一幅图片先绘制底部的像素,再绘制顶部的像素,所以这些bmp数据所表示的像素点就是从图片的左下角开始,一直表示到图片的右上角。

(3)Bmp数据的存储格式为BGR顺次存储。

大家不能习惯性地认为是RGB顺次存储。

以下部分内容转载自/share/detail/6982516BMP文件中文称为位图文件,实际上取自Bit Map的缩写。

位图分为四种:线画稿:只有黑白两种颜色,所以像素用0,1表示。

灰度图象:在灰度图像中,像素灰度用8bit表示,像素灰度级用8bit表示,所以每个像素都是介于黑色和白色之间的256种的灰度的一种。

索引图像:在真彩色出现之前,由于技术上的原因,计算机在处理时并没有达到每像素24位的真彩色水平,为此人们创造了索引颜色。

索引颜色通常也被称为映射颜色,在这种模式下,颜色都是预先定义的,并且可供选用的一组颜色也有限,索引颜色的图像最多只能显示256种颜色。

一幅索引颜色图像在图像文件里定义,当打开该文件时,构成该图像具体颜色的索引值就被读入程序里,然后根据索引值找到最终的颜色。

真彩色图像:在真彩色图像中,每一个像素由红、绿和蓝三个字节组成,每个字节为8bit,表示0~255之间的不同的亮度值,这三个字节组合可以产生1670万种不同的颜色。

BMP格式结构详解

BMP格式结构详解

位图文件(B it m a p-File,BMP)格式是Windows采用的图像文件存储格式,在Windows环境下运行的所有图像处理软件都支持这种格式。

Windows 3.0以前的BMP位图文件格式与显示设备有关,因此把它称为设备相关位图(d evice-d ependent b itmap,DDB)文件格式。

Windows 3.0以后的BMP位图文件格式与显示设备无关,因此把这种BMP位图文件格式称为设备无关位图(d evice-i ndependent b itmap,DIB)格式,目的是为了让Windows能够在任何类型的显示设备上显示BMP位图文件。

BMP位图文件默认的文件扩展名是BMP或者bmp。

6.1.2 文件结构位图文件可看成由4个部分组成:位图文件头(bitmap-file header)、位图信息头(bitmap-information header)、彩色表(color table)和定义位图的字节阵列,它们的名称和符号如表6-01所示。

表6-01 BMP图像文件组成部分的名称和符号位图文件的组成结构名称符号位图文件头(bitmap-file header)BITMAPFILEHEADERbmfh位图信息头(bitmap-information header)BITMAPINFOHEADERbmih彩色表(color table)RGBQUAD aColors[]图像数据阵列字节BYTE aBitmapBits[]位图文件结构可综合在表6-02中。

表6-02 位图文件结构内容摘要偏移量域的名称大小内容图像文件头0000h标识符(Identifier)2 bytes两字节的内容用来识别位图的类型:‘BM’ : Windows 3.1x, 95, NT, linux‘BA’ :OS/2 Bitmap Array‘CI’ :OS/2 Color Icon‘CP’ :OS/2 Color Pointer‘IC’ : OS/2 Icon‘PT’ :OS/2 Pointer0002h File Size 1 dword用字节表示的整个文件的大小0006h Reserved 1 dword保留,设置为0000Ah Bitmap DataOffset1 dword从文件开始到位图数据开始之间的数据(bitmapdata)之间的偏移量000Eh BitmapHeader Size1 dword位图信息头(Bitmap Info Header)的长度,用来描述位图的颜色、压缩方法等。

BMP格式

BMP格式

BMP格式图片的资料.MP(Bitmap-File)图形文件是Windows采用的图形文件格式,在Windows环境下运行的所有图象处理软件都支持BMP图象文件格式。

Windows系统内部各图像绘制操作都是以BMP为基础的。

Windows 3.0以前的BMP图文件格式与显示设备有关,因此把这种BMP图象文件格式称为设备相关位图DDB(device-dependent bitmap)文件格式。

Windows 3.0以后的BMP图象文件与显示设备无关,因此把这种BMP图象文件格式称为设备无关位图DIB(device-independent bitmap)格式(注:Windows 3.0以后,在系统中仍然存在DDB位图,象BitBlt()这种函数就是基于DDB位图的,只不过如果你想将图像以BMP格式保存到磁盘文件中时,微软极力推荐你以DIB格式保存),目的是为了让Windows能够在任何类型的显示设备上显示所存储的图象。

BMP位图文件默认的文件扩展名是BMP或者bmp(有时它也会以.DIB或.RLE 作扩展名)。

6.1.2 文件结构位图文件可看成由4个部分组成:位图文件头(bitmap-file header)、位图信息头(bitmap-information header)、彩色表(color table)和定义位图的字节阵列,它具有如下所示的形式。

位图文件的组成结构名称符号位图文件头(bitmap-file header) BITMAPFILEHEADER bmfh位图信息头(bitmap-information header) BITMAPINFOHEADER bmih彩色表(color table) RGBQUAD aColors[]图象数据阵列字节 BYTE aBitmapBits[]位图文件结构可综合在表6-01中。

图象文件头0000h 文件标识 2 bytes 两字节的内容用来识别位图的类型:…BM‟: Windows 3.1x, 95, NT, ……BA‟:OS/2 Bitmap Array…CI‟:OS/2 Color Icon…CP‟:OS/2 Color Pointer…IC‟: OS/2 Icon…PT‟:OS/2 Pointer注:因为OS/2系统并没有被普及开,所以在编程时,你只需判断第一个标识“BM”就行。

bmp是什么格式

bmp是什么格式

bmp是什么格式BMP 是什么格式在我们日常使用电脑以及处理各种图像文件的过程中,经常会遇到各种各样的文件格式,比如 JPEG、PNG、GIF 等等。

而今天咱们要聊的是 BMP 格式。

BMP 是一种比较常见的图像文件格式,全称为 Bitmap,也就是位图。

简单来说,它就是一种用于存储图像的格式。

BMP 格式的特点之一就是它几乎不进行压缩,或者说压缩率极低。

这就意味着图像在存储时会保留大量的原始数据,从而能够提供非常高的图像质量。

因为没有经过过度的压缩处理,所以图像的细节、颜色等信息都能得到最大程度的保留。

这对于那些对图像质量要求极高的应用场景,比如专业的图像处理、打印等,是非常重要的。

从结构上来看,BMP 格式的文件通常由文件头、信息头、颜色表和图像数据这几个部分组成。

文件头包含了一些关于文件的基本信息,比如文件类型、文件大小、数据起始位置等等。

信息头则提供了关于图像的详细描述,比如图像的宽度、高度、颜色深度等。

颜色表在一些特定的 BMP 格式中存在,用于定义图像中所使用的颜色。

而图像数据部分就是实实在在存储图像每个像素的颜色值了。

BMP 格式的优点是显而易见的。

首先就是前面提到的图像质量高,因为几乎不压缩,所以不会有因为压缩而导致的图像失真或质量下降的问题。

其次,BMP 格式的结构相对简单,易于理解和处理,这对于一些需要直接对图像数据进行操作的程序来说是很方便的。

然而,BMP 格式也有一些明显的缺点。

由于不压缩或者压缩率低,导致文件体积通常较大。

想象一下,一张高分辨率的 BMP 图像可能会占用几十兆甚至上百兆的存储空间,这在网络传输或者存储空间有限的情况下就会带来很大的不便。

在实际应用中,BMP 格式虽然不常直接用于网络上的图像展示或者一般的图像存储,但在某些特定的领域还是有其用武之地的。

比如说,在一些操作系统的界面元素中,或者在一些早期的游戏和程序中,可能会使用 BMP 格式的图像。

另外,对于一些需要进行图像编辑和处理的专业软件,也会支持BMP 格式的导入和导出,方便用户在处理过程中保持图像的高质量。

BMP图像存储格式

BMP图像存储格式

维基百科的BMP定义BMP取自位图BitMaP的缩写,也称为DIB(与设备无关的位图),是微软视窗图形子系统(Graphics Device Interface)内部使用的一种位图图形格式,它是微软视窗平台上的一个简单的图形文件格式。

图像通常保存的颜色深度有2(1位)、16(4位)、256(8位)、65536(16位)和1670万(24位)种颜色(其中位是表示每点所用的数据位)。

8位图像可以是索引彩色图像外,也可以是灰阶图像。

表示透明的alpha通道也可以保存在一个类似于灰阶图像的独立文件中。

带有集成的alpha通道的32位版本已经随着Windows XP出现,它在视窗的登录和主题系统中都有使用。

文件大小计算BMP文件通常是不压缩的,所需存储空间比较大。

一个像素所占的字节数为n∕8字节,n是位深。

文件大小可以根据以下公式近似计算:BMP文件大小≈54+4*2n+(width*height*n)∕8;54是位图文件的文件头,4*2n是调色板的大小(对于没有调色板的位图文件,则不存在这一项),最后一项是像素数据。

由于存储算法决定的因素,实际文件大小和计算值可能有细微差别;因此使用的≈符号而不是等于号。

文件存储格式BMP图像自推出以后,几经演进,存储格式也有所变化。

下表详细描述了位图文件可能包含的数据。

结构体名称可选大小用途备注位图文件头否14字节存储位图文件通用信息仅在读取文件时有用DIB头否固定(存在7种不同版本)存储位图详细信息及像素格式紧接在位图文件头后附加位掩码是3或4 DWORD(12或16字节)定义像素格式仅在DIB头是BITMAPINFOHEADER时存在调色板见备注可变定义图像数据(像素数组)所用颜色色深≤ 8时不能省略填充区A是可变结构体对齐位图文件头中像素数组偏移量的产物像素数组否可变定义实际的像素数值像素数据在DIB头和附加位掩码中定义。

像素数组中每行均以4字节对齐填充区B 是可变结构体对齐DIB头中ICC色彩特性数据偏移量的产物ICC色彩特性数据是可变定义色彩特性可以包含外部文件路径,由该文件来定义色彩特性Remark:像素数组每行均以4字节对齐,这会影响我们怎么读取像素数据。

bmp的知识点

bmp的知识点

bmp的知识点BMP的知识点BMP(Bitmap)是一种图像文件格式,它以像素为基本单位来描述图像。

下面将介绍BMP文件的结构、特点以及常见的应用。

一、BMP文件结构BMP文件由文件头、位图信息头、调色板和图像数据组成。

1. 文件头(14字节):包含文件类型(2字节)、文件大小(4字节)、保留字段(4字节)和图像数据偏移量(4字节)等信息。

2. 位图信息头:包含位图信息头大小(4字节)、图像宽度(4字节)、图像高度(4字节)、颜色平面数(2字节)、每个像素所占位数(2字节)等信息。

3. 调色板(可选):用于存储图像的颜色信息,包括调色板项数、颜色索引和颜色值等。

4. 图像数据:按行存储的像素数据,每个像素用指定的位数来表示。

二、BMP文件特点1. BMP文件格式简单,易于解析和处理,适用于各种平台和应用程序。

2. BMP文件支持多种色彩深度,如1位、4位、8位、16位、24位和32位等,可以满足不同图像质量和存储空间需求。

3. BMP文件保留了图像的原始数据,不进行压缩,因此不会损失图像的质量,但文件大小相对较大。

4. BMP文件支持灰度图像和彩色图像,灰度图像每个像素只有一个亮度值,彩色图像每个像素有红、绿、蓝三个分量的值。

三、BMP文件的应用1. 图像处理:BMP文件是常用的图像处理格式,可以通过读取、修改和保存BMP文件来实现各种图像处理操作,如图像旋转、缩放、灰度化、边缘检测等。

2. 图像显示:BMP文件可以被各种图像显示软件和设备所支持,如画图工具、图片浏览器、数码相框、打印机等。

3. 图像转换:BMP文件可以通过转换工具将其转换为其他图像格式,如JPEG、PNG、GIF等,以满足不同应用场景的需求。

4. 图像分析:BMP文件中的像素数据可以被提取和分析,用于图像处理算法的开发、图像识别和图像分析等领域。

5. 图像存储:BMP文件可以作为图像的原始存储格式,用于长期保存和备份,以保证图像质量和数据的完整性。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

一、可能你忽视的基础在正式开始之前,我不得不从最基本的地方开始,因为这些地方大多数人会忽视的一干二净,如果不在开始进行说明,那么在后面一定会有很多困惑的地方。

最开始我们回到数字在计算机里的表示,回到最开始的问题上-2&-255是多少,那么我们首先得回顾一下-2在计算机里面的表示是什么样子的。

最开始,希望你还记得什么叫无符号整数和有符号整数,实际上,你得庆幸在一般的图像中没有浮点数,不然你需要复习或者重新学习的基础比这个还多。

先说有符号整数,从计算机组成原理中,有符号整数是以2的补码表示的,有很多办法计算这个2的补码,但是我最推荐的可能不是你最常见的那个方法,我推荐的是权值法,因为我觉得这个方法最符合逻辑也最符合2的补码的数学表达式。

什么是权值法呢?我们从最简单的开始,比如说二进制101,我们之所以能转换成十进制5是因为我们对每一位都赋予了一个权值,从最低位开始权值是2的0次方,权值依次向最高位提高一个幂值,所以我们能够计算为2^2*1+2^1*0+2^0*1,得出的值是5,而每一个位都有一个权值。

对于2的补码也可以按照这样的思路,但是第一位的权值略有不同,如果同样是101,如果表示的有符号的整数,我们赋予最高位的权值是2的-2次方,于是这个二进制补码转换成十进制就是2^-2*1+2^1*0+2^0*1,这样就是-3,你可以用传说中反码加一的方式验证。

为什么我说权值法最符合逻辑呢?我来举个例子,就说3这个数,无论是作为有符号整数还是无符号整数,其表示方法都是11,我同样可以表示成为0000000011,前面的1只要你喜欢,无论写多少都不会改变3这个值。

那么如果是-3呢?我们前面已经验证了-3的二进制补码表示为101,现在我们试试看将符号位扩展,也就是前面添加1,得到11101(为了我后面的演算方便,就不添加很多1 了),那么这个值是多少呢?按照权值法,最高位是2的-4次方(这个-4就是最高位的位数),后面权值不变,我们来计算这个值2^- 4*1+2^3*1+2^2*1+2^1*0+2^0*1,计算一下吧,还是等于-3,这就是符号扩展的意义。

有时候,看似简单的东西往往蕴含了很多的学问。

下面,就要联系c++里面的基本数据类型来说明上面这个问题了,在c++中表示无符号整数用unsigned关键字,根据图像的像素的取值范围是[0,255],那么最适合表示这个值的c++数据类型是什么?在回答这个问题之前,再来看一下更基本的一个问题,一个int值在我们的计算机中(32位)是由几个字节表示的?你可能很快的可以回答出是4个字节,那int的表示范围-2147483648 ~+2147483647,这个值对于图像的像素的表示范围太大了,[0,255]这个值需要8位就能表示出来,而在32位系统中char是唯一的1个字节的数据类型,但是还要注意的是char的范围是-128~+127,也就是有符号的,所以我们表示一个像素值应该用的是unsigned char。

也许你觉得太罗嗦了,那么这是指多媒体编程的冰山一角,下面我开始以实际的例子演示,每一步你都有可能出错。

二、我们从显示图像数据开始图像文件再怎么特殊,实际上它还是一个文件,所以要读取一个图像,自然要用文件流(如果忘了或者不知道的,那我这里只能介绍最基本的,只能靠你自己了)。

我们用文件流读入一个图片。

我很想解释为什么后面要用ios::binary,但是篇幅有限,就先这样认为它是必要的好了。

第一个演示的目的是为了能够制作一个类似UE效果的功能,程序运行结果如下图:看起来很无趣的黑色,实现这个功能的核心代码如下:[cpp] view plaincopy1. while(getline(fin,str))2. {3.int length=str.length();4.for(int i=0;i<length;i++, count++)5.{ if(count>0&&count%16==0)6. cout<<endl;7. if((int)((unsigned char)str[i])<0x10)8. {9. cout<<"0";10. }11. cout<<hex<<(int)((unsigned char)str[i])<<" ";12.}13.14.int num=10;15.total_str+=str+(unsigned char)num;16.}17. cout<<endl;代码虽然很少看上去比程序还混乱,我会一行一行解释的,首先第一行一行一行的读取文件中的数值,有没有思考过,文件流读bmp中怎么样算是一行?这问题下面再进行说明,但是可以明确告诉你的是,bmp中绝对不是按一个像素行为一行的。

接下来是取得读入字符串的长度,再接下来进入循环,循环的一开始的一个判断是为了做每行显示16个字符的,可以不用管它,然后下面的这些看似简单的包含了这个程序的核心部分。

让我们回到字节0-1:42 4d这上面来,按照程序我们读入这个第一个字节,str[0]储存的是’B’这个字符,也是42这个值(至于为什么是42,参见ASCII码表),按照我们第一部分说的,对于一字节的数我们应该用unsigned char来表示,所以我们进行了将str[i]的值转换成unsigned char,至于再转换成int是为了能够显示出十六进制的数字。

一个让人疑惑的地方出现了,循环内为什么要有最后两句,这要回到getline这个函数的原理上面了,前面说过getline是读取文件的一行,那么怎样判断文件的一行呢?我们来看一下getline的定义:After the function extracts an element that compares equal to delim,in which case the element is neither put back nor appended to the controlledsequence.msdn上写的是如果读到一个终止符,那么这个函数结束并且这个终止符不会加到这个字符串中,哪些字符是终止符呢?一般来说换行(0x0A)和回车(0x0D)都会被选为终止符,括号是他们的ASCII码。

如此便得到了一个图像文件的全部数据,在我们的程序中是存储在total_str之中的。

这里面包括了文件信息头,位图信息头,调色板(当然如果有的话),位图数据区,下面需要进行的就是依次取出每个信息,然后保存起来,按照前面的字节顺序,注意小端法或者大段法。

这里我想提到的一个问题就是,为什么在第一部分说了一下看似没有关系进制转换问题呢?如果你在存储各个位图部分的数据的时候,如果发现输出的数据不对,请你返回去仔细阅读一下第一部分以及回忆下基本数据的长度。

三、把数据存储组织起来下面说明怎么将上面取出的数据字符串按照bmp的四部分存储起来,存储的目的一个是为了标示,还有一个作用就是在读取的时候方面取出来。

首先,bmp最先的一个部分是文件信息头,我们定义一个结构如下:在开始下面介绍的内容之前,先要说明一下这些UINT16以及DWORD的数据类型:在32位计算机中short由两个字节表示的,int是四字节表示的,所以UINT16,WORD表示的是两个字节,DWORD,LONG都表示四字节数。

结构中各个字段的意思如注释所示,和前面说明的文件信息头的字段是一一对应的,下面来展示怎么样将读出来的字符串(total_str)赋值到某一个字段上。

根据我们读取的字符串,total_str[0]和total_str[1]分别是字符’b’和’m’,这是两个字节,那么我们需要将BITMAPFILEHEADER里面的bfType赋值为这两个值。

采用的赋值方法如下所示:<<是不常见的左移操作,这样的话方便的就能将两个一字节的数扩展为双字节的数,这样bh.bfType里面存的值就是0x424d,你可以输出来进行验证。

这个看起来不起眼的操作似乎很容易扩展成将四个四字节的数扩展为一个四字节的数,但是当你操作的时候就会发现并不是这样:如果你是这样操作的话,那么你可以做一下输出,你会发现结果出乎你意料的错误,为什么?在第一部分我提过的符号扩展,后面所有的都没有进行过类型转换,total_str[i]进行移位并且或操作默认的是带符号操作的,举个例子,如果total_str 5-2依次是00 00 00 f3,那么你这样做之后bh.bfSize就会变成ff ff ff f3,虽然bh.bfSize是无符号数,但是右边的是有符号数,所以你得到的一定是错误的结果。

那正确的做法应该是怎么样的?一种做法如下:至于为什么这样是对的,我在这里不进行说明了。

按照上面的方法,依次对文件信息头内的字段赋值,一样的对其他三个部分进行赋值,位图信息头结构:数据区结构:调色板结构:也许,你会问我,数据区和调色板为什么不用unsigned char,这里完全可以用unsigned char 我用UINT16 的目的是因为我懒得再重新定义一个数据类型了。

赋值的时候要注意的我在上面说过了,其他的要注意的我想说的就是不要忘记有数据对齐,如果你忘了,请你回去再看一下前面的说明,当你能够把bmp的每一部分保存下来之后,那么你就可以对bmp 做各种操作了,从另一种角度来说,你可以自己构造自己的bmp位图。

四、如果你会MFC如果你熟悉windows编程,那么你一定知道上面的结构在MFC以及windows编程里都是已经有了的结构,那你需要做的只是将图片加载到内存,在控件上显示。

如果你想学这一部分的MFC构成,那么搜索的关键词是”MFC GDI”,在进行这个部分的MFC编程时,但是MFC的位图编程这一块所提供的类CBitmap并不好用,包括CPalette,BITMAP结构等等都不是很好用,所以在实际开发中,有很多人都是选择自己包装一下再进行使用。

这个部分如果你都可以会MFC的话,那么你就不是初级入门选手了,主要的学习方法应该是查阅MSDN和资料,如果你不会MFC的话,这一点篇幅也是说明不了任何问题的。

相关文档
最新文档