MFC下基于OpenGL绘图程序的开发步骤和框架
- 格式:doc
- 大小:160.50 KB
- 文档页数:5
3D图形学基本概念PerspectivePerspective refers to the angles between the lines that lend the illusion of three dimensions.Colors and ShadingMoving beyond line drawing, we need to add color to create a solid object. Shading refers to the way the color is applied to the polygon. Shading can be of two types in OpenGL - Flat or Smooth.Lights and ShadowsPlain solid color doesn’t offer enough realism. By applying Lighting effects we can make objects appear as they would in reality depending on their material properties and the lighting parameters. Adding a shadow further increases realism.Texture MappingWith Texture Mapping we can have wood grains, cloth textures, brick like textures etc instead of plain materials. This technique of applying an image to the surface of a polygon is called Texture Mapping. The image we use is called the Texture and the individual elements of the texture are called Texels.FogFog is an atmospheric effect that adds haziness to objects in a scene depending on how far the objects are from the viewer.Blending and TransparencyBlending is the combination of colors of objects on the screen. This effect can be used for a variety of purposes. By varying the amount each object is blended with the scene we can make objects look transparent.Anti-AliasingAliasing is an effect that is visible on screen due to the fact that an image consists of discrete pixels. By carefully blending the lines with the background color we can eliminate jagged edges and give them a smooth appearance. This blending technique is called anti-aliasing.第一个OpenGL程序复制代码//Simple.cpp - First OpenGL Program#include <windows.h> //Required for every Windows Program#include <gl\glut.h> //Required for using the GLUT library//Perform OpenGL Initialization herevoid SetupRC(){//Set the background clearing color to blueglClearColor(0.0f,0.0f,1.0f,1.0f);//设置背景色为蓝色}//The drawing callback functionvoid RenderScene(){//Clear the color bufferglClear(GL_COLOR_BUFFER_BIT);//Flush the rendering pipelineglFlush();}void main(){//Choose the display mode settingsglutInitDisplayMode(GLUT_SINGLE | GLUT_RGB);//初始化显示模式(单缓冲,RGB)//Create the WindowglutCreateWindow("Simple");//创建窗口//Set the RenderScsne function as the display callbackglutDisplayFunc(RenderScene);//绘制回调函数,当窗口需要绘制时,GLUT会调用此函数//Initialize OpenGLSetupRC();//初始化OpenGL//Start the GLUT frameworkglutMainLoop();//开始消息循环}WGL – Windows的OpenGL扩展层The WGL extension consists of a set of functions (wglCreateContext, wglDeleteContext etc.) and structures (such as PIXELFORMATDESCRIPTOR, GLYPHMETRICSFLOAT) etc. Thus every OpenGL implementation has a platform-specific portion which has to be set up and used according to the particular platform.设备上下文The Windows Graphical Device Interface (GDI) is capable of drawing to screen, to memory, to printers or to any other device that provides a GDI interface layer and that can process GDI calls. GDI accomplishes this by a rendering handle to the currently selected device, which is called the device context, or DC.绘制上下文A rendering context is the OpenGL equivalent of the GDI DC. All OpenGL calls are rendered to the device through a RC. The rendering context maintains OpenGL state variables such as current background color, current color etc. just as the DC maintains GDI state variables such as current pen, current brush etc.像素格式Pixel formats are the translation layer between OpenGL calls and the rendering operation that Windows performs.举个例子,若像素格式只支持很少一部分颜色值,则OpenGL在用RGB值(128,120,135)绘制一个像素时,就可能使用转换后的值(128,128,128)来绘制.The pixel format selected essentially describes such things as how colors are displayed, depth of field resolution and what additional capabilities are supported by the rendering context created.第一个基于MFC的OpenGL应用程开发环境:VC6.01,首先下载需要的GLUT头文件,DLL和Lib文件,下载链接: glutdlls37beta.zip (149 kilobytes),解压缩后把gltu.h放到"VC98/Include/GL"下,把glut.lib和glut32.lib放到"VC9/Lib" 下,glut32.dll和glut.dll放到你创建的应用程序的运行目录下2,创建一个MFC SDI应用程序,在项目属性中加入所需要链接的库文件1,在stdafx.h中加入下列语句://OpenGL Headers#include <gl/gl.h>#include <gl/glu.h>#include <gl/glut.h>#include <gl/glaux.h>2,打开ClassWizard,选择CCY457OpenGLView类,为下述消息加入消息处理函数:WM_CREATE (for OnCreate), WM_DESTROY (for OnDestroy), WM_SIZE (for OnSize),WM_ERASEBACKGROUND (for OnEraseBkground).3,在窗口创建之前我们必须设置窗口风格包含WS_CLIPCHILDREN和WS_CLIPSIBLINGS,从而避免OpenGL绘制到其他窗口中去。
基于MFC的OpenGL绘图本文更新版本请点击[置顶]《基于MFC的OpenGL编程》系列文章一、简介GDI是通过设备句柄(Device Context以下简称"DC")来绘图,而OpenGL则需要绘制环境(Rendering Context,以下简称"RC")。
每一个GDI命令需要传给它一个DC,但与GDI不同,OpenGL使用当前绘制环境(RC)。
一旦在一个线程中指定了一个当前RC,在此线程中其后所有的OpenGL命令都使用相同的当前RC。
虽然在单一窗口中可以使用多个RC,但在单一线程中只有一个当前RC。
下面我将首先产生一个OpenGL RC并使之成为当前RC,这将分为三个步骤:设置窗口像素格式;产生RC;设置为当前RC。
二、MFC中的OpenGL基本框架1、首先创建工程用AppWizard产生一个MFC EXE项目,其他默认即可。
2、将此工程所需的OpenGL文件和库加入到工程中在工程菜单中,选择"Build"下的"Settings"项。
单击"Link"标签,选择"General"目录,在Object/Library Modules的编辑框中输入"opengl32.lib glu32.lib glut.lib glaux.lib"(注意,输入双引号中的内容,各个库用空格分开;否则会出现链接错误),选择"OK"结束。
然后打开文件"stdafx.h",加入下列头文件:#include <gl\gl.h>#include <gl\glu.h>3、改写OnPreCreate函数并给视图类添加成员函数和成员变量OpenGL需要窗口加上WS_CLIPCHILDREN(创建父窗口使用的Windows风格,用于重绘时裁剪子窗口所覆盖的区域)和WS_CLIPSIBLINGS(创建子窗口使用的Windows风格,用于重绘时剪裁其他子窗口所覆盖的区域)风格。
基于MFC的OpenGL简易绘图系统
尤王杰
【期刊名称】《计算机应用文摘》
【年(卷),期】2022(38)7
【摘要】文章研究了基于C++的基本类库MFC和OpenGL图形库建立面向对象的二维图形绘制应用程序,实现了简单多边形的绘制以及自由绘制等功能。
重点应用面向对象的编程思想和基于MFC的OpenGL图形库,希望为软件开发初学者以及绘图应用使用者提供一定的帮助。
【总页数】3页(P32-34)
【关键词】MFC;OPENGL;绘图系统;C++面向对象
【作者】尤王杰
【作者单位】苏州大学计算机科学与技术学院
【正文语种】中文
【中图分类】TP391
【相关文献】
1.基于MFC和OpenGL的相贯线焊接仿真系统设计
2.基于MFC和OpenGL的三维车载导航系统
3.基于OpenGL的三维绘图系统设计
4.基于MFC与OpenGL 的可视化机械仿真设计系统
5.基于OpenGL的三维绘图系统设计
因版权原因,仅展示原文概要,查看原文内容请购买。
手把手教你搭建用MFC进行OpenGL编程的框架手把手教你搭建用MFC进行OpenGL编程的框架第一步:创建项目文件File || New || Project || MFC AppWizard (exe) || 输入Project Name || 创建一个基于SDI,View类基于CView的工程文件;第二步:向项目文件中添加OpenGL的绘图函数Project || Settings || 在Object/library modules:中输入opengl32.lib,glu32.lib,glaux.lib,三者之间用空格隔开,逗号不用输入;第三步:添加一些代码1)在项目工作区的FileView中找到StdAfx.h,添加下面的代码:#include#include#include2)在项目工作区的ClassView中找到CView类,右击CView类,选择Add Member Vairable,添加一个成员变量HGLRC m_hRC;选择Add Member Founction,添加一个成员函数void DrawScene();3)在项目工作区的ClassView中找到CView类,右击CView类,选择Add Windows Message Handler,为CView类添加WM_CREATE,WM_DESTORY(方法:在左边的New windows message/events中选中并双击,然后点击OK)。
在项目工作区的ClassView中找到CView类,找到函数OnCreate(),在该函数中添加如下代码://定义像素存储格式PIXELFORMATDESCRIPTOR pfd={sizeof(PIXELFORMATDESCRIPTOR),1,PFD_DRAW_TO_WINDOW|PFD_SUPPORT_OPENGL,PFD_TYP E_RGBA,24,0,0,0,0,0,0,0,0,0,0,0,0,0,32,0,0,PFD_MAIN_PLANE,0,0,0,0,};CClientDC dc(this);int pixelFormat=ChoosePixelFormat(dc.m_hDC,&pfd);BOOL success=SetPixelFormat(dc.m_hDC,pixelFormat,&pfd); m_hRC=wglCreateContext(dc.m_hDC);同理找到函数OnDestory(),在该函数中添加下面的代码:wglDeleteContext(m_hRC);4)在类CView中的函数PreCreateWindows()中添加下面的代码: cs.style|=(WS_CLIPSIBLINGS|WS_CLIPCHILDREN);5)在类CView中的函数OnDraw()中添加下面的代码:wglMakeCurrent(pDC->m_hDC,m_hRC);DrawScene();//用户自定义的场景绘制函数wglMakeCurrent(pDC->m_hDC,NULL);这样,一个基于OpenGl标准的程序框架已经构造好了,用户只需在DrawScene()函数中添加程序代码即可。
基于MFC对话框的OpenGL三维图形开发分类:VC MFC C++2013-05-26 21:15 3184人阅读评论(3) 收藏举报Visual Studio 2010MFC图形对话框上文中,,是在对话框的基础上,利用Picture控件进行OpenGL绘制的,,那么现在是基于一个新的类进行的OpenGL绘制,也有一个Demo,,是用GDI和OpenGL分别绘制的,,声明,,这是别人的Demo,拿来试用一下。
示例我也是学习了这些资料之后才懂得怎么做的。
以三维动态球体模型来讲述基于MFC对话框的OpenGL编程1.基本思想在Windows98/NT平台下,GDI是原始窗口的图形接口。
而GDI实现这些是通过一个设备描述表DC来实现的。
现在通过OpenGL绘图需要创建绘图描述表RC。
但是RC并不能直接完成绘图,只能与特定的DC联系起来,从而完成具体的绘图工作。
最后要注意释放RC 和DC。
2.编程步骤第一步,设置开发环境现在以Windows2000为例,首先将glu.dll,glu32.dll,glut.dll,glut32.dll,opengl32.dll文件拷贝到操作系统WINNT/System32目录下,将gl.h,glaux.h,glu.h,glut.h拷贝到Microsoft Visual Studio/VC98/Include/GL目录中中,将glaux.lib,glu32.lib,glut32.lib,opengl32.lib拷贝到Microsoft Visual Studio/VC98/Lib目录中;然后在编译程序的时候选择Project|Setting菜单,在Link标签中的Object/library modules编辑框中输入“opengl32.lib,glut32.lib ,glu32.lib,glaux.lib”。
到这时候环境就建立好了,可以进行下面的具体编程工作。
第二步,具体编程本实例采用基于对话框的工程。
OPENGL工作流程
OpenGL的工作流程大致如下:
1.根据基本图形单元建立景物模型,并且对所建立的模型进行数
学描述。
在OpenGL中,点、线、多边形、图像和位图都被视为基本图
形单元。
2.把景物模型放在三维空间中的合适的位置,并设置视点以观察
所感兴趣的景观。
3.计算模型中所有物体的色彩,其中的色彩根据应用要求来确
定,同时确定光照条件、纹理粘贴方式等。
4.把景物模型的数学描述及其色彩信息转换至计算机屏幕上的象
素,这个过程也就是光栅化。
5.在这些步骤的执行过程中,OpenGL可能执行其他的一些操作,
例如自动消隐处理等。
另外,景物光栅化之后被送入帧缓冲器之前还可
以根据需要对象素数据进行操作。
以上信息仅供参考,具体流程可能因实际需求和应用场景而有所不同,建议咨询专业人士获取准确信息。
基于MFC的OpenGL简易绘图系统作者:尤王杰来源:《计算机应用文摘》2022年第07期关键词:MFC;OpenGL;绘图系统;C++面向对象中图法分类号:TP391 文献标识码:A1概述MFC 是微软公司开发的一个类库,以C++类的形式封装了Windows 的API,并且包含一个应用程序框架,以减少应用程序开发人员的工作量。
其中,MFC包含大量Windows 句柄封装类和很多Windows 的内建控件和组件的封装类[1] 。
OpenGL 是一个开放式图形库,是用于渲染2D 和3D 矢量图形的跨语言、跨平台的应用程序编程接口,是一个功能强大、支持底层绘制和造型能力的软件图形函数库。
它独立于硬件和窗口系统,为程序员进行图形学相关的程序编写提供了极大的帮助[2] 。
绘图软件一般指基于计算机绘制图形的软件,如Windows 自带的画图软件等。
它的开发语言和技术已经十分成熟。
本系统实现了基于基本类库MFC 和OpenGL 图形库面向对象的二维图形绘制应用程序,可以实现绘图的功能同时也可以让软件开发人员对软件开发过程有进一步了解。
2软件开发环境软件主要使用C++编程语言编写,使用了C++的基本库类MFC 和图形库OpenGL 以及C++常用库;开发软件的操作系统环境为Windows 10;软件的集成开发环境为Viusal Studio 2017;软件开发的硬件环境为16GB 内存,intel Core i5⁃9400F CPU(2.9GHz);软件支持跨平台使用,可以在不同操作系统中实现功能,同时可以进行本地保存[3] 。
3系统框架设计本系统采用了C++编程语言以及面向对象的编程风格,其基本思想是将现实世界的事物抽象成对象,现实世界中的关系抽象成类、继承,帮助人们实现对现实世界的抽象与数字建模。
通过面向对象的方法,更利于用人理解的方式对复杂系统进行分析、设计与编程。
同时,面向对象能有效提高编程的效率,通过封装技术,可以更高效地开发出一个全新的系统[4] 。
MFC与OpenGL编程入门OpenGL 作图非常方便,故日益流行,但对许多人来说,是在微机上进行的,首先碰到的问题是,如何适应微机环境。
这往往是最关键的一步,虽然也是最初级的。
下面介绍如何在VC++ 上进行OpenGL 编程。
其实相当简单明快,只因国内缺少这方面的资料与例子,致使许多小细节要一个一个地试,耗去大量时间。
希望各位有什么心得体会,也公布出来,从而节省每个人都要试试的时间。
言归正传,下面以画一条Bezier 曲线为例,详细介绍VC++ 上OpenGL编程的方法。
这里实际上也给出了个C++ 良好封装性编程的范例。
文中给出了详细注释,以便给初学者明确的指引。
一步一步地按所述去做,你将顺利地画出第一个OpenGL 平台上的图形来。
一、产生程序框架T est.dswNew Project | MFC Application Wizard (EXE) | "Test" | OK*注* : 加“”者指要手工敲入的字串二、导入Bezier 曲线类的文件。
用下面方法产生BezierCurve.hBezierCurve.cpp 两个文件:WorkSpace | ClassView | Test Classes| <右击弹出> New Class | Generic Class(不用MFC类) | "CBezierCurve" | OK三、编辑好Bezier 曲线类的定义与实现。
写好下面两个文件:BezierCurve.h BezierCurve.cpp四、设置编译环境:1. 在BezierCurve.h 和TestView.h 内各加上:#include #include #include2. 在集成环境中,Project | Settings | Link | Object/library module| "opengl32.lib glu32.lib glaux.lib" | OK五、设置OpenGL 工作环境:(下面各个操作,均针对TestView.cpp )1. 处理PreCreateWindow(): 设置OpenGL 绘图窗口的风格cs.style |= WS_CLIPSIBLINGS | WS_CLIPCHILDREN | CS_OWNDC;2. 处理OnCreate():创建OpenGL 的绘图设备。
OpenGL(Fancy_mage)(参考《实战OpenGL三维可视化系统开发与源码精解》,吕希奎,周小平著)一、OpenGL像素格式1、像素格式设置像素格式是OpenGL窗口的重要属性,它包括是否使用双缓冲,颜色位数和类型以及深度位数等。
像素格式可由Windows系统定义的所谓像素格式描述子结构来定义(PIXELFORMATDESCRIPTOR),该结构定义在windows.h中(与BMP头文件BITMAPINFOHEADER相似,在windows.h中,结构体不需要单独定义)。
在该结构中包含有26个属性信息,其形式为:typedef structtagPIXELFORMATDESCRIPTOR{WORD nSize; //该结构所占内存空间。
WORD nVersion;//版本号,当前为。
DWORD dwFlags;/* PFD_DRAW_TO_BITMAP 支持内存中绘制位图PFD_DRAW_TO_WINDOW 支持屏幕绘图PFD_DOUBLEBUFFER 支持双缓冲PFD_CENERIC_FORMAT 指定选择GDI支持的像素格式PFD_NEED_PALETTE 指定需要逻辑调色板PFD_NEED_SYSTEM_PALETTE 指定需要硬件调色板PFD_STEREO NT 不支持PFD_SUPPORT_OPENGL 支持OpenGLPFD_SUPPORT_GDI 支持GDI,此时不可使用PFD_DOUBLEBUFFER*/BYTE iPixelType;//像素颜色模式,可选项为PFD_TYPE_RGBA或PFD_TYPE_INDEX,分别对应于RGBA模式和颜色索引模式。
BYTE cColorBits;//指定颜色的位数。
BYTE cRedBits; //采用RGBA模式时,红色组分占用位数BYTE cRedShift; //采用RGBA模式时,红色组分占偏移量BYTE cGreenBits;//采用RGBA模式时,绿色组分占用位数BYTE cGreenShift;//采用RGBA模式时,绿色组分偏移量BYTE cBlueBits; //采用RGBA模式时,蓝色组分占用位数BYTE cBlueShift; //采用RGBA模式时,蓝色组分偏移量BYTE cAlphaBits;//采用RGBA模式时,Alpha组分占用位数。
如何在MFC中调用OpenGL第一步:在CView类cpp中添加头文件支持:#include <gl/GL.h>#include <gl/glut.h>第二步:更改窗口样式使其支持OpenGL.在CView类成员函数PreCreateWindow中添加代码cs.style|=WS_CLIPSIBLINGS|WS_CLIPCHILDREN;第三步:重写CView中的Create函数,在函数中添加代码CString ClassName=AfxRegisterWndClass(CS_OWNDC);第四步:重新设置像素格式,并将其设置为当前像素格式在CView类中添加public型成员函数BOOL SetupPixelFormat(HDC hDC);函数体如下://step 3 重新设置像素格式BOOL CXXXMFCGLView::SetupPixelFormat(HDC hDC){//重新设置画图窗口的像素格式static PIXELFORMATDESCRIPTOR pfd ={sizeof(PIXELFORMATDESCRIPTOR), // size of this pfd1, // version numberPFD_DRAW_TO_WINDOW | // support windowPFD_SUPPORT_OPENGL | // support OpenGLPFD_DOUBLEBUFFER, // double bufferedPFD_TYPE_RGBA, // RGBA type24, // 24-bit color depth0, 0, 0, 0, 0, 0, // color bits ignored0, // no alpha buffer0, // shift bit ignored0, // no accumulation buffer0, 0, 0, 0, // accum bits ignored32, // 32-bit z-buffer0, // no stencil buffer0, // no auxiliary bufferPFD_MAIN_PLANE, // main layer0, // reserved0, 0, 0 // layer masks ignored };int pixelformat;//分配一个像素格式号if ( (pixelformat = ChoosePixelFormat(hdc, &pfd)) == 0 ){MessageBox(L"ChoosePixelFormat failed");return FALSE;}//设置为当前的像素格式if (SetPixelFormat(hdc, pixelformat, &pfd) == FALSE){MessageBox(L"SetPixelFormat failed");return FALSE;}return TRUE;}第五步:在CView类中添加消息WM_CREATE,在OnCreate函数中添加代码HDC hDC;HGLRC hRC;hDC=::GetDC(GetSafeHwnd());SetupPixelFormat(hDC);hRC=wglCreateContext(hDC);wglMakeCurrent(hDC, hRC);第六步:初始化OpenGL重写CView类中的OnInitialUpdate,根据需要在OnInitialUpdate中添加代码这里OnInitialUpdate的作用与常用的OpenGL控制台程序中init()相同例如://初始化OpenGL//////////////////////////////////////////////////////glClearColor(1.0, 1.0, 1.0, 1.0);glEnable(GL_SMOOTH);glEnable(GL_DEPTH_TEST);//set material property1glNewList(0, GL_COMPILE);glEnable(GL_COLOR_MATERIAL);GLfloat mat_ambient[]={0.15, 0.07, 0.04, 1.0}; //原材料的环境颜色GLfloat mat_diffuse[]={0.15, 0.07, 0.04, 1.0}; //原材料的散射颜色GLfloat mat_specular[]={0.15, 0.07, 0.04, 1.0}; //原材料的反射颜色GLfloat mat_emission[]={0.15, 0.07, 0.04, 1.0}; //原材料的发散颜色glMaterialfv(GL_FRONT, GL_AMBIENT, mat_ambient);glMaterialfv(GL_FRONT, GL_DIFFUSE, mat_diffuse);glMaterialfv(GL_FRONT, GL_SPECULAR, mat_specular);glMaterialf(GL_FRONT, GL_SHININESS, 50.0);glMaterialfv(GL_FRONT, GL_EMISSION, mat_emission);glEndList();//set light0glNewList(1, GL_COMPILE);glEnable(GL_LIGHTING);GLfloat light0_position[]={1.0, 1.0, 1.0, 1.0};GLfloat light0_spot_direction[]={-1.0, -1.0, -1.0, 1.0};GLfloat light0_ambient[]={0.015, 0.007, 0.004, 1.0};GLfloat ligh0_diffuse[]={1.0, 1.0, 1.0, 1.0};GLfloat light0_specular[]={1.0, 1.0, 1.0, 1.0};glLightfv(GL_LIGHT0, GL_POSITION, light0_position);glLightf(GL_LIGHT0, GL_SPOT_CUTOFF, 45);glLightfv(GL_LIGHT0, GL_SPOT_DIRECTION, light0_spot_direction);glLightfv(GL_LIGHT0, GL_AMBIENT, light0_ambient);glLightfv(GL_LIGHT0, GL_DIFFUSE, ligh0_diffuse);glLightfv(GL_LIGHT0, GL_SPECULAR, light0_specular);glEnable(GL_LIGHT0);glEndList();//////////////////////////////////////////////////////第七步:在CView类中添加WM_SIZE的消息响应函数OnSize这里OnSize的作用与OpenGL控制台编程中reshape的作用相同根据需要在其中添加代码例如://////////////////////////////////////////////////////glCallList(1);glViewport(0, 0, cx, cy);glMatrixMode(GL_PROJECTION);glLoadIdentity();if (cx <= cy)gluOrtho2D (-1.0, 1.0,-1.0*(GLfloat)cy/(GLfloat)cx, 1.0*(GLfloat)cy/(GLfloat)cx);elsegluOrtho2D (-1.0*(GLfloat)cx/(GLfloat)cy,1.0*(GLfloat)cx/(GLfloat)cy, -1.0, 1.0);glMatrixMode(GL_MODELVIEW);glLoadIdentity();//////////////////////////////////////////////////////第八步:根据需要在CView类OnDraw函数中添加代码绘图在这里OnDraw的功能与OpenGL按制台编程中的display函数相同例如://////////////////////////////////////////////////////glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);glRotatef(0, 1.0f, 0.0f, 0.0f);glRotatef(0, 0.0f, 1.0f, 0.0f);glCallList(0);glutSolidTeapot(0.5);glPushMatrix();glTranslatef(-0.8, -0.3, -0.2);glutSolidTorus(0.1, 0.2, 50, 60);glPopMatrix();glPushMatrix();glTranslatef(0.9, 0, 0);glutSolidSphere(0.2, 80, 80);glPopMatrix();glFlush();SwapBuffers(wglGetCurrentDC());//////////////////////////////////////////////////////第九步:在CView类中添加WM_DESTROYR的消息响应函数OnDestroy 在其中添加如下代码:HGLRC hRC;hRC=wglGetCurrentContext();wglMakeCurrent(NULL, NULL);if (hRC){wglDeleteContext(hRC);}到这里,一个完整的MFC调用OpenGL的程序就大功告成了。
实验二结合MFC与OpenGL实现三维应用程序的显示1.实验目的●熟悉OpenGL的编程环境设置●熟悉MFC的基本编程框架●MFC与OpenGL混合编程的设置●OpenGL中基本图元的绘制2.实验内容●创建MFC+OpenGL的编程环境●利用三角形和四边形等基本图元绘制底面圆圆心在坐标原点,半径为r,高为h,方向沿z轴方向的圆柱3.实验指导3.1MFC应用程序框架在Visual C++ 2.0以后的版本中,Microsoft公司推出了MFC(Microsoft Foundation Class)类库。
MFC类库是用来编写Windows程序的C++类集。
使用MFC类库,可以简化应用程序的开发,从而缩短开发周期,而且代码的可靠性和可重用性也大大提高。
3.1.1MFC应用程序的文档/视图结构概述MFC提供了一个典型且实用的基于文档与视图的应用程序框架模板,按照其应用程序生成向导的导引步骤(MFC AppWizard)就可以创建一个基于文档/视图结构的MFC应用程序框架。
在此框架的基础上,设计和插入相关的对象,就可以实现交互式的用户界面、几何模型的管理和操作、图形图像的显示,以及其他各种专业功能。
在MFC的文档/视图结构的应用程序框架中,文档类和视图类是成对出现的。
文档用于管理应用程序的数据;而视图用于显示文档中的数据,并处理与用户的交互信息。
MFC通过文档类和视图类的划分,使数据的存储和显示既相对独立又相互关联。
在MFC所提供的框架结构中,文档与视图的关系可以由图0.1简要表示。
MFC中的视图和文档是由视图类(CView Class)和文档类(CDocument Class)分别表示的。
视图类可以调用其本身的成员函数GetDocument(),获得一个指向文档类的指针,从而能够访问文档类中的数据。
例如:在视图类中的OnDraw()函数中,视图类通过调用GetDocument()函数获得一个指向文档累的指针,然后通过这个指针获取文档类中的数据,并使用CDC类(负责处理应用程序显示设备接口的MFC类)中的函数将这些数据绘制在视图窗口中。
在stdafx.h中添加的头文件(参照项目OpenGL)//////////////////////////////////////////////////////////////////////////// // 包含有关OpenGL函数的头文件#include<gl/gl.h>#include<gl/glu.h>#include<gl/glaux.h>#include<gl/glut.h>////////////////////////////////////////////////////////////////////////////项目-属性-链接器-输入 Opengl32.lib;glu32.lib;glaux.lib添加的变量和函数:BOOL RenderScene();BOOL SetupPixelFormat(void);void SetLogicalPalette(void);BOOL InitializeOpenGL(CDC* pDC);HGLRC m_hRC; //OpenGL绘制描述表HPALETTE m_hPalette; //OpenGL调色板CDC* m_pDC; //OpenGL设备描述表添加的消息映射:ON_WM_CREATE()ON_WM_DESTROY()ON_WM_SIZE()ON_WM_TIMER()◎PreCreateWindow(CREATESTRUCT& cs)//设置窗口类型cs.style |=WS_CLIPCHILDREN | WS_CLIPSIBLINGS;WS_CLIPCHILDREN,使得父窗体在绘制时留出其上的子窗体的位置不去画它,而那片区域留WS_CLIPSIBLING,必须用于子窗体,使得该子窗体在收到WM_PAINT时同时令其共父的诸多子窗体也会被PAINT。
①OnCreate(LPCREATESTRUCT lpCreateStruct)//初始化OpenGL和设置定时器m_pDC = new CClientDC(this);//设备描述表赋值SetTimer(1, 500, NULL);InitializeOpenGL(m_pDC); //涵盖了glutInit ()和glutInitDisplayMode()的功能///////////////////////////////////////////////////////m_pDC = new CClientDC(this);//设备描述表赋值//SetTimer(1, 500, NULL);InitializeOpenGL(m_pDC); //涵盖了glutInit ()和glutInitDisplayMode()的功能/////////////////////////////////////////////////////////////////////////////②OnSize(UINT nType, int cx, int cy)// 相当于GLUT中的glutReshapeFunc()函数//设置投影变换矩阵,设置视窗glMatrixMode(GL_PROJECTION); //设置当前矩阵为投影矩阵glLoadIdentity();//用单位矩阵初始化当前矩阵glFrustum(-1.0,1.0,-1.0,1.0,3.0,7.0);glViewport(0,0,cx,cy);////////////////////////////////////////////glViewport(0, 0, cx, cy);glMatrixMode(GL_PROJECTION);glLoadIdentity();if ((GLfloat)cx <= (GLfloat)cy)glOrtho(-35, 35, -35 * (GLfloat)cy / (GLfloat)cx, 35 * (GLfloat)cy / (GLfloat)cx, -50, 50);elseglOrtho(-35 * (GLfloat)cx / (GLfloat)cy, 35 * (GLfloat)cx / (GLfloat)cy, -35, 35, -50, 50);////////////////////////////////////③OnDraw(CDC* pDC)glClearColor(0.8f,0.8f,0.0f,1.0f);glClearDepth(1.0f);glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);glMatrixMode(GL_MODELVIEW);//设置当前矩阵为模型矩阵glLoadIdentity();//用单位矩阵初始化当前矩阵RenderScene(); //渲染场景SwapBuffers(wglGetCurrentDC());//当窗口需要被重绘时调用绘制的图形相当于glutDisplayFunc(display);glClear()语句的作用是用当前缓冲区清除值,也就是glClearColor或者glClearD epth等函数所指定的值来清除指定的缓冲区。
摘要绘图软件在多种工作中都有着很多的运用,而当前很多办公中的中小型绘图软件的缺乏使得小型绘图软件的开发显得十分必要。
因此论文着眼于当前使用较多的C++语言作为软件的开发语言。
运用C++软件中的软件基础库类(MFC)进行实用的绘图软件的开发。
MFC作为C++封装技术的主要体现,不仅拥有C++语言在绘图方面上的各类优势,同时与Windows系统能够有较多的信息交互。
因此基于MFC的绘图软件可以较好的将被处理的图片从抽象变成直观。
同时使用MFC设计绘图软件的过程中运用图形设备接口(GDI)来与Windows进行互相的信息交互。
运用MFC技术编写出的绘图软件有着界面简洁、功能较多等诸多优点。
因此基于MFC的绘图软件设计为很多中小型企业或工作室的绘图提供一套较为完善的解决方案。
关键字:绘图软件,MFC1AbstractDrawing software in a variety of work has a lot of use, and many of the current office in the lack of small and medium drawing software is the use of graphics software development is very necessary. So the paper focuses on the current use of more C + + language as a software development tools. The use of C + + software in the software base library (MFC) for practical drawing software development. MFC as the main embodiment of C + + encapsulation technology, not only has the C ++ language in the drawing of various advantages, while the Windows system can have more information exchange. So MFC-based drawing software can be better to be processed from the abstract image into an intuitive. At the same time the use of MFC design graphics software in the process of using the graphical device interface (GDI) to communicate with each other Windows information. The use of MFC technology to write the graphics software has a simple interface, more features and many other advantages. So MFC-based drawing software design for many small and medium enterprises or studio drawings to provide a more complete solution.Keywords:Drawing software,MFC21、绪论1.1 课题来源及意义随着计算机绘图辅助设计系统(即CAD系统)的渐渐成熟,图形绘制软件已经成为学校,工厂及各种小型工作室等不可缺的一大工具,大型绘图软件AutoCad ,Solidworks,Pro/E,MatLab也被人们广泛使用,但由于占用资源过大,运行速度慢,界面操作较为复杂,不能很好满足大部分普通人需求。
一、简介GDI是通过设备句柄(Device Context以下简称"DC")来绘图,而OpenGL则需要绘制环境(Rendering Context,以下简称"RC")。
每一个GDI命令需要传给它一个DC,但与GDI 不同,OpenGL使用当前绘制环境(RC)。
一旦在一个线程中指定了一个当前RC,在此线程中其后所有的OpenGL命令都使用相同的当前RC。
虽然在单一窗口中可以使用多个RC,但在单一线程中只有一个当前RC。
下面我将首先产生一个OpenGL RC并使之成为当前RC,这将分为三个步骤:设置窗口像素格式;产生RC;设置为当前RC。
二、MFC中的OpenGL基本框架1、首先创建工程用AppWizard产生一个MFC EXE项目,其他默认即可。
2、将此工程所需的OpenGL文件和库加入到工程中在工程菜单中,选择"Build"下的"Settings"项。
单击"Link"标签,选择"General"目录,在Object/Library Modules的编辑框中输入"opengl32.lib glu32.lib glut.lib glaux.lib"(注意,输入双引号中的内容,各个库用空格分开;否则会出现链接错误),选择"OK"结束。
然后打开文件"stdafx.h",加入下列头文件:#include <gl\gl.h>#include <gl\glu.h>3、改写OnPreCreate函数并给视图类添加成员函数和成员变量OpenGL需要窗口加上WS_CLIPCHILDREN(创建父窗口使用的Windows风格,用于重绘时裁剪子窗口所覆盖的区域)和WS_CLIPSIBLINGS(创建子窗口使用的Windows风格,用于重绘时剪裁其他子窗口所覆盖的区域)风格。
用VisualC_中的MFC和OpenGL建立三维图形应用环境用Visual C++中的MFC和OpenGL建立三维图形应用环境哈尔滨工业大学现代生产技术中心(150001) 凌云储林波摘要:使用Visual C++的基本类库MFC建立面向对象的OpenGL三维图形应用程序的开发环境。
关键词:三维图形编程OpenGL三维图形库M FC类库O penGL是一个功能强大的三维图形库,它与操作系统无关,用O penGL编写的应用程序可以很容易地移植到支持O penG L的操作系统上,例如U N IX。
在Windo ws N T和W indo w s95中提供了对OpenGL的支持,在Window s N T和W indow s95上可以使用V i-sual C++V2.0以上版本来开发OpenGL的应用程序。
而V isual C++完善的基本类库M FC和应用向导A ppW izard使得开发一个复杂的应用程序变得轻松自如。
如果将二者结合起来,便可开发出相当有水平的Windo ws下三维图形应用程序。
1 OpenGL绘图环境初始化使用OpenGL函数库之前,需要以特定的过程进行初始化。
因为O penG L函数库和操作系统无关,它有自已的独特设计,与W indo ws的图形设备接口GDI 模型以及多数M FC应用程序的建立方法不太一致。
Windo ws为此提供了一些专门的A P I函数。
下面简要介绍一下Win32下使用O penG L函数库特殊的初始化过程。
首先,必须重新设置画图窗口的象素格式,使其符合O penGL对象素格式的需要。
为此需声明一个P IX-ELF O RM A T D ESCR IPT OR 结构的变量,并适当地设置某些结构成员的值,使其支持O penG L及其颜色模式。
变量的声明见后面SetupPix elFo rma t()函数的描述。
再以此变量为参数调用Choo seP ix elFo rmat()函数分配1个象素格式号,然后调用SetPix elF or mat()将其设置为当前象素格式。
搭建基于MFC的OpenGL应用程序框架1.新建“MFC AppWizard (exe)”工程,并选择单文档。
2.在Project->Settings->link的Object/library modules中添加以下信息opengl32.lib Glut32.lib Glaux.lib glu32.lib。
3.在视类头文件TestView.h中添加头文件(#include "gl\gl.h",#include "gl\glu.h"和#include "gl\glaux.h")。
4.因为OpenGL要求窗口有WS_CLIPCHILDREN和WS_CLIPSIBLINGS的风格。
代码如下:cs.style=WS_CHILD|WS_VISIBLE|WS_CLIPCHILDREN|WS_CLIPSIBLINGS; CTestView类中添加如下的保护型成员变量HGLRC rc;//渲染上下文CClientDC *m_pDC;//客户区设备上下文GLfloat wAngleX;//x方向转角GLfloat wAngleY; //y方向转角GLfloat wAngleZ;//z方向转角float a;//立方体边长为2aGLuint texture[6];//纹理数组BOOL Play;//动画控制逻辑变量5.添加CGLSample1View类的消息处理函数OnCreate函数PIXELFORMATDESCRIPTOR pfd={sizeof(PIXELFORMATDESCRIPTOR), //pfd大小1, //版本号PFD_DRAW_TO_WINDOW| // 支持WindowsPFD_SUPPORT_OPENGL // 支持OpenGL|PFD_DOUBLEBUFFER, //使用双缓冲PFD_TYPE_RGBA, //RGBA 类型24, // 24位颜色深度0,0,0,0,0,0, // 忽略的颜色位0, // 无alpha缓存0, // 忽略移位0, // 无累积缓冲0,0,0,0, // 忽略的累积位32, // 32位z缓存0, // 无模版缓存0, // 无辅助缓存PFD_MAIN_PLANE, // 主绘制层0, // 保留位0,0,0, // 忽略的层掩模};m_pDC=new CClientDC(this);int pixelformat;if ((pixelformat=ChoosePixelFormat(m_pDC->GetSafeHdc(),&pfd))==0)//选择像素格式,返回索引号{MessageBox("ChoosePixelFormat failed");return FALSE;}if (SetPixelFormat(m_pDC->GetSafeHdc(),pixelformat,&pfd)==FALSE)//设置象素格式{MessageBox("SetPixelFormat failed");return FALSE;}rc=wglCreateContext(m_pDC->GetSafeHdc());//创建渲染上下文wglMakeCurrent(m_pDC->GetSafeHdc(),rc);//DC和RC关联使RC成为现行rcreturn 0;6.添加CGLSample1View类的消息处理函数OnDestroy函数if(wglGetCurrentContext()!=NULL)//如果有现行的RCwglMakeCurrent(NULL,NULL);//断开RC与线程的联系2 / 3if(rc!=NULL){wglDeleteContext(rc);rc=NULL;}7.在视类中添加成员函数DrawScene(),绘制三维场景。