AkwariumRoom/cw 9/shaders/shader_9_1.vert

54 lines
1.3 KiB
GLSL
Raw Normal View History

2023-01-29 16:27:16 +01:00
#version 430 core
layout(location = 0) in vec3 vertexPosition;
layout(location = 1) in vec3 vertexNormal;
layout(location = 2) in vec2 vertexTexCoord;
layout(location = 3) in vec3 vertexTangent;
layout(location = 4) in vec3 vertexBitangent;
uniform mat4 transformation;
uniform mat4 modelMatrix;
out vec3 vecNormal;
out vec3 worldPos;
uniform vec3 lightPos;
2023-02-09 13:32:22 +01:00
uniform vec3 lightPos2;
uniform vec3 lightPos3;
2023-01-29 16:27:16 +01:00
uniform vec3 spotlightPos;
2023-02-09 13:32:22 +01:00
2023-01-29 16:27:16 +01:00
uniform vec3 cameraPos;
uniform vec3 sunDir;
out vec3 viewDirTS;
out vec3 lightDirTS;
out vec3 spotlightDirTS;
out vec3 sunDirTS;
2023-02-09 13:32:22 +01:00
out vec3 lightDirTS2;
out vec3 lightDirTS3;
2023-01-29 16:27:16 +01:00
void main()
{
worldPos = (modelMatrix* vec4(vertexPosition,1)).xyz;
vecNormal = (modelMatrix* vec4(vertexNormal,0)).xyz;
gl_Position = transformation * vec4(vertexPosition, 1.0);
vec3 w_tangent = normalize(mat3(modelMatrix)*vertexTangent);
vec3 w_bitangent = normalize(mat3(modelMatrix)*vertexBitangent);
mat3 TBN = transpose(mat3(w_tangent, w_bitangent, vecNormal));
vec3 V = normalize(cameraPos-worldPos);
viewDirTS = TBN*V;
vec3 L = normalize(lightPos-worldPos);
lightDirTS = TBN*L;
2023-02-09 13:32:22 +01:00
vec3 L2 = normalize(lightPos2-worldPos);
lightDirTS2 = TBN*L2;
vec3 L3 = normalize(lightPos3-worldPos);
lightDirTS3 = TBN*L3;
2023-01-29 16:27:16 +01:00
vec3 SL = normalize(spotlightPos-worldPos);
spotlightDirTS = TBN*SL;
sunDirTS = TBN*sunDir;
}