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

隨筆 - 132  文章 - 51  trackbacks - 0
<2011年7月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

常用鏈接

留言簿(7)

隨筆分類

隨筆檔案

文章分類

文章檔案

cocos2d-x

OGRE

OPenGL

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

      在讀取BMP圖像的時候,主要處理了24位和32位圖像,在處理24位BMP圖像的時候,BMP圖像的數據已經被修改以便4字節自動對齊,
 對于24位BMP圖像而言,最需要注意的一點是,規定了每條行掃描線的數據大小必須是4的整數倍,如果不是4的整數倍,那么需要在行末端進行補0,否則數據讀取將出現偏移,直接導致的結果:會加載出一張傾斜的圖像。這個補0的操作叫做數據寬度對齊。
      很抽象?舉個例子,對于400×400的24位BMP圖像而言,行掃描是400px,是4的整數倍,那么無需進行補0操作。如果是30×38(本篇每張麻將牌素材的尺寸),那么行掃描顯然不是4的整數倍。對于24位BMP而言,一個像素由RGB三字節組成,那么一個行掃描的total字節是30 × 3 = 90字節,進行數據寬度對齊之后,行掃描的實際total字節是30 × 3 + 2 = 92字節。如此,才能被4整除。換句話說,每一行多出2個無用的字節。這在編程中,需要進行處理丟棄,否則圖像再次變形
    

            int channel= 0;
            
if ( texture->bpp == 24 ){
                channel 
= 3;
                texture
->imageType = GL_RGB;
            }
else{
                channel 
= 4;
                texture
->imageType = GL_RGBA;
            }

            
int biWidth = 0;                                                //每行補齊字節數,如果是24位的話需要補齊成4字節的倍數
            if ( (texture->width*channel) % 4 != 0 )
                biWidth 
= 4 - ( (texture->width*channel) % 4 );
            
我們求出每行自動填充的字節數,先讀取數據,然后跳過自動添加的字節數,再接著讀取下一行數據
            forint i = 0; i < height; i++ ){
                GLubyte
* pdest = texture->imageData + i * width * channel;
                fread( pdest, 
1, width * channel,file );

                
forint j = 0; j < width* channel; j+=channel ){
                    pdest[ j ] 
^= pdest[j+2^= pdest[j] ^= pdest[j+2];                //將BGR轉為RGB,BMP數據從左下角到右上角的方式存儲
                }

                
                fseek( file, biWidth, SEEK_CUR );                                    
//丟棄補足字節,開始填充下一行    
            }

讀取數據完畢,可以打印檢驗一下,用WINHEX打開看下,NoPropblem
因為我讀取的圖片不全是512*512,256*256,.......,所以我用OPENGL生成紋理的時候用了個gluBuild2DMipmaps
BOOL bRes = gluBuild2DMipmaps( GL_TEXTURE_2D,  texture->bpp/8, texture->width,texture->height, texture->imageType, GL_UNSIGNED_BYTE, texture->imageData );
畫出來后又成斜著的圖像了,數據也沒問題,只能說是生成MipMap 的時候讀取數據跨度有問題,但是我傳遞的是32位圖像的時候,生成的MIPMAP沒任何問題,即使圖像大小不能被2整除,即非512*512,256*256,.......
所以我做了個比較惡心的做法
    if ( bMipmap ){
        
if ( texture->imageType == GL_RGB ){
            GLubyte
* data = new GLubyte[texture->width*texture->height*4 ];
            
int counter = 0;
            
forint i = 0; i < texture->width*texture->height*3; i+=3 ){
                data[i
+counter] = texture->imageData[i];
                data[i
+1+counter] = texture->imageData[i+1];
                data[i
+2+counter] = texture->imageData[i+2];
                data[i
+3+counter] = 1.f;
                counter
++;
            }

            BOOL bRes 
= gluBuild2DMipmaps( GL_TEXTURE_2D,  4, texture->width,texture->height, GL_RGBA, GL_UNSIGNED_BYTE, data );
            delete[] data;
        }
else{
            BOOL bRes 
= gluBuild2DMipmaps( GL_TEXTURE_2D,  texture->bpp/8, texture->width,texture->height, texture->imageType, GL_UNSIGNED_BYTE, texture->imageData );
        }

        
        glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_LINEAR_MIPMAP_LINEAR );
        glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_LINEAR);    

