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

简介: 该案例主要是对常见的图元连接方式的运用

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


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

微信图片_20220513105719.png

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

微信图片_20220513105834.png

  • main函数:程序入口
  • ChangeSize函数:主要是设置视口及投影方式
  • SetupRC函数:图形数据配置,主要是顶点数据及图元连接方式
  • RenderScene函数:主要用于图形的绘制,可以系统触发,也可以开发者手动触发
  • SpecialKeys函数:对特殊键位的回调处理
  • KeyPressFunc:针对空格键的回调处理
  • DrawWireFrameBatch:用于立体图形的填充及边框绘制


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


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函数


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


  • 将模型视图矩阵和投影矩阵放到变换管道中,变换管道的作用是能帮助快速进行矩阵相乘,在RenderScene函数中可以直接通过变换管道的Get方法得到相应的矩阵
transformPipeline.SetMatrixStacks(modelViewMatrix, projectionMatrix);

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

微信图片_20220513110412.png

  • 设置观察者位置
cameraFrame.MoveForward(-15.0f);

观察者位置的设置有三种

微信图片_20220513110553.png

RenderScene函数


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

微信图片_20220513110714.png


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

微信图片_20220513110847.png


  • ChangeSize函数中向栈中初始化了一个单元矩阵
  • RenderScene函数中再次向栈中压入一个单元矩阵:主要是为了图形绘制完成后,矩阵的复原,所以此时栈中有两个单元矩阵
modelViewMatrix.PushMatrix();
  • 将cameraFrame构建为 观察者矩阵,将栈顶单元矩阵取出,与观察者矩阵相乘,得到新的观察者矩阵,再将其入栈
    M3DMatrix44f mCamera;
    cameraFrame.GetCameraMatrix(mCamera);
    modelViewMatrix.MultMatrix(mCamera);


  • 将objectFrame构建为 物体矩阵,取出栈顶的观察者矩阵,与物体矩阵相乘,得到模型视图矩阵,并将其入栈
  • 然后利用固定管线渲染图形,在图像渲染完成后,将栈中模型视图矩阵pop,恢复其初始状态。


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

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

微信图片_20220513111403.png

补充:

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

相关文章
|
4月前
|
算法
[Halcon&几何] 矩形顶点和对角连线角度计算
[Halcon&几何] 矩形顶点和对角连线角度计算
38 0
|
7月前
|
存储
Kitten 动态绘制 Y 轴方向立方体的实现方法
Kitten 动态绘制 Y 轴方向立方体的实现方法
25 0
关于已知线段,如何求封闭图形轮廓的一些猜想
关于已知线段,如何求封闭图形轮廓的一些猜想
|
数据挖掘 Python
【python数据分析】绘制双Y轴坐标系
前言 Matplotlib绘制出的图形中会存在一些问题,例如:如何绘制双Y轴坐标系?如何去掉图形默认的边框?以及如何移动坐标到指定位置?下面我们就来看看如何解决
【python数据分析】绘制双Y轴坐标系
|
10月前
群落堆叠柱状图+冲击图绘制
群落堆叠柱状图+冲击图绘制
75 1
|
11月前
|
机器学习/深度学习 算法 数据可视化
R绘图案例|基于分面的面积图绘制
R绘图案例|基于分面的面积图绘制
10830 0
|
自然语言处理 JavaScript 前端开发
【计算机图形学】六面体旋转并实时切换虚线实线 - 代码实现
【计算机图形学】六面体旋转并实时切换虚线实线 - 代码实现
790 0
【计算机图形学】六面体旋转并实时切换虚线实线 - 代码实现
|
计算机视觉
五、OpenCV绘制线、矩形、圆等基本几何形状
通过javaOpenCV中的Imgproc函数进行简单几何图形的绘制
99 0
五、OpenCV绘制线、矩形、圆等基本几何形状
在画图软件中,可以画出不同大小或颜色的圆形、矩形等几何图形。几何图形之间有许多共同的特征,如它们可以是用某种颜色画出来的,可以是填充的或者不填充的。
编写Java程序:在画图软件中,可以画出不同大小或颜色的圆形、矩形等几何图形。几何图形之间有许多共同的特征,如它们可以是用某种颜色画出来的,可以是填充的或者不填充的。
案例03 补充:金字塔等图形边框的绘制
案例03 补充:金字塔等图形边框的绘制
233 0
案例03 补充:金字塔等图形边框的绘制