预作用喷水系统:位图格式资料

来源:百度文库 编辑:九乡新闻网 时间:2024/04/20 04:40:16

位图文件分为4个部分:
第一部分:
文件头bitmap-file header
第二部分:
信息头bitmap-infomation header
第三部分:
颜色标 color table
第四部分:
位图数据 bitmap data

第一部分结构:
0x0000H - 0x0001H 2 BYTES 文件标识 基本上就是'BM'
0x0002H - 0x0005H 4 BYTES 表示整个文件的大小 字节顺序是否固定 little_Endian or big_Endian?
0x0006H - 0x0009H 4 BYTES 保留 必须设置为0
0x000AH - 0x000DH 4 BYTES 位图数据的偏移量 从文件开始计算

第二部分结构:
0x000EH - 0x0011H 4 BYTES 位图信息头的长度大小 整个第二部分结构的大小,可能会增加字段,所以需要读取该值
0x0012H - 0x0015H 4 BYTES 位图宽度 单位像素
0x0016H - 0x0019H 4 BYTES 位图高度 单位像素
还有另一个用处,就是指明该图像是倒向的位图,还是正向的位图。
如果该值是一个正数,图像是倒向的,如果该值是一个负数,图像是正向的。
当高度值是一个负数时(正向图像)图像将不能被压缩,压缩方式不能是BI_RLE8或BI_RLE4。

0x001AH - 0x001BH 2 BYTES 位图的位面数 总是1
0x001CH - 0x001DH 2 BYTES 每个像素的位数 值为1 4 8 16 24 32
0x001EH - 0x0021H 4 BYTES 压缩方式 [0] 不压缩 BI_RGB
[1] RLE-8压缩,8位RLE压缩 BI_RLE8 每个象素8比特的RLE压缩编码,压缩格式由2字节组成
[2] RLE-4压缩,4位RLE压缩 BI_RLE4 每个象素4比特的RLE压缩编码,压缩格式由2字节组成
[3] Bitfields位域存放方式 BI_BITFILEDS 每个象素的比特由指定的掩码决定
0x0022H - 0x0024H 4 BYTES 位图数据大小 必须是4的整数倍,说明图象的大小,以字节为单位。当用BI_RGB格式时,可设置为0。
0x0026H - 0x0029H 4 BYTES 水平分辨率 对于设备无关图 ,设置成为0
0x002AH - 0x002DH 4 BYTES 垂直分辨率 对于设备无关图 ,设置成为0
0x002EH - 0x0031H 4 BYTES 使用的颜色数 说明位图实际使用的颜色表中的颜色索引数,
设为0的话,则说明使用所有调色板项,如果有调色板,则大小等于2^VALUE(0x001CH - 0x001DH)
16位及以上位图不使用颜色表。

0x0032H - 0x0035H 4 BYTES 重要的颜色数 指定重要的颜色数, 一般设置为0,表示所有的颜色一样重要
如果设置的不等于0或者颜色数,就只有这么多值

 

第三部分结构:
起始地址为:(如果该部分存在的话)
sizeof(第一部分) + sizeof(第二部分) 读取位图文件的时候第一部分应该不变,需要根据第二部分的0x000EH-0x0011H的值
大小来确定第二部分的数据大小。
整个区域的大小:
N * 4 BYTES 4个字节依次表示BGRA, 编程中是RGBA 这里是little_Endian

具体大小依赖很多数值


第四部分结构:
起始地址为:VALUE(0x000AH - 0x000DH)

整个区域的大小:
具体每个像素的表示方法,依赖0x001CH - 0x001DH每个像素的位数
0x001EH - 0x0021H压缩方式
0x002EH - 0x0031H颜色表大小

 


【0x001CH - 0x001DH】每个像素的位数
biBitCount=1 表示位图最多有两种颜色,缺省情况下是黑色和白色,你也可以自己定义这两种颜色。
图像信息头装调色板中将有两个调色板项,称为索引0和索引1。
图象数据阵列中的每一位表示一个象素。
如果一个位是0,显示时就使用索引0的RGB值,如果位是1,则使用索引1的RGB值。

