OpenGL的使用

案例 03:金字塔、六边形、圆环的绘制

2020-07-09  本文已影响0人  Style_月月

OpenGL + OpenGL ES +Metal 系列文章汇总

该案例主要是对常见的图元连接方式的运用,常见的基本图元连接方式见此链接

最终实现的效果如图所示:


最终效果

如图所示,整体的绘制流程如下


整体流程

主要对其中三个函数进行一些说明

ChangeSize函数

在之前的demo中,changeSize主要是用来设置视口大小以及当视口发生变化时调用的,而本案例中立体图形的绘制需要使用投影矩阵,因此需要在该函数中设置投影矩阵
主要涉及以下几个步骤

//参数1:垂直方向上的视场角度
//参数2:视口纵横比 = w/h
//参数3:近裁剪面距离
//参数4:远裁剪面距离
viewFrustum.SetPerspective(35.0f, float(w)/float(h), 1.0f, 500.0f);
projectionMatrix.LoadMatrix(viewFrustum.GetProjectionMatrix());
modelViewMatrix.LoadIdentity();

SetupRC函数

从流程图上可以看出,除了基本的背景色设置,存储着色器初始化以及顶点数据的创建及传输外,还需要对阵矩阵及观察者做一下设置

transformPipeline.SetMatrixStacks(modelViewMatrix, projectionMatrix);

其中,变换管道通过get可获得的矩阵有4种

方法 说明
GetProjectionMatrix() 投影矩阵
GetNormalMatrix() 法线矩阵
GetModelViewMatrix() 模型视图矩阵,简称mv
GetModelViewProjectionMatrix() 模型视图投影矩阵,简称mvp
cameraFrame.MoveForward(-15.0f);

观察者位置的设置有三种

方法 说明
void MoveForward(float fDelta) 向外移动的像素点,修改z
void MoveUp(float fDelta) 向上移动的像素点,修改y
void MoveRight(float fDelta) 向右移动的像素点,修改x

RenderScene函数

其流程如下所示,主要是立体图形的渲染过程


渲染流程

从流程图中可以看出,这个过程是将物体坐标转换为裁剪坐标,然后经过OpenGL的处理,转换为NDC,并显示到屏幕上的一个过程。在此过程中栈的变化如下所示


栈中变化过程
modelViewMatrix.PushMatrix();
    M3DMatrix44f mCamera;
    cameraFrame.GetCameraMatrix(mCamera);
    modelViewMatrix.MultMatrix(mCamera);

具体代码见Github 04_OpenGL点/线...

最后,附一个圆形中顶点坐标(x,y)的求解图示


圆中顶点坐标的求解

补充:
图形中关于边框的绘制的详解见案例03 补充:金字塔等图形边框的绘制

上一篇 下一篇

猜你喜欢

热点阅读