二、OpenGL坐标系

2020-10-09  本文已影响0人  Mjs

1. 2D笛卡尔坐标系

image

坐标是由x、y决定的。

2. 3D笛卡尔坐标系

image

坐标是由x、y、z决定的。

3. 视口

glViewport(GLint x,GLint y,GLsizei width,GLsizei height)

image image

窗口和视口大小可以相同,也可以不同,一般情况跟窗口等比。

4. 投影

image

4.1 正投影

正投影是指平行投射线垂直于投影面。

4.2 透视投影

透视投影属于中心投影。

透视投影图简称为透视图或透视,它是从某个投射中心将物体投射到单一投影面上所得到的图形。透视图与人们观看物体时所产生的视觉效果非常接近。透视图以渲染、配景,使之成为形象逼真的效果图。

5. OpenGL ES中的坐标系

OpenGL ES坐标系统包括视窗坐标规格化设备坐标裁剪坐标视觉坐标世界坐标对象坐标,如下图的洋葱一样成一个多层系统。

image

世界物体照相机空间是右手坐标系
规范化设备坐标系用的是左手坐标系

image

5.1 视窗坐标系

image

视窗坐标也就是我们手机窗口对应的坐标系统,以左上角为原点,右下角对应我们手机的最大像素值的集合,如下图是一个像素为320*480的手机,那他右下角的坐标就是(320,480)。

5.2 规格化设备坐标系

image

规格化设备坐标是以屏幕中心为原点,X轴朝右,Y轴朝上,所以左下角的坐标为(-1, -1),右上角的坐标为(1,1)。当然这是z轴为0时的显示,实际上我们的规格化设备坐标系统是要考虑z轴,所以由平面要转换成一个正方体,原点坐标为(0,0,0),也就是这个立方体的中心,而它左上角离我们最近的那个顶点的坐标就是(1,1,1),右下角离我们最远的那个顶点的坐标就是(-1,-1,-1)。

5.3 裁剪坐标系

image

裁剪坐标是执行矩阵变换透视投影之后,但在执行透视除法之前的坐标。超出裁剪空间的坐标会被丢弃。

5.4 视觉坐标系

image

视觉坐标系是从我们的眼睛出发朝我们的手机设备看过去所能看到的,会有一个z轴的最近距离和最远距离,也就是zNearzFar,只有在这两者之间并且也满足x轴和Y轴坐标在屏幕当中的坐标才会显示出来,越远的东西会显示得越小,产生透视的效果。

5.5 世界坐标系

image

世界坐标就是一个用户构造的固定的坐标系,方便描述这个坐标系下各种物体相对于原点的位置。

5.6 物体坐标系

image

每个物体都有自己独立的坐标系。当物体旋转和移动的时候,这个坐标系也会发生相应的变化。

5.7 惯性坐标系

image

惯性坐标系是指世界坐标系和物体坐标系转换的中间产物。惯性坐标系的原点和物体坐标系的原点重合,但惯性坐标系的轴和世界坐标系的轴平行。

为什么要引入惯性坐标系?因为物体坐标系转换到惯性坐标系只需要旋转,从惯性坐标系转换到世界坐标系只需要平移。

6. OpenGL中的坐标变换

OpenGL最终渲染到屏幕上是2D的,所以我们需要将3D坐标进行一系列的变换为2D坐标,整个过程如下图所示。

image

OpenGL中只定义了裁剪坐标系、规范化设备坐标系和屏幕坐标系。而局部坐标系(模型坐标系)、世界坐标系和相机坐标系都是为了方便用户设计而自定义的坐标系,他们的关系如下图所示。

image

开发中,从局部坐标系(模型坐标系)到裁剪坐标系的转变是通过矩阵运算得到的。这三个矩阵就是MVP矩阵:模型矩阵(M)、观察矩阵(V)和投影矩阵(P)

V_clip = M_pro * M_view * M_model * V_local

在顶点着色器中完成计算后,计算结果会交给gl_PositionOpenGL将会自动计算透视除法和裁剪。

6.1 模型变换

模型变换的目的是通过变换,使得用顶点定义或3D模型软件构造的模型,能够按照需要,通过缩小、平移、旋转等操作放置到场景中合适的位置。

通过模型变换后,物体的位置在全局的世界坐标系下,世界坐标系是所有物体交互的一个公共坐标系。

6.2 视变换

视变换是为了方便观察场景中的物体、方便计算而设立的坐标系。相机坐标系中的坐标,是从相机的角度来解释世界坐标系中的位置。

image
转载:收纳箱
上一篇下一篇

猜你喜欢

热点阅读