biBitCount=4 表示位图最多有16种颜色。每个象素用4位表示,并用这4位作为彩色表的表项来查找该象素的颜色。
例如,如果位图中的第一个字节为0x1F,它表示有两个象素,第一象素的颜色就在彩色表的第2表项中查找,
而第二个象素的颜色就在彩色表的第16表项中查找。此时,调色板中缺省情况下会有16个RGB项。对应于索引0到索引15。

biBitCount=8 表示位图最多有256种颜色。每个象素用8位表示,并用这8位作为彩色表的表项来查找该象素的颜色。
例如,如果位图中的第一个字节为0x1F,这个象素的颜色就在彩色表的第32表项中查找。
此时,缺省情况下,调色板中会有256个RGB项,对应于索引0到索引255。

biBitCount=16 表示位图最多有2^16种颜色。每个色素用16位(2个字节)表示。这种格式叫作高彩色,或叫增强型16位色,或64K色。
它的情况比较复杂,当 biCompression成员的值是BI_RGB时,它没有调色板。
16位中,最低的5位表示蓝色分量,中间的5位表示绿色分量,高的5位表示红色分量,一共占用了15位,最高的一位保留,设为0。
这种格式也被称作555 16位位图。
如果biCompression成员的值是BI_BITFIELDS,那么情况就复杂了,首先是原来调色板的位置被三个DWORD变量占据,称为红、绿、蓝掩码。
分别用于描述红、绿、蓝分量在16位中所占的位置。
在Windows 95(或98)中,系统可接受两种格式的位域:555和565,
在555格式下,红、绿、蓝的掩码分别是:0x7C00、0x03E0、0x001F,
而在565格式下,它们则分别为:0xF800、0x07E0、0x001F。
你在读取一个像素之后,可以分别用掩码“与”上像素值,从而提取出想要的颜色分量(当然还要再经过适当的左右移操作)。
在NT系统中,则没有格式限制,只不过要求掩码之间不能有重叠。

biBitCount=24 表示位图最多有2^24种颜色。这种位图没有调色板,
在位数组中,每3个字节代表一个象素,分别对应于颜色R、G、B。

biBitCount=32 表示位图最多有2^32种颜色。这种位图的结构与16位位图结构非常类似,
当biCompression成员的值是BI_RGB时,它也没有调色板,32位中有24位用于存放RGB值,
顺序是:最高位—保留,红8位、绿8位、蓝8位。
这种格式也被成为888 32位图。
如果 biCompression成员的值是BI_BITFIELDS时,
原来调色板的位置将被三个DWORD变量占据,成为红、绿、蓝掩码,
分别用于描述红、绿、蓝分量在32位中所占的位置。
在Windows 95(or 98)中,系统只接受888格式,
也就是说三个掩码的值将只能是:0xFF0000、0xFF00、0xFF。
而在NT系统中,你只要注意使掩码之间不产生重叠就行。
(注:这种图像格式比较规整,因为它是DWORD对齐的,
所以在内存中进行图像处理时可进行汇编级的代码优化(简单))。


第二部分的【0x002EH - 0x0031H 4 BYTES 使用的颜色数】

指定实际使用的颜色数目。如果设置成0,位图使用的颜色数目就等于 biBitCount成员中的数目。
请注意,如果不是可用颜色的最大值或不是0,则在编程时应该注意调色板尺寸的计算,
比如在4位位图中,调色板的缺省尺寸应该是16*sizeof(RGBQUAD),如果不是,
那么调色板的尺寸就应该是 VALUE(0x002EH - 0x0031H)*sizeof(RGBQUAD)。

 

 

图象数据压缩

BI_RLE8:每个象素为8比特的RLE压缩编码,可使用编码方式和绝对方式中的任何一种进行压缩,这两种方式可在同一幅图中的任何地方使用。

编码方式:由2个字节组成,第一个字节指定使用相同颜色的象素数目,第二个字节指定使用的颜色索引。
此外,这个字节对中的第一个字节可设置为0,联合使用第二个字节的值表示:

