VS2012下基于Glut OpenGL glDepthMask示例程序:
glDepthMask (GLboolean flag)函数可以决定将他之后的数据不写入深度缓冲区。当flag为GL_TRUE时之后的数据不写入深度缓冲区,即使启用了深度缓冲区测试功能。
使用上一个Demo:点击打开链接上加入该功能:
未启用glDepthMask时如下所示:
单击鼠标右键弹出相应菜单:
选菜单On启用glDepthMask后看到坐标系的Z轴箭头已经看不见了,因为坐标系的Z轴箭头是在多边形之前绘制的。
源代码如下所示:
// GlutStarDemo.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <gl/glut.h>
#include <math.h>
//圆周率宏
#define GL_PI 3.1415f
//获取屏幕的宽度
GLint SCREEN_WIDTH=0;
GLint SCREEN_HEIGHT=0;
//设置程序的窗口大小
GLint windowWidth=400;
GLint windowHeight=300;
//绕x轴旋转角度
GLfloat xRotAngle=0.0f;
//绕y轴旋转角度
GLfloat yRotAngle=0.0f;
#define MODE_SOLID 1
#define MODE_LINE 2
#define MODE_POINTS 3
GLint iMode=MODE_SOLID;// 多边形的填充方式
GLboolean bEdgeFlag=GL_TRUE;//控制边的显示与否
GLboolean bDepthMaskFlag=GL_TRUE;//控制边的显示与否
//受支持的点大小范围
GLfloat sizes[2];
//受支持的点大小增量
GLfloat step;
//菜单回调函数
void processMenu(int value){
switch(value){
case 1:
iMode=MODE_SOLID;
break;
case 2:
iMode=MODE_LINE;
break;
case 3:
iMode=MODE_POINTS;
break;
case 4:
bEdgeFlag=GL_TRUE;
break;
case 5:
bEdgeFlag=GL_FALSE;
break;
case 6:
bDepthMaskFlag=GL_TRUE;
break;
case 7:
bDepthMaskFlag=GL_FALSE;
break;
default:
break;
}
//重新绘制
glutPostRedisplay();
}
//显示回调函数
void renderScreen(void){
GLfloat x,y,z,angle;
int i;
//把整个窗口清理为当前清理颜色:黑色
glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);
if(bDepthMaskFlag)
glDepthMask(GL_TRUE);
else
glDepthMask(GL_FALSE);
//将当前Matrix状态入栈
glPushMatrix();
//坐标系绕x轴旋转xRotAngle
glRotatef(xRotAngle,1.0f,0.0f,0.0f);
//坐标系绕y轴旋转yRotAngle
glRotatef(yRotAngle,0.0f,1.0f,0.0f);
//设置多边形正面和背面的填充模式
if(MODE_SOLID==iMode)
glPolygonMode(GL_FRONT_AND_BACK,GL_FILL);
if(MODE_LINE==iMode)
glPolygonMode(GL_FRONT_AND_BACK,GL_LINE);
if(MODE_POINTS==iMode)
glPolygonMode(GL_FRONT_AND_BACK,GL_POINT);
x=0.0f;
y=0.0f;
z=0.0f;
//进行平滑处理
glEnable(GL_POINT_SMOOTH);
glHint(GL_POINT_SMOOTH,GL_NICEST);
glEnable(GL_LINE_SMOOTH);
glHint(GL_LINE_SMOOTH,GL_NICEST);
glEnable(GL_POLYGON_SMOOTH);
glHint(GL_POLYGON_SMOOTH,GL_NICEST);
//绘制坐标系
if(MODE_POINTS!=iMode){
glColor3f(1.0f,1.0f,1.0f);
glBegin(GL_LINES);
glVertex3f(-80.0f,0.0f,0.0f);
glVertex3f(80.0f,0.0f,0.0f);
glVertex3f(0.0f,-80.0f,0.0f);
glVertex3f(0.0f,80.0f,0.0f);
glVertex3f(0.0f,0.0f,-80.0f);
glVertex3f(0.0f,0.0f,80.0f);
glEnd(); glPushMatrix();
glTranslatef(80.0f,0.0f,0.0f);
glRotatef(90.0f,0.0f,1.0f,0.0f);
glutWireCone(3,6,10,10);
glPopMatrix(); glPushMatrix();
glTranslatef(0.0f,80.0f,0.0f);
glRotatef(-90.0f,1.0f,0.0f,0.0f);
glutWireCone(3,6,10,10);
glPopMatrix(); glPushMatrix();
glTranslatef(0.0f,0.0f,80.0f);
glRotatef(90.0f,0.0f,0.0f,1.0f);
glutWireCone(3,6,10,10);
glPopMatrix();
}
glColor3f(0.0f,1.0f,0.0f);
glBegin(GL_TRIANGLES);
//glPointSize(sizes[1]);
glEdgeFlag(bEdgeFlag);
glVertex2f(-20.0f, 20.0f);
glEdgeFlag(GL_TRUE);
glVertex2f(20.0f, 20.0f);
glVertex2f(0.0f, 60.0f); glVertex2f(-20.0f,20.0f);
glVertex2f(-60.0f,0.0f);
glEdgeFlag(bEdgeFlag);
glVertex2f(-20.0f,-20.0f);
glEdgeFlag(GL_TRUE); glVertex2f(-20.0f,-20.0f);
glVertex2f(0.0f, -60.0f);
glEdgeFlag(bEdgeFlag);
glVertex2f(20.0f, -20.0f);
glEdgeFlag(GL_TRUE); glVertex2f(20.0f, -20.0f);
glVertex2f(60.0f, 0.0f);
glEdgeFlag(bEdgeFlag);
glVertex2f(20.0f, 20.0f);
glEdgeFlag(GL_TRUE); // Center square as two triangles
glEdgeFlag(bEdgeFlag);
glVertex2f(-20.0f, 20.0f);
glVertex2f(-20.0f,-20.0f);
glVertex2f(20.0f, 20.0f); glVertex2f(-20.0f,-20.0f);
glVertex2f(20.0f, -20.0f);
glVertex2f(20.0f, 20.0f);
glEdgeFlag(GL_TRUE);
glEnd(); //恢复压入栈的Matrix
glPopMatrix();
//交换两个缓冲区的指针
glutSwapBuffers();
}
//设置Redering State
void setupRederingState(void){
//设置清理颜色为黑色
glClearColor(0.0f,0.0,0.0,1.0f);
//设置绘画颜色为绿色
glColor3f(0.0f,1.0f,0.0f);
//使能深度测试
glEnable(GL_DEPTH_TEST);
//获取受支持的点大小范围
glGetFloatv(GL_POINT_SIZE_RANGE,sizes);
//获取受支持的点大小增量
glGetFloatv(GL_POINT_SIZE_GRANULARITY,&step);
printf("point size range:%f-%f\n",sizes[0],sizes[1]);
printf("point step:%f\n",step);
}
//窗口大小变化回调函数
void changSize(GLint w,GLint h){
//横宽比率
GLfloat ratio;
//设置坐标系为x(-100.0f,100.0f)、y(-100.0f,100.0f)、z(-100.0f,100.0f)
GLfloat coordinatesize=100.0f;
//窗口宽高为零直接返回
if((w==0)||(h==0))
return;
//设置视口和窗口大小一致
glViewport(0,0,w,h);
//对投影矩阵应用随后的矩阵操作
glMatrixMode(GL_PROJECTION);
//重置当前指定的矩阵为单位矩阵
glLoadIdentity();
ratio=(GLfloat)w/(GLfloat)h;
//正交投影
if(w<h)
glOrtho(-coordinatesize,coordinatesize,-coordinatesize/ratio,coordinatesize/ratio,-coordinatesize,coordinatesize);
else
glOrtho(-coordinatesize*ratio,coordinatesize*ratio,-coordinatesize,coordinatesize,-coordinatesize,coordinatesize);
//对模型视图矩阵堆栈应用随后的矩阵操作
glMatrixMode(GL_MODELVIEW);
//重置当前指定的矩阵为单位矩阵
glLoadIdentity();
} //按键输入处理回调函数
void specialKey(int key,int x,int y){ if(key==GLUT_KEY_UP){
xRotAngle-=5.0f;
}
else if(key==GLUT_KEY_DOWN){
xRotAngle+=5.0f;
}
else if(key==GLUT_KEY_LEFT){
yRotAngle-=5.0f;
}
else if(key==GLUT_KEY_RIGHT){
yRotAngle+=5.0f;
}
//重新绘制
glutPostRedisplay();
} int main(int argc, char* argv[])
{
int nModeMenu;
int nEdgeMenu;
int nDepthMask;
int nMainMenu;
//初始化glut
glutInit(&argc,argv);
//使用双缓冲区模式
glutInitDisplayMode(GLUT_DOUBLE|GLUT_RGBA|GLUT_DEPTH);
//获取系统的宽像素
SCREEN_WIDTH=glutGet(GLUT_SCREEN_WIDTH);
//获取系统的高像素
SCREEN_HEIGHT=glutGet(GLUT_SCREEN_HEIGHT);
//创建窗口,窗口名字为OpenGL Star Demo
glutCreateWindow("OpenGL Star Demo");
//创建二级菜单
nModeMenu=glutCreateMenu(processMenu);
glutAddMenuEntry("Solid",1);
glutAddMenuEntry("Outline",2);
glutAddMenuEntry("Points",3);
nEdgeMenu=glutCreateMenu(processMenu);
glutAddMenuEntry("On",4);
glutAddMenuEntry("Off",5);
nDepthMask=glutCreateMenu(processMenu);
glutAddMenuEntry("On",6);
glutAddMenuEntry("Off",7);
nMainMenu=glutCreateMenu(processMenu);
glutAddSubMenu("Mode",nModeMenu);
glutAddSubMenu("Edge",nEdgeMenu);
glutAddSubMenu("DepthMsk",nDepthMask);
//将菜单榜定到鼠标右键上
glutAttachMenu(GLUT_RIGHT_BUTTON);
//设置窗口大小
glutReshapeWindow(windowWidth,windowHeight);
//窗口居中显示
glutPositionWindow((SCREEN_WIDTH-windowWidth)/2,(SCREEN_HEIGHT-windowHeight)/2);
//窗口大小变化时的处理函数
glutReshapeFunc(changSize);
//设置显示回调函数
glutDisplayFunc(renderScreen);
//设置按键输入处理回调函数
glutSpecialFunc(specialKey);
//设置全局渲染参数
setupRederingState();
glutMainLoop();
return 0;
}
VS2012下基于Glut OpenGL glDepthMask示例程序:的更多相关文章
- VS2012下基于Glut OpenGL glEdgeFlag示例程序:
glEdgeFlag (GLboolean flag)表示一个顶点是否应该被认为是多边形的一条边界边的起点.flag为GL_TRUE后面的点都被认为是边界上的点,flag为GL_FALSE则之后的点不 ...
- VS2012下基于Glut OpenGL glScissor示例程序:
剪裁测试用于限制绘制区域.我们可以指定一个矩形的剪裁窗口,当启用剪裁测试后,只有在这个窗口之内的像素才能被绘制,其它像素则会被丢弃.换句话说,无论怎么绘制,剪裁窗口以外的像素将不会被修改.有的朋友可能 ...
- VS2012下基于Glut 矩阵变换示例程序2:
在VS2012下基于Glut 矩阵变换示例程序:中我们在绘制甜圈或者圆柱时使用矩阵对相应的坐标进行变换后自己绘制甜圈或者圆柱.我们也可以使用glLoadMatrixf.glLoadMatrixd载入变 ...
- VS2012下基于Glut 矩阵变换示例程序:
也可以使用我们自己的矩阵运算来实现OpenGL下的glTranslatef相应的旋转变换.需要注意的是OpenGL下的矩阵是列优先存储的. 示例通过矩阵运算使得圆柱或者甜圈自动绕Y轴旋转,可以单击鼠标 ...
- 使用VS2012开发基于Office 2013的AddIn程序
默认VS2012开发的Office Add是基于2010的,如下所示: 如果你机器上安装的Office版本是2013,那么使用VS2012创建的工程是无法运行的,弹出如下的错误: 那么此时怎么办呢?将 ...
- .NET Core初体验 - 在Mac下运行第一个Web示例程序
要说最近两天程序猿之间最喜欢吹水的事是什么?那绝壁是甲骨文要放弃Java!简直做梦都要笑醒!由于公司的产品线全面转向Java,最近几个月也一直在苦学Java技术.已经默默决定了,如果消息证实是真的,我 ...
- 部署Bookinfo示例程序详细过程和步骤(基于Kubernetes集群+Istio v1.0)
部署Bookinfo示例程序详细过程和步骤(基于Kubernetes集群+Istio v1.0) 部署Bookinfo示例程序 在下载的Istio安装包的samples目录中包含了示例应用程序. ...
- 基于阿里云容器服务用docker容器运行ASP.NET 5示例程序
小试阿里云容器服务 之后,接下来有一个挡不住的小试冲动--用docker容器运行程序.首先想到的程序是 ASP.NET 5示例程序,于是参考msdn博客中的这篇博文 Running ASP.NET 5 ...
- Windows7+VS2012下OpenGL 4的环境配置
系统环境 Windows 7 Ultimate x64,Visual Studio Ultimate 2012 Update 4,和一块支持OpenGL 4.x的显卡. 准备工作 首先用GPU Cap ...
随机推荐
- Nagios监控lvs服务
1在lvs server上安装nrpe客户端: 1.1,rpm方式安装nrpe客户端 下载地址:http://download.csdn.net/detail/mchdba/7493875 [root ...
- 框架Asp.net Identity
框架Asp.net Identity 在Asp.net上,微软的membershop框架经历了Asp.net membership到Asp.net simple membership,再到现在的Asp ...
- 查看oracle数据库服务器的名字
原文:查看oracle数据库服务器的名字 windows 中 1. select name from v$database ; 直接运行就可以查看了, 2.查看tnsnames.ora 的连接,有个S ...
- J2EE
随笔分类 - J2EE 关于SpringMVC Json使用 摘要: 很简单的一个东西,这里就不做过多介绍了,写一个小Demo,随手记录下.首先,在搭好SpringMVC工程环境之后,如果想用Sp ...
- PDFBox之文档创建
1.创建一个空的PDF 下面的小例子表示如何使用PDFBox来创建一个新的PDF文档. // 创建一个空的文档 PDDocument document = new PDDocument(); // 创 ...
- Asterisk 未来之路3.0_0006
原文:Asterisk 未来之路3.0_0006 Modules Asterisk 是基于模块构建的.一个模块提供某个特定的功能,它是动态的被装载.比如:信道驱动(chan_sip.so),或可以连接 ...
- CodeIgniter学习一:基础知识
1. url片段(CI域名组成说明) example.com/index.php/test/index 第一部分(test):控制器 第二部分(index):方法,动作 如果第二部分 ...
- avalonJS入门(一)
前端神器avalonJS入门(一) posted @ 2014-10-31 17:44 vajoy 阅读(1665) 评论(32) 编辑 收藏 avalonJS是司徒正美开发和维护的前端mvvm框 ...
- 如何在局域网安装Redmine(转贴)
如何在局域网安装Redmine(转贴) 分类: Redmine2009-06-01 10:31 1740人阅读 评论(0) 收藏 举报 phpmyadmin项目管理railssubversion数据库 ...
- 基于AngularJS的前端云组件最佳实践
AngularJS是google设计和开发的一套前端开发框架,他能帮助开发人员更便捷地进行前端开发.AngularJS是为了克服HTML在构建应用上的不足而设计的,它非常全面且简单易学习,因此Angu ...