將24位的圖像生成紋理的時候,我把數據轉換為32位的就沒問題了,一直沒更好的辦法,請大家不吝指導

題外文章:
BMP文件的結構,從大的分類來看,可以分成2部分:頭部信息區和圖像數據區。其中頭部信息區中,保存了圖像的各種屬性,如文件格式,圖片寬度,調色板等等。過了頭部信息區之后,就是用來呈現圖像的真正的數據區了。BMP文件屬于像素文件,也就是說,數據區中的數據,其實就是記錄了圖像中每一個像素的顏色,以32位BMP圖片來說,每一個像素由ARGB四個字節保存其顏色,其中A是透明度。那么,一副400×400的32位BMP圖像,就由160000個像素組成,則,數據區大小=160000×4byte = 640000byte = 640kb,所以也不難怪,BMP圖像文件給人的印象就是文件非常大。

       那么將BMP文件中的像素逐個讀入數據緩沖再顯示,是否就能正常顯示了呢?顯然不是的。前面說了,在文件開頭有一塊頭部信息區,如果把這些數據也一起讀進緩沖,那么圖像是無法最終顯示的。因此,通常載入BMP圖像的首要任務是要知道這塊頭部信息區的大小,也就是數據區的偏移量offset,再利用fseek尋址到這個位置,再進行逐個像素的解析。而頭部信息區的大小值貌似在頭部信息區的某個字節中有的,只需要讀取該字節,便可知道。對于24位和32位的BMP圖像而言,這個offset值為0x36,也就是頭部信息區的大小是54個字節。

       如果你要把加載圖像的函數做的通用一些的話,那么圖片的寬度和高度也是需要獲取的,對于24位BMP圖像,這兩個值可以分別在0x12和0x16進行尋址得到,注意fread需要讀雙字,即4字節,否則會出錯。

       對于24位BMP圖像而言,最需要注意的一點是,規定了每條行掃描線的數據大小必須是4的整數倍,如果不是4的整數倍,那么需要在行末端進行補0,否則數據讀取將出現偏移,直接導致的結果:會加載出一張傾斜的圖像。這個補0的操作叫做數據寬度對齊。

       很抽象?舉個例子,對于400×400的24位BMP圖像而言,行掃描是400px,是4的整數倍,那么無需進行補0操作。如果是30×38(本篇每張麻將牌素材的尺寸),那么行掃描顯然不是4的整數倍。對于24位BMP而言,一個像素由RGB三字節組成,那么一個行掃描的total字節是30 × 3 = 90字節,進行數據寬度對齊之后,行掃描的實際total字節是30 × 3 + 2 = 92字節。如此,才能被4整除。換句話說,每一行多出2個無用的字節。這在編程中,需要進行處理丟棄,否則圖像再次變形。

       最后一個需要注意的小細節是,BMP圖像的原點坐標,都是以左下角為基準,向右、向上增加。所以,在編程時,需要對y軸數據做一些小變換。否則將會得到一幅顛倒的圖像,此外,BMP的三原色順序是BGR,注意編程中的處理。


