当前位置: 首页 > news >正文

计算机图形学编程(使用OpenGL和C++)(第2版)学习笔记 13.几何着色器(二)爆炸效果修改图元类型

1. 爆炸效果

这是几何着色器中的一个常见应用,我们使用几何着色器来模拟爆炸效果。
1
我们希望将每个三角形沿其表面法向量向外移动,则实际上是将组成环面的三角形向外“爆炸”。

我们只需取三个顶点的法向量,然后将其相加并求平均,即可得到环面的法向量。这样就能形成爆炸效果。
2

1.1. 代码

只需修改几何着色器即可,主要修改为红框部份:
3

完整代码如下

#version 430// 定义输入图元类型为三角形
layout (triangles) in;// 从顶点着色器接收的输入变量(必须声明为数组)
in vec3 varyingNormal[];    // 法线向量数组
in vec3 varyingLightDir[];  // 光照方向数组
in vec3 varyingVertPos[];   // 顶点位置数组// 传递给片段着色器的输出变量
out vec3 gNormal;    // 法线向量
out vec3 gLightDir;  // 光照方向
out vec3 gVertPos;   // 顶点位置// uniform变量声明
uniform mat4 proj_matrix;  // 投影矩阵
uniform mat4 norm_matrix;  // 法线变换矩阵// 定义输出图元类型为三角形带,每个图元最多输出3个顶点
layout (triangle_strip, max_vertices = 3) out;void main(void)
{vec3 triangleNormal=(varyingNormal[0] + varyingNormal[1] + varyingNormal[2]) / 3.0;// 处理三角形的每个顶点for (int i = 0; i < 3; i++){// 计算膨胀效果//vec3 normal = normalize(varyingNormal[i]);  // 归一化法线向量vec3 normal = normalize(triangleNormal);  // 归一化法线向量// 将顶点沿法线方向移动(膨胀效果)//gl_Position = proj_matrix * gl_in[i].gl_Position + normalize(vec4(normal, 1.0));gl_Position =proj_matrix*( gl_in[i].gl_Position + normalize(vec4(normal, 1.0)) * 0.5);// 将变量传递给片段着色器gNormal = varyingNormal[i];      // 传递法线gLightDir = varyingLightDir[i];  // 传递光照方向gVertPos = varyingVertPos[i];    // 传递顶点位置// 发射顶点EmitVertex();}// 结束当前图元的构建EndPrimitive();
}

2. 修改图元类型

1
上图是将三角形图元修改为线段图元,我们只需要修改几何着色器即可,
核心思路是形成新的两个点

完整代码如下

#version 430
// 点光源结构体定义
struct PositionalLight
{   vec4 ambient;    // 环境光分量vec4 diffuse;    // 漫反射分量vec4 specular;   // 镜面反射分量vec3 position;   // 光源位置
};
// 定义输入图元类型为三角形
layout (triangles) in;// 从顶点着色器接收的输入变量(必须声明为数组)
in vec3 varyingNormal[];    // 法线向量数组
in vec3 varyingLightDir[];  // 光照方向数组
in vec3 varyingVertPos[];   // 顶点位置数组// 传递给片段着色器的输出变量
out vec3 gNormal;    // 法线向量
out vec3 gLightDir;  // 光照方向
out vec3 gVertPos;   // 顶点位置// uniform变量声明
uniform mat4 proj_matrix;  // 投影矩阵
uniform mat4 norm_matrix;  // 法线变换矩阵uniform PositionalLight light;    // 点光源属性
layout (line_strip, max_vertices = 2) out;void main(void)
{float sLen=0.5;vec3 op0 = gl_in[0].gl_Position.xyz; // 原始三角形顶点vec3 op1 = gl_in[1].gl_Position.xyz; vec3 op2 = gl_in[2].gl_Position.xyz; vec3 ep0 = gl_in[0].gl_Position.xyz + varyingNormal[0]*sLen; // 偏移三角形顶点vec3 ep1 = gl_in[1].gl_Position.xyz + varyingNormal[1]*sLen; vec3 ep2 = gl_in[2].gl_Position.xyz + varyingNormal[2]*sLen; // 计算组成小线段的新点vec3 newPoint1 = (op0 + op1 + op2)/3.0; // 原始点(起点)vec3 newPoint2 = (ep0 + ep1 + ep2)/3.0; // 终点gl_Position = proj_matrix * vec4(newPoint1, 1.0); gVertPos = newPoint1; gLightDir = light.position - newPoint1; gNormal = varyingNormal[0]; EmitVertex(); gl_Position = proj_matrix * vec4(newPoint2, 1.0); gVertPos = newPoint2; gLightDir = light.position - newPoint2; gNormal = varyingNormal[1]; EmitVertex();// 结束当前图元的构建EndPrimitive();
}

