您的位置:首页 > 运维架构

【OpenGL】nehe教程第二、三课学习笔记

2017-03-23 00:49 218 查看
第二课中,首先讲解了世界坐标系各个轴相对于屏幕的大小及方向,简单归纳就是右手螺旋,

用拇指、食指、中指相互呈90度,食指指天,中指指自己(或从屏幕向外垂直线延伸),拇指指右

还涉及了6个函数,分别是glTranslatef、glLoadIdentity、glBegin、glEnd、glVertex3f、glColor3f.

glTranslatef移动坐标系,将三个轴按照参数移动单位长度??(关于单位长度,笔者做了一些尝试,弄清glTranslate将z轴移动对单位长度的影响)

再重复一下上节课已见过的glLoadIdentity的作用,将坐标系重置到初识位置(0,0,0).

glBegin、glEnd类似于html的标签,两个一对,只有在它俩中间的绘图函数才会起作用,glBegin的参数表明接下来的点绘出的是什么图形,

比如glBegin(GL_POLYGON)是多边形

glBegin(GL_QUADS)是四边形

glVertex3f函数标明点的位置,3代表三个参数也可理解成三维点,f代表float参数(i代表整形)(至于点的顺序是怎样的,是顺时针还是逆时针还是折线,笔者也试了一下)

glColor3f函数将按照RGB(默认)的模式描述点的颜色,点点间线的颜色将由两个点一起决定,期间呈现颜色的过渡,就像是ps的渐变工具似的,glcolor可以在glBegin外使用,如果没有再次用glColor,那么点都将是上一次设置的颜色

关于z轴移动对单位长度的影响

Windows窗体大小为480*480,OpenGL的大小设为960*960,方便我截屏0.0

序号z轴移动单位长度/quads边长效果图
1

0

经测试,0全黑无显示

1
2-0.51(即(0.5f,0.5f,0.0f))


3-1同上

很明显,情况2的图是3的中心四分之一


4-2同上
5-1.219黑边刚出
结论:不是简单的倍数关系,回想计算机锥型投影原理,应该类似与棱台一样的对应关系,可以继续探究一番
ps:好吧,思想幼稚了,还是复习一遍计算机图形学原理,中间涉及到了若干坐标系的转换,最关键的因素是在intiGL里对glPerspective的设置,near是0.1,也就是说glTranslatef必须移动0.1才行,还有一个是相机的摆放位置,gluLookAt这个函数,在nehe的教程里暂时没有看到,可能后面讲。先放放吧。

最终结论是,对应关系很复杂,1.0f只是相对值,可以用它判别其他物体图形的大小。这里有篇博文,可以看看http://blog.csdn.net/ronintao/article/details/9157221



关于点顺序的探究

1逆时针顺序



2将第四个放在第二个



3在2的情况下,将第三个和第四个交换



可以得出结论,OpenGL将按照点出现的顺序绘制,当第四个点不是按照正常四边形的时候如图2,会进行折纸一样的折叠效果
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息