原文地址:BMP文件的結構,從大的分類來看,可以分成2部分:頭部信息區和圖像數據區。其中頭部信息區中,保存了圖像的各種屬性,如文件格式,圖片寬度,調色板等等。過了頭部信息區之后,就是用來呈現圖像的真正的數據區了。BMP文件屬于像素文件,也就是說,數據區中的數據,其實就是記錄了圖像中每一個像素的顏色,以32位BMP圖片來說,每一個像素由ARGB四個字節保存其顏色,其中A是透明度。那么,一副400×400的32位BMP圖像,就由160000個像素組成,則,數據區大小=160000×4byte = 640000byte = 640kb,所以也不難怪,BMP圖像文件給人的印象就是文件非常大。

       那么將BMP文件中的像素逐個讀入數據緩沖再顯示,是否就能正常顯示了呢?顯然不是的。前面說了,在文件開頭有一塊頭部信息區,如果把這些數據也一起讀進緩沖,那么圖像是無法最終顯示的。因此,通常載入BMP圖像的首要任務是要知道這塊頭部信息區的大小,也就是數據區的偏移量offset,再利用fseek尋址到這個位置,再進行逐個像素的解析。而頭部信息區的大小值貌似在頭部信息區的某個字節中有的,只需要讀取該字節,便可知道。對于24位和32位的BMP圖像而言,這個offset值為0x36,也就是頭部信息區的大小是54個字節。

       如果你要把加載圖像的函數做的通用一些的話,那么圖片的寬度和高度也是需要獲取的,對于24位BMP圖像,這兩個值可以分別在0x12和0x16進行尋址得到,注意fread需要讀雙字,即4字節,否則會出錯。

       對于24位BMP圖像而言,最需要注意的一點是,規定了每條行掃描線的數據大小必須是4的整數倍,如果不是4的整數倍,那么需要在行末端進行補0,否則數據讀取將出現偏移,直接導致的結果:會加載出一張傾斜的圖像。這個補0的操作叫做數據寬度對齊。

       很抽象?舉個例子,對于400×400的24位BMP圖像而言,行掃描是400px,是4的整數倍,那么無需進行補0操作。如果是30×38(本篇每張麻將牌素材的尺寸),那么行掃描顯然不是4的整數倍。對于24位BMP而言,一個像素由RGB三字節組成,那么一個行掃描的total字節是30 × 3 = 90字節,進行數據寬度對齊之后,行掃描的實際total字節是30 × 3 + 2 = 92字節。如此,才能被4整除。換句話說,每一行多出2個無用的字節。這在編程中,需要進行處理丟棄,否則圖像再次變形。

       最后一個需要注意的小細節是,BMP圖像的原點坐標,都是以左下角為基準,向右、向上增加。所以,在編程時,需要對y軸數據做一些小變換。否則將會得到一幅顛倒的圖像,此外,BMP的三原色順序是BGR,注意編程中的處理。


