AkwariumRoom-Reupload/cw 9/shaders/shader_texture.vert

78 lines
1.8 KiB
GLSL
Raw Normal View History

2023-02-09 15:33:19 +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;
2023-02-09 15:33:19 +01:00
uniform mat4 transformation;
uniform mat4 modelMatrix;
2023-02-10 14:25:02 +01:00
uniform float size;
2023-02-09 15:33:19 +01:00
uniform mat4 LightVP;
2023-02-09 15:33:19 +01:00
out vec3 vecNormal;
out vec3 worldPos;
out vec2 vecTex;
uniform vec3 lightPos;
uniform vec3 lightPos2;
uniform vec3 lightPos3;
uniform vec3 spotlightPos;
uniform vec3 cameraPos;
uniform vec3 sunDir;
out vec3 viewDirTS;
out vec3 lightDirTS;
out vec3 spotlightDirTS;
out vec3 sunDirTS;
out vec3 lightDirTS2;
out vec3 lightDirTS3;
out vec4 sunSpacePos;
2023-02-09 15:33:19 +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;
vec3 L2 = normalize(lightPos2-worldPos);
lightDirTS2 = TBN*L2;
vec3 L3 = normalize(lightPos3-worldPos);
lightDirTS3 = TBN*L3;
vec3 SL = normalize(spotlightPos-worldPos);
spotlightDirTS = TBN*SL;
sunDirTS = TBN*sunDir;
2023-02-10 14:25:02 +01:00
if(size == 5){
vecTex = vertexTexCoord * vec2(15,15);
vecTex.y = 1.0 - vecTex.y;
}
2023-02-12 16:36:55 +01:00
else if(size == 7){
vecTex = vertexTexCoord * vec2(20,40);
vecTex.y = 1.0 - vecTex.y;
}
else if(size == 10){
vecTex = vertexTexCoord * vec2(150,150);
2023-02-10 14:25:02 +01:00
vecTex.y = 1.0 - vecTex.y;
}
else{
vecTex = vertexTexCoord;
vecTex.y = 1.0 - vecTex.y;
}
sunSpacePos=LightVP*modelMatrix*vec4(vertexPosition,1);
}