在vc 6中设置好opengl开发环境,视口的大小设置成与客户区大小_第1页
在vc 6中设置好opengl开发环境,视口的大小设置成与客户区大小_第2页
在vc 6中设置好opengl开发环境,视口的大小设置成与客户区大小_第3页
在vc 6中设置好opengl开发环境,视口的大小设置成与客户区大小_第4页
在vc 6中设置好opengl开发环境,视口的大小设置成与客户区大小_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、在vc 6中设置好opengl开发环境,视口的大小设置成与客户区大小一样,欲将客户区的图像保存为24位真彩色位图,源代码如下,可是存在这样的问题:程序运行,窗口刚创建时(此时不拉动边框改变客户区大小),可以正常保存。当最大化窗口或将最大化窗口复原,都可以正常保存。而当人为拉动边框改变客户区大小后,保存的图像出现问题,如下:调试信息如下:源代码如下:void CMySDOpenGLView:OnCaptureImage() /保存位图的消息函数/ TODO: Add your command handler code hereCString s("Windows Bitmap(*.bm

2、p)|*.bmp|");CFileDialog fd(FALSE,"bmp",0,OFN_OVERWRITEPROMPT|OFN_HIDEREADONLY|OFN_PATHMUSTEXIST,s);if(fd.DoModal()=IDOK)BeginWaitCursor();int viewport4;glGetIntegerv(GL_VIEWPORT,viewport); bool success = false; DWORD nFileType=0;if(strcmp(fd.GetFileExt(),"bmp")=0) nFileType=

3、1; if(nFileType=1)success=m_imagecapture.CaptureGLBufferToBMP(fd.GetPathName(),/调用保存位图类的 viewport0,viewport1,/函数保存位图 viewport2,viewport3);else / Invalid file extension specified. MessageBox("WTF? Unknown file extension specified for screen capture.n","Error",MB_OK); if (!success)

4、 char errorMsg64; if(nFileType = 0) sprintf(errorMsg, "Specified file extension is not recognized."); else sprintf(errorMsg, "Could not save image file."); MessageBox(errorMsg, "Error", MB_OK | MB_ICONERROR); EndWaitCursor();保存位图类的定义class CImageCapturepublic:CImageCaptu

5、re();virtual CImageCapture();bool CaptureGLBufferToBMP(CString filename, int x, int y, int width, int height);int WriteBitmapFile(CString filename, int width, int height, unsigned char *imageData);CImageCapture:CImageCapture()CImageCapture:CImageCapture()bool CImageCapture:CaptureGLBufferToBMP(CStri

6、ng filename, int x, int y, int width, int height)void* imageData = malloc(width*height*3);/ allocate memory for the imageDatamemset(imageData, 0, width*height*3); / clear imageData memory contents/ read the image data from the windowglReadPixels(0, 0, width, height, GL_RGB, GL_UNSIGNED_BYTE, (unsign

7、ed char*)imageData);/ write the image data to a fileWriteBitmapFile(filename, width, height, (unsigned char*)imageData);/ free the image data memoryfree(imageData);return true;/ WriteBitmapFile()/ desc: takes image data and saves it into a 24-bit RGB .BMP file/ with width X height dimensionsint CIma

8、geCapture:WriteBitmapFile(CString filename, int width, int height, unsigned char *imageData)FILE *filePtr;/ file pointerBITMAPFILEHEADER bitmapFileHeader;/ bitmap file headerBITMAPINFOHEADER bitmapInfoHeader;/ bitmap info headerunsigned int imageIdx;/ used for swapping RGB->BGRunsigned char tempR

9、GB;/ used for swapping/ open file for writing binary modefilePtr = fopen(filename, "wb");if (!filePtr)return 0;/ define the bitmap file headerbitmapFileHeader.bfSize = sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER)+(4*(width*24+31)/32) * height);bitmapFileHeader.bfType = 0x4D42;bitmapFi

10、leHeader.bfReserved1 = 0;bitmapFileHeader.bfReserved2 = 0;bitmapFileHeader.bfOffBits = sizeof(BITMAPFILEHEADER) + sizeof(BITMAPINFOHEADER);/ define the bitmap information headerbitmapInfoHeader.biSize = sizeof(BITMAPINFOHEADER);bitmapInfoHeader.biPlanes = 1;bitmapInfoHeader.biBitCount = 24;/ 24-bitb

11、itmapInfoHeader.biCompression = BI_RGB;/ no compressionbitmapInfoHeader.biSizeImage = 4*(width*24+31)/32) * height;/ width * height * (RGB bytes)bitmapInfoHeader.biXPelsPerMeter = 0;bitmapInfoHeader.biYPelsPerMeter = 0;bitmapInfoHeader.biClrUsed = 0;bitmapInfoHeader.biClrImportant = 0;bitmapInfoHead

12、er.biWidth = width;/ bitmap widthbitmapInfoHeader.biHeight = height;/ bitmap height/ switch the image data from RGB to BGRfor (imageIdx = 0; imageIdx < bitmapInfoHeader.biSizeImage; imageIdx+=3)tempRGB = imageDataimageIdx;imageDataimageIdx = imageDataimageIdx + 2;imageDataimageIdx + 2 = tempRGB;/

13、add empty Byte to every row, if this row cannot be divided exactly by 4. unsigned char *imageDataAfterAdding =(unsigned char *) malloc(4*(width*24+31)/32) * height);memset(imageDataAfterAdding, 0, 4*(width*24+31)/32) * height); for(int k=0; k<height; k+)for(int i=0; i<width*3; i+)imageDataAfterAddingk*width*3+i+k*(4*(width*24+31)/32)-width*3)= imageDatak*width*3+i;/ write the bitmap file headerfwrite(&bitmapFileHeader, 1, sizeof(BITMAPFILEHEADER), filePtr);/ write the bitmap info headerfwrite(&bitmapInfoHeader, 1, sizeof(B

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论