原文地址:http://naozifangde.blog.163.com/blog/static/1280042642009101614938531/
posted on 2010-05-29 11:22 風輕云淡 閱讀(2691) 評論(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| 亚洲成人在线| 亚洲永久精品国产| 在线亚洲精品福利网址导航| 欧美精品乱人伦久久久久久| 亚洲免费成人av电影| 一本色道久久综合狠狠躁篇的优点| 欧美精品啪啪| 欧美在线免费播放| 久久国产黑丝| 99re6热只有精品免费观看| 99视频国产精品免费观看| 国产麻豆成人精品| 久久九九国产精品| 久久躁狠狠躁夜夜爽| 99国产精品99久久久久久| 中文在线不卡| 亚洲国产91| 亚洲性视频网站| 一区二区亚洲精品| 日韩亚洲欧美成人| 国产亚洲一区二区三区在线观看 | 亚洲国产精品123| 亚洲啪啪91| 欧美午夜一区二区福利视频| 久久天堂成人| 欧美日韩一区二区在线| 久久夜色精品国产亚洲aⅴ| 欧美国产日韩免费| 久久久精彩视频| 欧美日韩国产欧| 久久综合久久美利坚合众国| 欧美日韩一区三区四区| 久久综合精品国产一区二区三区| 欧美日韩1区2区| 久久婷婷国产综合尤物精品| 欧美系列电影免费观看| 亚洲大片av| 韩国欧美国产1区| 在线一区二区三区做爰视频网站 | 国产精品大片wwwwww| 欧美风情在线观看| 国产亚洲综合性久久久影院| 一本色道久久99精品综合| 亚洲电影免费观看高清| 午夜精品福利在线| 亚洲在线中文字幕| 欧美日韩不卡| 亚洲欧洲中文日韩久久av乱码| 一区二区视频免费在线观看 | 亚洲国产美国国产综合一区二区| 国产亚洲综合在线| 亚洲专区在线| 亚洲欧美伊人| 国产精品草莓在线免费观看| 亚洲欧洲日本一区二区三区| 亚洲缚视频在线观看| 久久精品九九| 久久久久久999| 国产一区二区三区高清| 午夜精品一区二区三区在线播放| 亚洲在线网站| 国产精品视频第一区| 一区二区三区av| 亚洲一区二区日本| 欧美偷拍一区二区| 中文在线不卡| 欧美一区二区三区四区在线观看地址 | 中文欧美字幕免费| 欧美视频一区二区| 亚洲深爱激情| 欧美一区三区三区高中清蜜桃| 国产精品美女一区二区在线观看| 一区二区三区四区五区视频| 亚洲影视九九影院在线观看| 国产精品毛片在线看| 亚洲一区二区黄色| 久久久久久久久久久一区| 伊人精品久久久久7777| 免费的成人av| 亚洲伦伦在线| 欧美在线不卡视频| 玉米视频成人免费看| 欧美1区2区| 一本色道久久综合亚洲精品不 | 欧美一区1区三区3区公司| 国产精品亚洲综合久久| 欧美中在线观看| 亚洲第一区在线| 亚洲一区日韩| 激情偷拍久久| 欧美大片在线看| 亚洲一区二区三区午夜| 另类专区欧美制服同性| 日韩午夜免费视频| 国产精品一区二区你懂的| 久久久久欧美| 一本色道久久综合亚洲二区三区 | 亚洲伊人第一页| 国产一区在线免费观看| 欧美激情一区二区三区四区| 亚洲无线视频| 亚洲国产高清在线| 亚洲欧美另类在线| 91久久精品国产91久久| 国产精品午夜国产小视频| 免费观看一区| 香蕉久久精品日日躁夜夜躁| 亚洲国产美女久久久久| 欧美亚洲午夜视频在线观看| 最近看过的日韩成人| 国产欧美精品在线| 欧美日韩性生活视频| 巨乳诱惑日韩免费av| 亚洲影音一区| 日韩天堂av| 亚洲高清不卡在线| 久久这里有精品视频| 亚洲永久免费观看| 一本不卡影院| 亚洲国产精品第一区二区三区| 国产精品一国产精品k频道56| 欧美激情在线有限公司| 久久久www成人免费无遮挡大片| 正在播放欧美视频| 亚洲精品色图| 亚洲国产美女久久久久| 老鸭窝毛片一区二区三区| 校园春色国产精品| 亚洲一区一卡| 亚洲午夜成aⅴ人片| 日韩小视频在线观看专区| 亚洲电影免费在线| 一区在线视频| 国内不卡一区二区三区| 国产精品一国产精品k频道56| 欧美色精品天天在线观看视频 | 欧美日韩妖精视频| 欧美理论在线| 欧美日本一道本在线视频| 老司机精品久久| 鲁大师影院一区二区三区| 久久久久久综合| 久久在线播放| 欧美大香线蕉线伊人久久国产精品| 久久久噜噜噜久久中文字幕色伊伊| 欧美一区91| 久久久91精品国产| 久久视频在线视频| 欧美va天堂在线| 欧美精品www在线观看| 欧美精品日韩一本| 欧美日韩国产bt| 欧美四级电影网站| 国产精品视频内| 国内精品亚洲| 亚洲黄色免费| 亚洲一区二区视频| 亚洲欧美欧美一区二区三区| 欧美一区二区视频97| 久久激情视频| 欧美国产日韩二区| 亚洲精品乱码久久久久久蜜桃麻豆| 99在线精品观看| 先锋影音久久| 久久一区国产| 欧美视频一区在线观看| 国产日韩欧美夫妻视频在线观看| 国产性猛交xxxx免费看久久| 在线看国产日韩| 一本大道久久a久久精二百| 亚洲欧美日韩中文视频| 久久精品国产96久久久香蕉| 亚洲第一页自拍| 亚洲一区二区欧美| 免费观看久久久4p| 国产精品美女久久| 亚洲激情女人| 香蕉亚洲视频| 最新日韩av| 欧美伊人久久| 欧美精品在线一区| 好看的日韩视频| 中文成人激情娱乐网| 久久在线观看视频| 亚洲一区制服诱惑| 欧美精品不卡| 好吊色欧美一区二区三区四区| 一区二区三欧美| 美女福利精品视频| 亚洲欧美日韩电影| 欧美日韩色综合| …久久精品99久久香蕉国产| 性久久久久久久久久久久| 亚洲国产你懂的| 久久久久欧美精品| 国产区精品在线观看| 亚洲性视频h| 亚洲精品国产系列| 女同一区二区|