QT+OpenGL反射与折射

news/2024/11/25 15:25:10/

文章目录

  • QT+OpenGL反射与折射
    • 反射
    • 折射

QT+OpenGL反射与折射

本篇完整工程见gitee:QtOpenGL 对应点的tag,由turbolove提供技术支持,您可以关注博主或者私信博主

反射

反射这个属性表现为物体(或者物体的一部分)反射它周围的环境,即根据观察者的视角,物体的颜色或多或少等于他的环境。

最终的反射向量将会作为索引/采样立方体贴图的方向向量,返回颜色的值。

关键代码:

shader.vert

#version 330 core
layout (location = 0) in vec3 aPos;
layout (location = 1) in vec3 aNormal;
layout (location = 2) in vec2 aTexCoords;out vec3 Normal;
out vec3 FragPos;
out vec2 TexCoords;uniform mat4 model;
uniform mat4 view;
uniform mat4 projection;
void main() {TexCoords=aTexCoords;Normal = mat3(transpose(inverse(model))) * aNormal;FragPos=vec3(model * vec4(aPos,1.0));gl_Position = projection * view * model * vec4(aPos, 1.0);
}

shader.frag

#version 330 corestruct Material {sampler2D texture_diffuse1;sampler2D texture_specular1;float shininess;
};struct Light {vec3 direction;vec3 ambient;vec3 diffuse;vec3 specular;
};
uniform Light light;uniform Material material;
out vec4 FragColor;in vec2 TexCoords;
in vec3 Normal;
in vec3 FragPos;uniform vec3 viewPos;void main() {vec3 diffuseTexColor=vec3(texture(material.texture_diffuse1,TexCoords));vec3 specularTexColor=vec3(texture(material.texture_specular1,TexCoords));// ambientvec3 ambient = diffuseTexColor*light.ambient;// diffusevec3 norm = normalize(Normal);vec3 lightDir = normalize(-light.direction);float diff = max(dot(norm, lightDir), 0.0);vec3 diffuse = diff *diffuseTexColor*light.diffuse;// specularvec3 viewDir = normalize(viewPos - FragPos);vec3 reflectDir = reflect(-lightDir, norm);float spec = pow(max(dot(viewDir, reflectDir), 0.0), material.shininess);vec3 specular =  spec*specularTexColor*light.specular;vec3 result = (ambient + diffuse + specular);FragColor = vec4(result, 1.0);
}

reflection.vert

#version 330 core
layout (location = 0) in vec3 aPos;
layout (location = 1) in vec3 aNormal;
out vec3 Normal;
out vec3 Position;
uniform mat4 model;
uniform mat4 view;
uniform mat4 projection;
void main() {Normal = mat3(transpose(inverse(model))) * aNormal;Position = vec3(model * vec4(aPos, 1.0));gl_Position = projection * view * vec4(Position, 1.0);
}

reflection.frag

#version 330 core
out vec4 FragColor;
in vec3 Normal;
in vec3 Position;
uniform vec3 viewPos;
uniform samplerCube skybox;
void main() {vec3 I = normalize(Position - viewPos);vec3 R = reflect(I, normalize(Normal));FragColor = vec4(texture(skybox, R).rgb, 1.0);
}

在这里插入图片描述

折射

折射是光线由于传播介质的改变而产生的方向变化。折射是通过斯涅尔定律来描述的。

折射可以使用GLSL的内建refract函数来轻松实现,他需要一个法向量、一个观察方向和两个材质之间的折射率。

这里使用反射的shader。

主要代码:

reflection.frag

void main()
{float ratio = 1.00/1.52;vec3 I = normalize(Position - cameraPos);vec3 R = refract(I, normalize(Normal), ratio);FragColor = vec4(texture(skybox, R).rgb, 1.0);
}

在这里插入图片描述


http://www.ppmy.cn/news/61209.html

相关文章

阿里云服务器ECS上安装Redis数据库流程by Alibaba Cloud Linux

阿里云服务器操作系统Alibaba Cloud Linux 2针对Redis应用进行了专项调优,相比社区版操作系统,Redis应用整体性能提升20%以上。Alibaba Cloud Linux 2内置Redis 6.0.5和Redis 3.2.12的yum源,执行sudo yum install命令即可部署Redis 6.0.5和Re…

js中的简写语法

1、简写的闭包自执行函数(Immediately Invoked Function Expression (IIFE)) 使用括号将函数定义包裹起来,再在末尾加上另一对括号,即可创建一个自执行函数。例如: (() > {console.log("Hello, world!"…

vue-router4、vuex4、Pinia

vue-router4 vue 升级 vue3 之后,配套的 vue-router 也升级为 vue-router4.x 版本 vue-router4 的语法和 3 的版本语法基本一致,但是有一些细微的修改。 vue-router官网:Vue Router | The official Router for Vue.js/ vue2 vue-router3 vu…

亚马逊下单需要什么条件?(养号干货知识)

混迹亚马逊的老手都知道,测评向来都是最有效,最快速的推广方式,给自己商品做点销量,优化一下listing,留一下一些优质评论,甚至于打压一下竞品,帮自己商品解个围。 养号环境四大步: …

Java 基础进阶篇(九)—— Java集合详细总结

文章目录 一、集合类体系结构二、Collection系列集合2.1 Collection 集合体系2.2 Collection 集合体系特点2.3 Collection 常用API2.4 Collection 集合的遍历方式2.4.1 方式一:迭代器2.4.2 方式二:foreach(增强for循环)2.4.3 方式…

数字化转型导师坚鹏:企业干部如何进行数字化转型

企业干部如何进行数字化转型 ——数字化转型背景下重塑企业干部核心竞争力 授课背景: 很多银行存在以下问题: 企业干部不知道如何进行数字化转型? 企业干部不清楚银行数字化能力模型的内涵? 企业干部不知道如何通过数字化…

MySQL数据库——MySQL修改视图(ALTER VIEW)

修改视图是指修改 MySQL 数据库中存在的视图&#xff0c;当基本表的某些字段发生变化时&#xff0c;可以通过修改视图来保持与基本表的一致性。 基本语法 可以使用 ALTER VIEW 语句来对已有的视图进行修改。 语法格式如下&#xff1a; ALTER VIEW <视图名> AS <SE…

我们都低估了GPT-4,它才是梦开始的地方

最近这两个月 AI技术带来的冲击一个接一个 我们的团队 都在忙着研究各种AIC能力 这个方面 还真不如自己马上上手 用这些软件感受来的那么强烈 我觉得至少有几个产品 大家可以去试一下 第一 大家赶紧去看一个check GBT plus的账号 然后亲身体验一下GPT4的底层能力 第二 是编程的…