实验七 OpenGL显示加速技术教材.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验报告 课程名称:____计算机图形学___ 指导老师:______ _______成绩:_______ __ 实验名称: OpenGL显示加速技术 实验类型:_____基础实验_____同组学生姓名:______________ 一、实验目的和要求 通过实现实验内容,掌握OpenGL中顶点数组和显示列表的使用,并验证课程中关于OpenGL显示加速技术的内容。 二、实验内容和原理 使用Visual Studio C++编译已有项目工程。 要求修改代码达到以下要求: 补充完成函数drawVA(),实现使用顶点数组绘制场景: void drawVA() { … } 补充完成函数Gen3DObjectList (),实现显示列表的生成: GLint Gen3DObjectList() { … }; 分析对比使用三种方法得到的fps。 添加拾取功能,对于鼠标点中的Bunny或桌子,改变显示颜色。 三、主要仪器设备 Microsoft Visual Studio 2010 Windows 7 Ultimate Glut压缩包 Ex7 工程 四、操作方法和实验步骤 理解顶点数组: 在OpenGL中,所有的几何图元都是由顶点定义的,而每个顶点又有很多属性,如:坐标,颜色,法向量等。如果对每个顶点逐个的调用函数来描述,那么,开销是非常大的。而且不方便对复杂几何体顶点的管理。这里采用了顶点数组的方法,不但便于数据的管理,而且大大减少了函数的调用。 使用顶点数组,需要三个步骤:启用数组,指定数组数据、解引用并渲染。 启用顶点数组: void glEnableClientState(GLenum array); 指定数组的数据: void glVertexPointer(GLint size,GLenum type,GLsizei stride,const GLvoid* pointer); 解引用和渲染: void glArrayElement(GLint ith); 示例代码: void drawVA() { glEnableClientState(GL_VERTEX_ARRAY); glEnableClientState(GL_NORMAL_ARRAY); glNormalPointer(GL_FLOAT,0,normals); glVertexPointer(3, GL_FLOAT, 0, vertices); // draw a cube glDrawElements(GL_TRIANGLES,16301*3,GL_UNSIGNED_SHORT,face_indicies); // deactivate vertex arrays after drawing glDisableClientState(GL_VERTEX_ARRAY); glDisableClientState(GL_NORMAL_ARRAY); } Gen3DObjectList ()函数 GLint Gen3DObjectList() { GLint lid=glGenLists(1); //生成显示类表 glNewList(lid, GL_COMPILE); glBegin (GL_TRIANGLES); //每3分坐标相连接,生成一个三角形 for(int i=0;i(sizeof(face_indicies)/sizeof(face_indicies[0]));i++) { for(int j=0;j3;j++) { int idx=face_indicies[i][j]; glNormal3fv(normals[idx][0]); glVertex3fv(vertices[idx][0]); } } glEnd (); glEndList(); //结束生成显示列表 return lid; }; 添加拾取功能 鼠标操作: if(button == GLUT_LEFT_BUTTON state == GLUT_DOWN) { printf(x = %d, y = %d , x , y); startPicking(x, y); selectRender(); stopPicking(); } 实现pick功能时的拾取视窗大小定义: gluPickMatrix(cursorX , viewport[3] - cursorY , 1 , 1 , viewport); 返回法线绘制模型的个数: hits =

文档评论(0)

xiaofei2001128 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档