這篇文章給大家分享的是有關(guān)Linux下如何讀取位圖的的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
為天橋等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及天橋網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都做網(wǎng)站、網(wǎng)站建設(shè)、天橋網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!詳解Linux下讀取位圖的注意事項
在Linux下讀取位圖遇到的問題,很好地體現(xiàn)了linux與Windows操作系統(tǒng)的不同。按理說位圖格式與操作系統(tǒng)無關(guān),讀取也應(yīng)該無關(guān),實際上在位圖讀到內(nèi)存中時已經(jīng)不同。下面主要介紹自己在Linux下操作位圖遇到的問題。
(一)、位圖結(jié)構(gòu)
位圖一開始是兩個結(jié)構(gòu)體,包括位圖的詳細信息,是讀取后面數(shù)據(jù)的關(guān)鍵。所以讀取位圖首先要正確讀取這兩個結(jié)構(gòu)體:BITMAPFILEHEADER和BITMAPINFOHEADER。其具體定義為:
typedef struct tagBITMAPFILEHEADER { // bmfh WORD bfType; DWORD bfSize; WORD bfReserved1; WORD bfReserved2; DWORD bfOffBits; }__attribute__ ((packed))BITMAPFILEHEADER; typedef struct tagBITMAPINFOHEADER { // bmih DWORD biSize; LONG biWidth; LONG biHeight; WORD biPlanes; WORD biBitCount; DWORD biCompression; DWORD biSizeImage; LONG biXPelsPerMeter; LONG biYPelsPerMeter; DWORD biClrUsed; DWORD biClrImportant; }__attribute__ ((packed))BITMAPINFOHEADER;
上面兩個結(jié)構(gòu)是Windows下可以正常使用的。但是Linux下沒有WORD、DWORD之類的變量類型,所以我們需要將這些變量映射到Linux下的常用變量類型:
typedef unsigned short WORD; typedef unsigned int DWORD; typedef int LONG;//use int not long here!!! typedef unsigned char BYTE;
上述映射要特別注意每個類型的字節(jié)數(shù)。不同的操作系統(tǒng)變量的長度不同,我們在定義時首先需要用sizeof獲得本機器的變量類型長度,然后再根據(jù)位圖每個屬性長度去選擇合適的變量類型。在此第三個變量LONG在windows下是四個字節(jié),但是在Linux下是八個字節(jié),所以我們需要用int來代替LONG。
(二)、對齊
在位圖結(jié)構(gòu)的定義中,我們在結(jié)構(gòu)體名稱前面添加了語句__attribute__ ((packed))。__attribute__ ((packed)) 的作用就是告訴編譯器取消結(jié)構(gòu)在編譯過程中的優(yōu)化對齊,按照實際占用字節(jié)數(shù)進行對齊,是GCC特有的語法。在windows下,讀取操作不會優(yōu)化,按照結(jié)構(gòu)體實際的大小去讀取,但是在Linux下,為了加快訪存速度,會啟用訪存的對齊操作。這時讀到內(nèi)存中的結(jié)構(gòu)體大小就大于最初的定義,此時如果按照之前的大小去訪問位圖屬性,將讀到錯誤的數(shù)值。為了使訪問方便,我們需要禁止對齊優(yōu)化。
(三)、位圖數(shù)據(jù)
對于24位真彩色位圖,位圖不包括調(diào)色板,位圖數(shù)據(jù)就是RGB顏色的值。所以很多人認為數(shù)據(jù)的大小就是3*height*width,讀取數(shù)據(jù)的時候直接利用這個大小,但這是錯誤的。24位真彩色位圖每一行還需要滿足一個條件:數(shù)據(jù)長度能被4整除,否則需要用0補齊到能被4整除。所以讀取的過程需要一行一行完成,而且在每一行的末尾,我們都需要跳過一定數(shù)量的0,這個計算公式如下:
skip=(4-(3*width)%4)%4;
C語言下,讀取過程如下:
for(int i=0;i(四)、RGB順序
如前所述,24位真彩色位圖不包括調(diào)色板,位圖數(shù)據(jù)就是RGB顏色的值,每個顏色占據(jù)一個字節(jié)。此時很多人認為顏色的順序是R、G、B,但這也是錯誤的,實際的順序應(yīng)該是B、G、R。這一點也需要特別注意。
感謝各位的閱讀!關(guān)于“Linux下如何讀取位圖的”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
分享名稱:Linux下如何讀取位圖的-創(chuàng)新互聯(lián)
本文來源:http://weahome.cn/article/pjeci.html