第二个字节的值为0:行的结束。
第二个字节的值为1:图象结束。
第二个字节的值为2:其后的两个字节表示下一个象素从当前开始的水平和垂直位置的偏移量。

绝对方式:第一个字节设置为0,而第二个字节设置为0x03~0xFF之间的一个值。
在这种方式中,第二个字节表示跟在这个字节后面的字节数,每个字节包含单个象素的颜色索引。
压缩数据格式需要字边界(word boundary)对齐。下面的例子是用16进制表示的8-位压缩图象数据:

03 04 05 06 00 03 45 56 67 00 02 78 00 02 05 01 02 78 00 00 09 1E 00 01
这些压缩数据可解释为 :

压缩数据

扩展数据
03 04 04 04 04
05 06 06 06 06 06 06
00 03 45 56 67 00 45 56 67
02 78 78 78
00 02 05 01 从当前位置右移5个位置后向下移一行
02 78 78 78
00 00 行结束
09 1E 1E 1E 1E 1E 1E 1E 1E 1E 1E
00 01 RLE编码图象结束


BI_RLE4:每个象素为4比特的RLE压缩编码,同样也可使用编码方式和绝对方式中的任何一种进行压缩,
这两种方式也可在同一幅图中的任何地方使用。这两种方式是:

编码方式:由2个字节组成,第一个字节指定象素数目,第二个字节包含两种颜色索引,一个在高4位,另一个在低4位。
第一个象素使用高4位的颜色索引,第二个使用低4位的颜色索引,第3个使用高4位的颜色索引,依此类推。

绝对方式:这个字节对中的第一个字节设置为0,第二个字节包含有颜色索引数,其后续字节包含有颜色索引,
颜色索引存放在该字节的高、低4位中,一个颜色索引对应一个象素。
此外,BI_RLE4也同样联合使用第二个字节中的值表示:

第二个字节的值为0:行的结束。
第二个字节的值为1:图象结束。
第二个字节的值为2:其后的两个字节表示下一个象素从当前开始的水平和垂直位置的偏移量。

下面的例子是用16进制数表示的4-位压缩图象数据:

03 04 05 06 00 06 45 56 67 00 04 78 00 02 05 01 04 78 00 00 09 1E 00 01

这些压缩数据可解释为 :

压缩数据

扩展数据
03 04 0 4 0
05 06 0 6 0 6 0
00 06 45 56 67 00 4 5 5 6 6 7
04 78 7 8 7 8
00 02 05 01 从当前位置右移5个位置后向下移一行
04 78 7 8 7 8
00 00 行结束
09 1E 1 E 1 E 1 E 1 E 1
00 01 RLE图象结束

3. 彩色表

彩色表包含的元素与位图所具有的颜色数相同,象素的颜色用RGBQUAD结构来定义。对于24-位真彩色图象就不使用彩色表(同样也包括16位、和32位位图),

typedef struct tagRGBQUAD { /* rgbq */

BYTE rgbBlue;
BYTE rgbGreen;
BYTE rgbRed;
BYTE rgbReserved;

} RGBQUAD;

其中:

rgbBlue

指定蓝色强度

rgbGreen


指定绿色强度

rgbRed


指定红色强度

rgbReserved

保留,设置为0

4. 位图数据

紧跟在彩色表之后的是图象数据字节阵列。
图象的每一扫描行由表示图象象素的连续的字节组成,

每一行的字节数取决于图象的颜色数目和用象素表示的图象宽度。
扫描行是由底向上存储的,这就是说,阵列中的第一个字节表示位图左下角的象素,
而最后一个字节表示位图右上角的象素。(
只针对与倒向DIB,如果是正向 DIB,则扫描行是由顶向下存储的),倒向DIB的原点在图像的左下角,
而正向DIB的原点在图像的左上角。同时,每一扫描行的字节数必需是4的整倍数,也就是DWORD对齐的。
如果你想确保图像的扫描行DWORD对齐,可使用下面的代码:

(((width*biBitCount)+31)>>5)<<2