文章转载自:
http://ayin.aaladrg.cn
http://airmark.aaladrg.cn
http://capricious.aaladrg.cn
http://anasarca.aaladrg.cn
http://attainments.aaladrg.cn
http://chromatogram.aaladrg.cn
http://aerialist.aaladrg.cn
http://abirritant.aaladrg.cn
http://centavo.aaladrg.cn
http://assay.aaladrg.cn
http://candlestand.aaladrg.cn
http://atempo.aaladrg.cn
http://balliol.aaladrg.cn
http://cashbox.aaladrg.cn
http://bacchus.aaladrg.cn
http://bridle.aaladrg.cn
http://advertorial.aaladrg.cn
http://backside.aaladrg.cn
http://apportion.aaladrg.cn
http://boyhood.aaladrg.cn
http://calcography.aaladrg.cn
http://anaemia.aaladrg.cn
http://centigrade.aaladrg.cn
http://beggary.aaladrg.cn
http://cervelat.aaladrg.cn
http://allelic.aaladrg.cn
http://blatancy.aaladrg.cn
http://appointor.aaladrg.cn
http://cep.aaladrg.cn
http://bridle.aaladrg.cn
http://www.dtcms.com/a/200720.html

相关文章:

  • ARMv7的NVIC中断优先级
  • Timer-XL:长上下文Transformer模型引领时序预测新篇章
  • TransmittableThreadLocal实现上下文传递-笔记
  • 活学妙用——5W2H分析法
  • 深入理解 Redisson 看门狗机制:保障分布式锁自动续期
  • 【工具变量】A股上市公司企业大数据运用数据(2007-2023年)
  • HTTP由浅入深
  • 力扣303 区域和检索 - 数组不可变
  • ubuntu 20.04 运行和编译LOAM_Velodyne
  • EtherCAT通讯框架
  • 导轨固定螺栓的扭矩标准是多少?
  • RAC共享存储扩容
  • win11下,启动springboot时,提示端口被占用的处理方式
  • RAG策略
  • Python读取和处理TIFF数据教程 (由简入深)
  • NumPy 2.x 完全指南【十一】N 维数组对象(ndarray)
  • 庐山派 HDMI Python 图像开发 K230图像传输方案
  • 在资源受限环境下,移动端如何实现流畅动画?如何在内存、CPU、GPU、网络等多种限制条件下,依然保持动画高帧率、低延迟、不卡顿?
  • 自定义协议与序列化
  • 大型商用货运无人机强势入局2025深圳eVTOL展
  • 【硬核数学】2. AI如何“学习”?微积分揭秘模型优化的奥秘《从零构建机器学习、深度学习到LLM的数学认知》
  • 亚远景-ASPICE与ISO 21434在汽车电子系统开发中的应用案例
  • 微服务项目->在线oj系统(Java版 - 5)
  • 机器学习第十六讲:K-means → 自动把超市顾客分成不同消费群体
  • Java—— File详解
  • VTK|箱体切割器
  • 【git进阶】git rebase(变基)
  • 前端子项目打包集成主项目实战指南
  • SOC-ESP32S3部分:1、ESP32开发IDF-5.4环境搭建
  • RV1126多线程获取SMARTP的GOP模式数据和普通GOP模式数据