• <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啦,吔  回復  更多評論
              

            国内精品久久久久影院亚洲| 久久99九九国产免费看小说| 精品久久久久久中文字幕| 91久久婷婷国产综合精品青草| 99久久婷婷国产综合亚洲| 久久久久久免费一区二区三区| 精品久久人人做人人爽综合| 久久综合偷偷噜噜噜色| 国产V综合V亚洲欧美久久| 一本色道久久88综合日韩精品| 国产精品久久久久影视不卡| 久久久久久无码国产精品中文字幕| 久久强奷乱码老熟女网站| 99久久国产主播综合精品| 国产女人aaa级久久久级| 久久久久久精品免费看SSS| 免费国产99久久久香蕉| 亚洲日本va中文字幕久久| 国产69精品久久久久99尤物| 久久久久人妻一区二区三区| 色综合久久88色综合天天| 99久久香蕉国产线看观香| 国产91久久综合| 久久精品国产91久久综合麻豆自制| 偷偷做久久久久网站| 九九久久精品国产| 91久久福利国产成人精品| 性做久久久久久久| 99精品国产免费久久久久久下载| 国产成人久久777777| 久久精品嫩草影院| 国产成人精品白浆久久69| 欧美精品久久久久久久自慰| 成人久久免费网站| 大香伊人久久精品一区二区| 亚洲va久久久久| 精品国产乱码久久久久软件| 亚洲精品99久久久久中文字幕 | 精品无码久久久久久久久久| 伊人久久大香线焦综合四虎| 久久久久四虎国产精品|