• <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>

            小星星的天空

            O(∩_∩)O 小月亮的fans ^_^

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              16 隨筆 :: 0 文章 :: 61 評論 :: 0 Trackbacks

                  

            首先,我們了解一下BMP的格式,BMP有四部分組成,用表格表示如下:

             

             

             

             

            1. 文件信息頭

            2. 位圖信息頭

            3. 調色板

            4. 位圖數據

             

            第一部分,文件信息頭的格式如下:

            typedef struct tagBITMAPFILEHEADER {

                    WORD    bfType;

                    DWORD   bfSize;

                    WORD    bfReserved1;

                    WORD    bfReserved2;

                    DWORD   bfOffBits;

            } BITMAPFILEHEADER, FAR *LPBITMAPFILEHEADER, *PBITMAPFILEHEADER;

            共有14個字節,其中bfType為文件類型,BMP的類型為0×4d42,也就是字母mb;bfSize是文件大小,為1,23,4部分大小的總和;bfReserved1bfReserved212,3部分大小的總和。

             

            第二部分,位圖信息頭,定義如下:

            typedef struct tagBITMAPINFOHEADER{

                    DWORD      biSize;

                    LONG       biWidth;

                    LONG       biHeight;

                    WORD       biPlanes;

                    WORD       biBitCount;

                    DWORD      biCompression;

                    DWORD      biSizeImage;

                    LONG       biXPelsPerMeter;

                    LONG       biYPelsPerMeter;

                    DWORD      biClrUsed;

                    DWORD      biClrImportant;

            } BITMAPINFOHEADER, FAR *LPBITMAPINFOHEADER, *PBITMAPINFOHEADER;

            總共40個字節,字段比較多,可以查看MSDN中的說明,對于RGB24的位圖,這個結構體一般定義如下:

            BITMAPINFOHEADER bih;

                   bih.biSize = sizeof(BITMAPINFOHEADER);

                   bih.biWidth = width;

                   bih.biHeight = height;

                   bih.biPlanes = 1;

                   bih.biBitCount = 24;

                   bih.biCompression = 0;

                   bih.biSizeImage = size;

                   bih.biXPelsPerMeter = 0;

                   bih.biYPelsPerMeter = 0;

                   bih.biClrUsed = 0;

                   bih.biClrImportant = 0;

             

            第三部分是調色板信息,定義如下:

            typedef struct tagRGBQUAD {

                    BYTE    rgbBlue;

                    BYTE    rgbGreen;

                    BYTE    rgbRed;

                    BYTE    rgbReserved;

            } RGBQUAD;

            這部分用來表示RGB各色的強度,一般情況我們不把這一部分寫到文件中。

             

            第四部分就是真正的數據,比如寬度和高度分別是320240,這部分數據的長度應該為320*240*3(每個像素點上有3個字節,分別用來表示b,g,r的顏色)。

             

            根據對BMP格式的說明,我們可以輕易的寫出一個生成BMP圖像的函數,如下所示:


            void saveBmp(const char* name ,int width,int height, unsigned char* data)
            {
             BMPHeader hdr;
             BMPInfoHeader infoHdr;
             int x, y;

             infoHdr.size = 40;
             infoHdr.width = width;
             infoHdr.height = height;
             infoHdr.planes = 1;
             infoHdr.bitsPerPixel = 24;
             infoHdr.compression = 0;
             infoHdr.imageSize =width* height * 3;
             infoHdr.xPelsPerMeter = 0;
             infoHdr.yPelsPerMeter = 0;
             infoHdr.clrUsed = 0;
             infoHdr.clrImportant = 0;

             hdr.type = 0x4D42;
             hdr.reserved1 = 0;
             hdr.reserved2 = 0;
             hdr.offset = 54;
             hdr.size =(DWORD)(sizeof(BMPHeader)+sizeof(BMPInfoHeader)+width* height * 3);


             FILE *fd;

             if( !(fd = fopen(name,"wb+")) )
             {
              printf("***BMP load error: file access denied***\n");
              exit(0);
             }
             fwrite(&hdr,1,sizeof(BMPHeader),fd);
             fwrite(&infoHdr,1,sizeof(BMPInfoHeader),fd);
             fwrite(data,1,width* height * 3,fd);
             fclose(fd);

            }


             從opengl中讀取場景也很簡單,就是個函數就搞定,廢話少說,直接上代碼:

            void
            saveSceneImage()
            {
             GLint pView[4];
             glGetIntegerv(GL_VIEWPORT,pView);

             GLsizei numComponet = 3;
             GLsizei bufferSize = pView[2]*pView[3]*sizeof(GLfloat)*numComponet;
             GLfloat* _data = new GLfloat[bufferSize];
             unsigned char*  data = new unsigned char[bufferSize];
             

             glReadPixels(pView[0],pView[1],pView[2],pView[3],GL_RGB,GL_FLOAT,_data);

             for (int i = 0 ; i <bufferSize ; i ++)
             {
              {
               data[i] = _data[i] * 256;
              }
             }
             saveBmp("1.bmp",pView[2],pView[3],data);
             delete[] data;
             delete[] _data;

            }

             

            有哪位朋友有更好的方法,歡迎討論

            posted on 2009-06-02 23:54 Little Star 閱讀(3921) 評論(1)  編輯 收藏 引用 所屬分類: Computer Graphics

            評論

            # re: opengl場景保存成BMP文件 2009-06-03 13:42 巫云
            有了這個格式表就可以自己生成bmp啦,吔  回復  更多評論
              

            亚洲一本综合久久| 久久一本综合| 国产69精品久久久久99| 99久久伊人精品综合观看| 久久精品国产WWW456C0M| 婷婷久久综合| 久久久国产精华液| 久久99精品国产麻豆宅宅| 免费精品久久天干天干| 1000部精品久久久久久久久| 欧美一级久久久久久久大片| 国产精品久久久久久久久鸭| 日日狠狠久久偷偷色综合0| 精品国产91久久久久久久| 伊人久久无码精品中文字幕| 丁香五月综合久久激情| 国产高清国内精品福利99久久| 无码AV波多野结衣久久| 精品人妻伦九区久久AAA片69| 欧美成a人片免费看久久| 国内精品久久久久久不卡影院| 99久久国产热无码精品免费| 亚洲AV无码成人网站久久精品大| 亚洲乱码中文字幕久久孕妇黑人| 久久影视综合亚洲| 欧美黑人又粗又大久久久| 久久久久亚洲AV无码麻豆| 伊人色综合久久天天| 久久精品夜色噜噜亚洲A∨| 一本久道久久综合狠狠爱| 久久99精品国产麻豆| 久久男人中文字幕资源站| 久久国产AVJUST麻豆| 国内精品久久国产大陆| 久久亚洲AV成人无码| 51久久夜色精品国产| 午夜人妻久久久久久久久| 亚洲国产成人久久一区久久| 国产成人久久激情91| 色欲久久久天天天综合网精品| 四虎久久影院|