青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

唐吉訶德

  C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
  5 Posts :: 75 Stories :: 3 Comments :: 0 Trackbacks

常用鏈接

留言簿(2)

我參與的團(tuán)隊(duì)

搜索

  •  

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

1:BMP文件組成
BMP文件由文件頭、位圖信息頭、顏色信息和圖形數(shù)據(jù)四部分組成。
2:BMP文件頭(14字節(jié))
BMP文件頭數(shù)據(jù)結(jié)構(gòu)含有BMP文件的類型、文件大小和位圖起始位置等信息。
結(jié)構(gòu)定義如下:
typedef struct tagBITMAPFILEHEADER
{
WORDbf Type; // 位圖文件的類型,必須為BMP(0-1字節(jié))
DWORD bfSize; // 位圖文件的大小,以字節(jié)為單位(2-5字節(jié))
WORD bfReserved1; // 位圖文件保留字,必須為0(6-7字節(jié))
WORD bfReserved2; // 位圖文件保留字,必須為0(8-9字節(jié))
DWORD bfOffBits; // 位圖數(shù)據(jù)的起始位置,以相對(duì)于位圖(10-13字節(jié))
// 文件頭的偏移量表示,以字節(jié)為單位
} BITMAPFILEHEADER;
3:位圖信息頭(40字節(jié))
BMP位圖信息頭數(shù)據(jù)用于說明位圖的尺寸等信息。
typedef struct tagBITMAPINFOHEADER{
DWORD biSize; // 本結(jié)構(gòu)所占用字節(jié)數(shù)(14-17字節(jié))
LONG biWidth; // 位圖的寬度,以像素為單位(18-21字節(jié))
LONG biHeight; // 位圖的高度,以像素為單位(22-25字節(jié))
WORD biPlanes; // 目標(biāo)設(shè)備的級(jí)別,必須為1(26-27字節(jié))
WORD biBitCount;// 每個(gè)像素所需的位數(shù),必須是1(雙色),(28-29字節(jié))
// 4(16色),8(256色)或24(真彩色)之一
DWORD biCompression; // 位圖壓縮類型,必須是 0(不壓縮),(30-33字節(jié))
// 1(BI_RLE8壓縮類型)或2(BI_RLE4壓縮類型)之一
DWORD biSizeImage; // 位圖的大小,以字節(jié)為單位(34-37字節(jié))
LONG biXPelsPerMeter; // 位圖水平分辨率,每米像素?cái)?shù)(38-41字節(jié))
LONG biYPelsPerMeter; // 位圖垂直分辨率,每米像素?cái)?shù)(42-45字節(jié))
DWORD biClrUsed;// 位圖實(shí)際使用的顏色表中的顏色數(shù)(46-49字節(jié))
DWORD biClrImportant;// 位圖顯示過程中重要的顏色數(shù)(50-53字節(jié))
} BITMAPINFOHEADER;
4:顏色表
顏色表用于說明位圖中的顏色,它有若干個(gè)表項(xiàng),每一個(gè)表項(xiàng)是一個(gè)RGBQUAD類型的結(jié)構(gòu),定義一種顏色。RGBQUAD結(jié)構(gòu)的定義如下:
typedef struct tagRGBQUAD {
BYTE rgbBlue;// 藍(lán)色的亮度(值范圍為0-255)
BYTE rgbGreen; // 綠色的亮度(值范圍為0-255)
BYTE rgbRed; // 紅色的亮度(值范圍為0-255)
BYTE rgbReserved;// 保留,必須為0
} RGBQUAD;
顏色表中RGBQUAD結(jié)構(gòu)數(shù)據(jù)的個(gè)數(shù)有biBitCount來確定:
當(dāng)biBitCount=1,4,8時(shí),分別有2,16,256個(gè)表項(xiàng);
當(dāng)biBitCount=24時(shí),沒有顏色表項(xiàng)。
位圖信息頭和顏色表組成位圖信息,BITMAPINFO結(jié)構(gòu)定義如下:
typedef struct tagBITMAPINFO {
BITMAPINFOHEADER bmiHeader; // 位圖信息頭
RGBQUAD bmiColors[1]; // 顏色表
} BITMAPINFO;
5:位圖數(shù)據(jù)
位圖數(shù)據(jù)記錄了位圖的每一個(gè)像素值,記錄順序是在掃描行內(nèi)是從左到右,掃描行之間是從下到上。位圖的一個(gè)像素值所占的字節(jié)數(shù):
當(dāng)biBitCount=1時(shí),8個(gè)像素占1個(gè)字節(jié);
當(dāng)biBitCount=4時(shí),2個(gè)像素占1個(gè)字節(jié);
當(dāng)biBitCount=8時(shí),1個(gè)像素占1個(gè)字節(jié);
當(dāng)biBitCount=24時(shí),1個(gè)像素占3個(gè)字節(jié);
Windows規(guī)定一個(gè)掃描行所占的字節(jié)數(shù)必須是
4的倍數(shù)(即以long為單位),不足的以0填充,
biSizeImage = ((((bi.biWidth * bi.biBitCount) + 31) & ~31) / 8) * bi.biHeight;
具體數(shù)據(jù)舉例:
如某BMP文件開頭:
4D42 4690 0000 0000 0000 4600 0000 2800 0000 8000 0000 9000 0000 0100*1000 0300 0000 0090 0000 A00F 0000 A00F 0000 0000 0000 0000 0000*00F8 0000 E007 0000 1F00 0000 0000 0000*02F1 84F1 04F1 84F1 84F1 06F2 84F1 06F2 04F2 86F2 06F2 86F2 86F2 .... ....
BMP文件可分為四個(gè)部分:位圖文件頭、位圖信息頭、彩色板、圖像數(shù)據(jù)陣列,在上圖中已用*分隔。
一、圖像文件頭
1)1:(這里的數(shù)字代表的是"字",即兩個(gè)字節(jié),下同)圖像文件頭。0x4D42=’BM’,表示是Windows支持的BMP格式。
2)2-3:整個(gè)文件大小。4690 0000,為00009046h=36934。
3)4-5:保留,必須設(shè)置為0。
4)6-7:從文件開始到位圖數(shù)據(jù)之間的偏移量。4600 0000,為00000046h=70,上面的文件頭就是35字=70字節(jié)。
二、位圖信息頭
5)8-9:位圖圖信息頭長(zhǎng)度。
6)10-11:位圖寬度,以像素為單位。8000 0000,為00000080h=128。
7)12-13:位圖高度,以像素為單位。9000 0000,為00000090h=144。
8)14:位圖的位面數(shù),該值總是1。0100,為0001h=1。
9)15:每個(gè)像素的位數(shù)。有1(單色),4(16色),8(256色),16(64K色,高彩色),24(16M色,真彩色),32(4096M色,增強(qiáng)型真彩色)。1000為0010h=16。
10)16-17:壓縮說明:有0(不壓縮),1(RLE 8,8位RLE壓縮),2(RLE 4,4位RLE壓縮,3(Bitfields,位域存放)。RLE簡(jiǎn)單地說是采用像素?cái)?shù)+像素值的方式進(jìn)行壓縮。T408采用的是位域存放方式,用兩個(gè)字節(jié)表示一個(gè)像素,位域分配為r5b6g5。圖中0300 0000為00000003h=3。
11)18-19:用字節(jié)數(shù)表示的位圖數(shù)據(jù)的大小,該數(shù)必須是4的倍數(shù),數(shù)值上等于(≥位圖寬度的最小的4的倍數(shù))×位圖高度×每個(gè)像素位數(shù)。0090 0000為00009000h=80×90×2h=36864。
12)20-21:用象素/米表示的水平分辨率。A00F 0000為0000 0FA0h=4000。
13)22-23:用象素/米表示的垂直分辨率。A00F 0000為0000 0FA0h=4000。
14)24-25:位圖使用的顏色索引數(shù)。設(shè)為0的話,則說明使用所有調(diào)色板項(xiàng)。
15)26-27:對(duì)圖象顯示有重要影響的顏色索引的數(shù)目。如果是0,表示都重要。
三、彩色板
16)28-....(不確定):彩色板規(guī)范。對(duì)于調(diào)色板中的每個(gè)表項(xiàng),用下述方法來描述RGB的值:
1字節(jié)用于藍(lán)色分量
1字節(jié)用于綠色分量
1字節(jié)用于紅色分量
1字節(jié)用于填充符(設(shè)置為0)
對(duì)于24-位真彩色圖像就不使用彩色板,因?yàn)槲粓D中的RGB值就代表了每個(gè)象素的顏色。
如,彩色板為00F8 0000 E007 0000 1F00 0000 0000 0000,其中:
00FB 0000為FB00h=1111100000000000(二進(jìn)制),是藍(lán)色分量的掩碼。
E007 0000為 07E0h=0000011111100000(二進(jìn)制),是綠色分量的掩碼。
1F00 0000為001Fh=0000000000011111(二進(jìn)制),是紅色分量的掩碼。
0000 0000總設(shè)置為0。
將掩碼跟像素值進(jìn)行“與”運(yùn)算再進(jìn)行移位操作就可以得到各色分量值。看看掩碼,就可以明白事實(shí)上在每個(gè)像素值的兩個(gè)字節(jié)16位中,按從高到低取5、6、5位分別就是r、g、b分量值。取出分量值后把r、g、b值分別乘以8、4、8就可以補(bǔ)齊第個(gè)分量為一個(gè)字節(jié),再把這三個(gè)字節(jié)按rgb組合,放入存儲(chǔ)器(同樣要反序),就可以轉(zhuǎn)換為24位標(biāo)準(zhǔn)BMP格式了。
四、圖像數(shù)據(jù)陣列
17)27(無調(diào)色板)-...:每?jī)蓚€(gè)字節(jié)表示一個(gè)像素。陣列中的第一個(gè)字節(jié)表示位圖左下角的象素,而最后一個(gè)字節(jié)表示位圖右上角的象素。
五、存儲(chǔ)算法
BMP文件通常是不壓縮的,所以它們通常比同一幅圖像的壓縮圖像文件格式要大很多。例如,一個(gè)800×600的24位幾乎占據(jù)1.4MB空間。因此它們通常不適合在因特網(wǎng)或者其它低速或者有容量限制的媒介上進(jìn)行傳輸。根據(jù)顏色深度的不同,圖像上的一個(gè)像素可以用一個(gè)或者多個(gè)字節(jié)表示,它由n/8所確定(n是位深度,1字節(jié)包含8個(gè)數(shù)據(jù)位)。圖片瀏覽器等基于字節(jié)的ASCII值計(jì)算像素的顏色,然后從調(diào)色板中讀出相應(yīng)的值。更為詳細(xì)的信息請(qǐng)參閱下面關(guān)于位圖文件的部分。 n位2n種顏色的位圖近似字節(jié)數(shù)可以用下面的公式計(jì)算: BMP文件大小約等于 54+4*2的n次方+(w*h*n)/8
,其中高度和寬度都是像素?cái)?shù)。需要注意的是上面公式中的54是位圖文件的文件頭,是彩色調(diào)色板的大小。另外需要注意的是這是一個(gè)近似值,對(duì)于n位的位圖圖像來說,盡管可能有最多2n中顏色,一個(gè)特定的圖像可能并不會(huì)使用這些所有的顏色。由于彩色調(diào)色板僅僅定義了圖像所用的顏色,所以實(shí)際的彩色調(diào)色板將小于。如果想知道這些值是如何得到的,請(qǐng)參考下面文件格式的部分。由于存儲(chǔ)算法本身決定的因素,根據(jù)幾個(gè)圖像參數(shù)的不同計(jì)算出的大小與實(shí)際的文件大小將會(huì)有一些細(xì)小的差別。
posted on 2011-02-23 14:12 心羽 閱讀(690) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 圖片處理
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久久久久久波多野高潮日日| 欧美午夜视频| 亚洲黑丝在线| 久久综合图片| 免费看黄裸体一级大秀欧美| 欧美在线观看网址综合| 香蕉久久精品日日躁夜夜躁| 亚洲神马久久| 中文av一区特黄| 先锋影音国产精品| 欧美国产另类| 欧美日韩在线免费视频| 国产精品入口麻豆原神| 国产精品亚洲网站| 91久久精品美女高潮| 亚洲欧美国产77777| 欧美一区二区三区免费视| 欧美在线视频一区二区三区| 欧美黑人在线播放| 国产精品白丝av嫩草影院| 国产麻豆成人精品| 99国产麻豆精品| 久久精品一区四区| 久久精品最新地址| 亚洲黄色av一区| 欧美一区二区三区视频在线| 欧美日本韩国一区二区三区| 国产一区二区三区四区老人| 一本色道久久88亚洲综合88| 老鸭窝亚洲一区二区三区| 一本大道av伊人久久综合| 蜜桃av一区| 一区福利视频| 久久综合久久久久88| 欧美一区二区三区的| 国产精品二区在线| 在线中文字幕不卡| 中文欧美在线视频| 国产精品日韩一区二区三区| 亚洲欧美综合v| 亚洲一区二区三区四区五区午夜| 国产精品白丝jk黑袜喷水| 亚洲乱码久久| 一区二区三区日韩欧美| 国产亚洲欧美aaaa| 欧美成人精品一区二区三区| 欧美aⅴ一区二区三区视频| 亚洲剧情一区二区| 亚洲一区二区日本| 国产综合久久久久久鬼色| 国产婷婷色一区二区三区| 久久国产66| 欧美精品一区在线观看| 久久久中精品2020中文| 欧美久久一区| 欧美~级网站不卡| 国产精品a久久久久久| 久久一区二区视频| 国产精品日韩一区二区三区| 亚洲国产欧美一区二区三区丁香婷| 国产精品毛片一区二区三区| 欧美国产日韩视频| 国产亚洲欧美另类中文| 亚洲小视频在线| 中文在线不卡视频| 男女激情视频一区| 欧美a级片网站| 一区在线影院| 久久亚洲一区二区三区四区| 午夜日韩视频| 欧美性猛交一区二区三区精品| 亚洲国产精品久久久久婷婷老年| 国产欧美一区视频| 亚洲欧美成人一区二区三区| 亚洲男女自偷自拍图片另类| 国产精品高潮呻吟久久av无限| 99国产精品久久久久老师| 夜夜夜精品看看| 欧美性大战久久久久久久| 亚洲视频在线观看网站| 亚洲欧美日韩第一区| 国产欧美日韩高清| 欧美在线首页| 99riav久久精品riav| 亚洲综合国产激情另类一区| 国产综合久久久久久| 欧美精品一区视频| 欧美一区二区三区在线观看视频| 欧美性大战久久久久久久蜜臀| 亚洲综合色网站| 久久亚洲春色中文字幕| 99re66热这里只有精品3直播| 亚洲乱码国产乱码精品精天堂 | 午夜精品久久久久久久白皮肤| 亚洲一级在线观看| 亚洲国产精品久久| 国产区日韩欧美| 欧美国产1区2区| 欧美一区二区黄色| 99v久久综合狠狠综合久久| 欧美综合国产精品久久丁香| 亚洲免费观看| 亚洲理论在线观看| 一区精品在线| 国产欧美日韩另类视频免费观看| 欧美精品一区二区视频| 玖玖综合伊人| 男女精品视频| 在线一区视频| 欧美专区在线观看一区| 久久久久久综合| 久久综合九色欧美综合狠狠| 久久精品国产亚洲精品| 久久久www成人免费精品| 亚洲欧美日韩综合国产aⅴ| 亚洲一区二三| 久久se精品一区精品二区| 亚洲伊人观看| 欧美一区二区三区精品电影| 久久综合色播五月| 欧美日本亚洲韩国国产| 欧美激情综合在线| 国产精品久久久久毛片软件| 国产欧美精品日韩区二区麻豆天美| 国产精品欧美日韩一区二区| 亚洲看片网站| 欧美在线播放一区| 免费观看一区| 国产精品影片在线观看| 1000部国产精品成人观看| 亚洲欧洲精品一区二区三区波多野1战4 | 99视频日韩| 久久精品亚洲一区| 欧美日韩妖精视频| 亚洲国产高清一区| 性xx色xx综合久久久xx| 亚洲国产老妈| 久久日韩粉嫩一区二区三区| 午夜精品999| 亚洲国产一区在线观看| 久久久999精品免费| 国产女人aaa级久久久级| 亚洲精品美女| 欧美激情综合色| 久久久精品一区二区三区| 国产精品美女午夜av| 亚洲综合欧美| 亚洲视频免费| 国产精品尤物| 久久久综合激的五月天| 欧美在线视频一区二区| 国产一区二区中文| 久久精品99国产精品| 久久av免费一区| 亚洲人成高清| 亚洲性视频网站| 国产日韩欧美在线播放| 久久久久久久久久码影片| 久久不见久久见免费视频1| 国产伦精品一区二区三区| 久久久999精品| 欧美高清在线观看| 久热精品视频| 午夜精品理论片| 久久一区二区三区超碰国产精品| 在线国产精品一区| 日韩视频一区二区在线观看| 国产美女搞久久| 欧美.com| 国产一区二区激情| 亚洲看片一区| 亚洲精品你懂的| 欧美一区二区三区久久精品茉莉花| 亚洲国产第一页| 午夜精品999| 亚洲视频综合| 女人天堂亚洲aⅴ在线观看| 中文成人激情娱乐网| 欧美成人精精品一区二区频| 亚洲欧美制服另类日韩| 欧美色区777第一页| 欧美成人中文字幕| 国产午夜精品美女视频明星a级| 亚洲黄色一区二区三区| 亚洲第一色在线| 久久久久国产精品一区三寸| 久久激情五月婷婷| 国产精品免费电影| 亚洲伊人一本大道中文字幕| 99精品视频免费| 欧美色视频日本高清在线观看| av成人免费在线观看| 亚洲资源在线观看| 国产毛片精品视频| 欧美一区在线直播| 另类综合日韩欧美亚洲| 亚洲国产综合91精品麻豆| 美玉足脚交一区二区三区图片| 欧美激情一区在线| 亚洲欧美另类在线|