当前位置:首页 > > 充电吧
[导读]在上节课的内容上作些扩展,我们现在开始生成真正的3D对象,而不是象前两节课中那样3D世界中的2D对象。我们给三角形增加一个左侧面,一个右侧面,一个后侧面来生成一个金字塔(四棱锥)。给正方形增加左、右、

在上节课的内容上作些扩展,我们现在开始生成真正的3D对象,而不是象前两节课中那样3D世界中的2D对象。我们给三角形增加一个左侧面,一个右侧面,一个后侧面来生成一个金字塔(四棱锥)。给正方形增加左、右、上、下及背面生成一个立方体。 

我们混合金字塔上的颜色,创建一个平滑着色的对象。给立方体的每一面则来个不同的颜色。

只需要在上节课的基础上改动render函数

void Lesson4::render()
{
    glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);

    glViewport(0,0,(GLint)width(),(GLint)height()); // 重置当前视口
    glMatrixMode(GL_PROJECTION);                    // 选择投影矩阵
    glLoadIdentity();                               // 重置投影矩阵为单位矩阵
    // glu库函数Qt不支持,但是glu库函数是对gl库函数的封装,方便使用。因此我们可以自己
    // 写一个类似gluPerspective的函数myPerspective,用于设置透视。
    //gluPerspective(45.0f,(GLfloat)width/(GLfloat)height,0.1f,100.0f);
    myPerspective(45.0,(GLfloat)width()/(GLfloat)height(),0.1,100.0);

    glMatrixMode(GL_MODELVIEW);// 选择模型视图矩阵
    glLoadIdentity();          // 重置模型视图矩阵为单位矩阵

    glTranslatef(-1.5f,0.0f,-6.0f); // 左移1.5单位,并移入屏幕6.0
    glRotatef(rtri,0.0f,1.0f,0.0f);	// 绕Y轴旋转金字塔

    // 注意所有的面-三角形都是逆时针次序绘制的。这点十分重要,在以后的课程中我会作出解释。
    // 现在,您只需明白要么都逆时针,要么都顺时针,但永远不要将两种次序混在一起,
    // 除非您有足够的理由必须这么做。
    glBegin(GL_TRIANGLES);			    // 绘制金字塔
    glColor3f(1.0f,0.0f,0.0f);			// 红色
    glVertex3f( 0.0f, 1.0f, 0.0f);		// 三角形的上顶点 (前侧面)
    glColor3f(0.0f,1.0f,0.0f);			// 绿色
    glVertex3f(-1.0f,-1.0f, 1.0f);		// 三角形的左下顶点 (前侧面)
    glColor3f(0.0f,0.0f,1.0f);			// 蓝色
    glVertex3f( 1.0f,-1.0f, 1.0f);		// 三角形的右下顶点 (前侧面)
    glColor3f(1.0f,0.0f,0.0f);			// 红色
    glVertex3f( 0.0f, 1.0f, 0.0f);		// 三角形的上顶点 (右侧面)
    glColor3f(0.0f,0.0f,1.0f);			// 蓝色
    glVertex3f( 1.0f,-1.0f, 1.0f);		// 三角形的左下顶点 (右侧面)
    glColor3f(0.0f,1.0f,0.0f);			// 绿色
    glVertex3f( 1.0f,-1.0f, -1.0f);		// 三角形的右下顶点 (右侧面)
    glColor3f(1.0f,0.0f,0.0f);			// 红色
    glVertex3f( 0.0f, 1.0f, 0.0f);		// 三角形的上顶点 (后侧面)
    glColor3f(0.0f,1.0f,0.0f);			// 绿色
    glVertex3f( 1.0f,-1.0f, -1.0f);		// 三角形的左下顶点 (后侧面)
    glColor3f(0.0f,0.0f,1.0f);			// 蓝色
    glVertex3f(-1.0f,-1.0f, -1.0f);		// 三角形的右下顶点 (后侧面)
    glColor3f(1.0f,0.0f,0.0f);			// 红色
    glVertex3f( 0.0f, 1.0f, 0.0f);		// 三角形的上顶点 (左侧面)
    glColor3f(0.0f,0.0f,1.0f);			// 蓝色
    glVertex3f(-1.0f,-1.0f,-1.0f);		// 三角形的左下顶点 (左侧面)
    glColor3f(0.0f,1.0f,0.0f);			// 绿色
    glVertex3f(-1.0f,-1.0f, 1.0f);		// 三角形的右下顶点 (左侧面)
    glEnd();                            // 金字塔绘制结束

    glLoadIdentity();
    glTranslatef(1.5f,0.0f,-6.0f);  // 右移1.5单位,并移入屏幕6.0
    glRotatef(rquad,1.0f,1.0f,1.0f);// 在XYZ轴上旋转立方体

    glBegin(GL_QUADS);				    // 绘制立方体
    glColor3f(0.0f,1.0f,0.0f);			// 颜色改为蓝色
    glVertex3f( 1.0f, 1.0f,-1.0f);		// 四边形的右上顶点 (顶面)
    glVertex3f(-1.0f, 1.0f,-1.0f);	    // 四边形的左上顶点 (顶面)
    glVertex3f(-1.0f, 1.0f, 1.0f);		// 四边形的左下顶点 (顶面)
    glVertex3f( 1.0f, 1.0f, 1.0f);		// 四边形的右下顶点 (顶面)
    glColor3f(1.0f,0.5f,0.0f);			// 颜色改成橙色
    glVertex3f( 1.0f,-1.0f, 1.0f);		// 四边形的右上顶点(底面)
    glVertex3f(-1.0f,-1.0f, 1.0f);		// 四边形的左上顶点(底面)
    glVertex3f(-1.0f,-1.0f,-1.0f);		// 四边形的左下顶点(底面)
    glVertex3f( 1.0f,-1.0f,-1.0f);		// 四边形的右下顶点(底面)
    glColor3f(1.0f,0.0f,0.0f);			// 颜色改成红色
    glVertex3f( 1.0f, 1.0f, 1.0f);		// 四边形的右上顶点(前面)
    glVertex3f(-1.0f, 1.0f, 1.0f);		// 四边形的左上顶点(前面)
    glVertex3f(-1.0f,-1.0f, 1.0f);		// 四边形的左下顶点(前面)
    glVertex3f( 1.0f,-1.0f, 1.0f);		// 四边形的右下顶点(前面)
    glColor3f(1.0f,1.0f,0.0f);			// 颜色改成黄色
    glVertex3f( 1.0f,-1.0f,-1.0f);		// 四边形的右上顶点(后面)
    glVertex3f(-1.0f,-1.0f,-1.0f);		// 四边形的左上顶点(后面)
    glVertex3f(-1.0f, 1.0f,-1.0f);		// 四边形的左下顶点(后面)
    glVertex3f( 1.0f, 1.0f,-1.0f);		// 四边形的右下顶点(后面)
    glColor3f(0.0f,0.0f,1.0f);			// 颜色改成蓝色
    glVertex3f(-1.0f, 1.0f, 1.0f);		// 四边形的右上顶点(左面)
    glVertex3f(-1.0f, 1.0f,-1.0f);		// 四边形的左上顶点(左面)
    glVertex3f(-1.0f,-1.0f,-1.0f);		// 四边形的左下顶点(左面)
    glVertex3f(-1.0f,-1.0f, 1.0f);		// 四边形的右下顶点(左面)
    glColor3f(1.0f,0.0f,1.0f);			// 颜色改成紫罗兰色
    glVertex3f( 1.0f, 1.0f,-1.0f);		// 四边形的右上顶点(右面)
    glVertex3f( 1.0f, 1.0f, 1.0f);		// 四边形的左上顶点(右面)
    glVertex3f( 1.0f,-1.0f, 1.0f);		// 四边形的左下顶点(右面)
    glVertex3f( 1.0f,-1.0f,-1.0f);		// 四边形的右下顶点(右面)
    glEnd();						    // 立方体绘制结束
}

