62 lines
1.9 KiB
GLSL
62 lines
1.9 KiB
GLSL
#version 430 core
|
|
|
|
in layout(location = 0) vec3 position;
|
|
in layout(location = 1) vec3 normal;
|
|
in layout(location = 2) vec2 UV;
|
|
in layout(location = 3) vec4 color;
|
|
in layout(location = 4) vec3 tangent;
|
|
in layout(location = 5) vec3 bitangent;
|
|
|
|
layout(binding = 0) uniform sampler2D diffuseTexture;
|
|
layout(binding = 1) uniform sampler2D normalTexture;
|
|
layout(binding = 2) uniform sampler2D displacementTexture;
|
|
uniform float displacementCoefficient;
|
|
|
|
uniform mat4 MVP;
|
|
uniform mat4 MV;
|
|
uniform mat4 MVnormal;
|
|
|
|
// material
|
|
uniform vec2 uvOffset;
|
|
uniform float opacity;
|
|
uniform float shininess;
|
|
uniform vec3 diffuse_color;
|
|
uniform vec3 specular_color;
|
|
uniform vec3 emissive_color;
|
|
|
|
uniform bool isIlluminated;
|
|
uniform bool isTextured;
|
|
uniform bool isVertexColored;
|
|
uniform bool isNormalMapped;
|
|
uniform bool isDisplacementMapped;
|
|
uniform bool isReflectionMapped;
|
|
uniform bool isInverted;
|
|
|
|
out layout(location = 0) vec3 vertex_out;
|
|
out layout(location = 1) vec3 normal_out;
|
|
out layout(location = 2) vec2 uv_out;
|
|
out layout(location = 3) vec4 color_out;
|
|
out layout(location = 4) vec3 tangent_out;
|
|
out layout(location = 5) vec3 bitangent_out;
|
|
|
|
void main() {
|
|
vec3 displacement = vec3(0.0);
|
|
if (isDisplacementMapped) {
|
|
float o = texture(displacementTexture, UV + uvOffset).r * 2.0 - 1.0;
|
|
float u = (texture(displacementTexture, UV + uvOffset + vec2(0.001, 0.0)).r*2.0-1.0 - o) / 0.004;
|
|
float v = (texture(displacementTexture, UV + uvOffset + vec2(0.0, 0.001)).r*2.0-1.0 - o) / 0.004;
|
|
|
|
displacement = normal * displacementCoefficient * o;
|
|
}
|
|
|
|
normal_out = normalize(vec3(MVnormal * vec4(normal, 1.0f)));
|
|
vertex_out = vec3(MV * vec4(position+displacement, 1.0f));
|
|
uv_out = UV + uvOffset;
|
|
gl_Position = MVP * vec4(position+displacement, 1.0f);
|
|
|
|
color_out = color;
|
|
|
|
tangent_out = normalize(vec3(MVnormal * vec4(tangent, 1.0f)));
|
|
bitangent_out = normalize(vec3(MVnormal * vec4(bitangent, 1.0f)));
|
|
}
|