运行效果


Qt5版本NeHe OpenGL教程1-5课源码链接:https://download.csdn.net/download/caoshangpa/10413680

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

  PowerVR GPU系列现可提供从单簇到六簇内核的多种组合   全球移动通信大会,西班牙巴塞罗那 —— 2013 年 2 月 25 日 —&md

关键字: 内核 GPU ip powervr g6100 opengl es3.0

长期以来,Android一直为开发人员提供免费的用户界面,以补充背景图片的多样化创建,甚至在多年前,甚至还支持在背景图片中使用openGL。 但是,旧的移动设备无法很好地扩展背景图像,因此移动实时背景图像的开发主要由“出...

关键字: Android opengl 壁纸

函数原型:     void glLoadIdentity(void)函数说明:      OpenGL为我们提供了一个非常简单的恢复初始坐标系的手段,那就是调用glLoadIdentity()命令。

关键字: opengl glloadidentity

pro文件QT -=gui greaterThan(QT_MAJOR_VERSION, 4): QT += widgets TARGET = lesson1 TEMPLATE = app

关键字: opengl QT

坐标系统想要弄懂几何变换,一定要搞清楚OpenGL中的坐标系统。从我们构造模型的局部坐标系(Local/Object Space)经过一系列处理最终渲染到屏幕坐标(Screen Space)下,这过程

关键字: opengl 坐标系

被用户诟病20年后,NVIDIA终于做出让步,在SIGGRAPH开幕活动中,NVIDIA发布Studio Driver: SIGGRAPH Edition驱动程序(v431.70),正式为所有GeFo

关键字: NVIDIA opengl

在这一课里,将学会如何将纹理映射到立方体的六个面。学习texture map纹理映射(贴图)有很多好处。比方说您想让一颗导弹飞过屏幕。根据前几课的知识,我们最可行的办法可能是很多个多边形来构建导弹的轮

关键字: nehe opengl

当前光栅位置:    当前光栅位置就是开始绘制下一幅位图/图像的屏幕位置。  //左下角glRasterPos2f(GLfloat x, GLfloat y);glRasterPos3f(GLfloa

关键字: opengl

这一课将把如下图片做成一个飘动的旗帜,其实主要还是用到了纹理映射。lesson10.h#ifndef LESSON10_H #define LESSON10_H #include#include#i

关键字: opengl QT

在这一课里,我们将添加光照和键盘控制,它让程序看起来更美观。现在设置4个变量来控制绕x轴和y轴旋转角度的步长,以及绕x轴和y轴的旋转速度。另外还创建了一个z变量来控制进入屏幕深处的距离。并添加一个布尔

关键字: opengl qt5
关闭