2024-01-17 23:36:37 +00:00
<!DOCTYPE html>
< html >
< head >
< meta charset = "utf-8" / >
< title > WebGL Example< / title >
< script id = "vertex-shader" type = "x-shader/x-vertex" > # v e r s i o n 3 0 0 e s
in vec4 vPosition;
in vec3 vNormal;
uniform mat4 modelMatrix;
uniform mat4 viewMatrix;
uniform mat4 projectionMatrix;
uniform vec3 lightPosition;
uniform vec4 Ia;
uniform vec4 Id;
uniform vec4 Is;
uniform vec4 ka;
uniform vec4 kd;
uniform vec4 ks;
uniform float specExp;
const float c1 = 1.0;
const float c2 = 0.0005;
const float c3 = 0.000003;
out vec4 vfColor;
void main()
{
mat4 modelViewMatrix = viewMatrix * modelMatrix;
mat4 normalMatrix = inverse(transpose(modelViewMatrix));
vec4 position = modelViewMatrix * vPosition;
vec4 normal = normalMatrix * vec4(vNormal, 0.0);
vec4 lightPos = viewMatrix * vec4(lightPosition, 1.0);
vec3 N = normalize(normal.xyz);
vec3 L = normalize((lightPos - position).xyz);
vec3 V = normalize((-position).xyz);
vec3 R = reflect(-L, N);
float d = distance(lightPos, position);
float fAtt = min(1.0/(c1 + c2 * d + c3 * pow(d, 2.0)), 1.0);
vec4 I = Ia * ka
+ fAtt * (Id * kd * max(dot(N, L), 0.0)
+ Is * ks * pow(max(dot(R, V), 0.0), specExp));
vfColor = vec4(I.xyz, 1.0);
gl_Position = projectionMatrix * position;
}
< / script >
< script id = "fragment-shader" type = "x-shader/x-fragment" > # v e r s i o n 3 0 0 e s
precision mediump float;
in vec4 vfColor;
out vec4 fColor;
void main()
{
fColor = vfColor;
}
< / script >
< script id = "vertex-shader-water" type = "x-shader/x-vertex" > # v e r s i o n 3 0 0 e s
in vec4 vPosition;
in vec3 vNormal;
in vec2 vTexCoord;
uniform mat4 modelMatrix;
uniform mat4 viewMatrix;
uniform mat4 projectionMatrix;
uniform vec3 lightPosition;
out vec4 positionCam;
out vec4 normalCam;
out vec4 lightPosCam;
out vec2 vfTexCoord;
void main()
{
mat4 modelViewMatrix = viewMatrix * modelMatrix;
mat4 normalMatrix = inverse(transpose(modelViewMatrix));
positionCam = modelViewMatrix * vPosition;
normalCam = normalMatrix * vec4(vNormal, 0.0);
lightPosCam = viewMatrix * vec4(lightPosition, 1.0);
gl_Position = projectionMatrix * positionCam;
vfTexCoord = vTexCoord;
}
< / script >
< script id = "fragment-shader-water" type = "x-shader/x-fragment" > # v e r s i o n 3 0 0 e s
precision mediump float;
in vec4 positionCam;
in vec4 normalCam;
in vec4 lightPosCam;
in vec2 vfTexCoord;
uniform vec4 Ia;
uniform vec4 Id;
uniform vec4 Is;
uniform vec4 ka;
uniform vec4 kd;
uniform vec4 ks;
uniform float specExp;
const float c1 = 1.0;
const float c2 = 0.0005;
const float c3 = 0.000003;
uniform sampler2D diffuseMap;
2024-01-18 03:25:57 +00:00
uniform sampler2D normalMap;
2024-01-17 23:36:37 +00:00
// TODO 1.2: Füge Normal Map als uniforme Variable hinzu.
out vec4 fColor;
void main()
{
// TODO 1.5: Berechne (normalisierte) Normale, Tangente und Binormale im Kameraraum
2024-01-18 03:25:57 +00:00
vec3 n = normalize(normalCam.xyz);
vec3 t = normalize(cross(n, vec3(0.0, 0.0, 1.0)));
vec3 b = cross(n, t);
2024-01-17 23:36:37 +00:00
// TODO 1.6: Stelle TBN-Matrix zur Transformation vom Kamera- in den Tangentenraum auf.
2024-01-18 03:25:57 +00:00
mat3 tbn = mat3(t.x, t.y, t.z, b.x, b.y, b.z, n.x, n.y, n.z);
2024-01-17 23:36:37 +00:00
// TODO 1.7: Lese Normale aus Normal Map aus, verschiebe ihren Wertebereich und transformiere sie anschließend mit der TBN-Matrix vom Tangentenraum in den Kameraraum. (Kommentiere hiezu zunächst die folgende Zeile aus.)
2024-01-18 03:25:57 +00:00
// vec3 N = normalize(normalCam.xyz);
vec3 normalTex = texture(normalMap, vfTexCoord).rgb;
vec3 N = normalize(tbn * (normalTex * 2.0 - 1.0));
2024-01-17 23:36:37 +00:00
// Calculate and normalize L, V and R
vec3 L = normalize((lightPosCam - positionCam).xyz);
vec3 V = normalize((-positionCam).xyz);
vec3 R = reflect(-L, N);
float d = distance(lightPosCam, positionCam);
float fAtt = min(1.0/(c1 + c2 * d + c3 * pow(d, 2.0)), 1.0);
vec4 diffuseColor = texture(diffuseMap, vfTexCoord);
vec4 I = Ia * ka
+ fAtt * (Id * diffuseColor * max(dot(N, L), 0.0)
+ Is * ks * pow(max(dot(R, V), 0.0), specExp));
fColor = vec4(I.xyz, 1.0);
}
< / script >
< script type = "text/javascript" src = "common/initShaders.js" > < / script >
< script type = "text/javascript" src = "common/gl-matrix.js" > < / script >
< script type = "text/javascript" src = "common/objects3D.js" > < / script >
< / head >
< body >
< h1 > Lorem Ipsum< / h1 >
< canvas id = "gl-canvas" width = "1024" height = "512" >
If you see this, your browser doesn't support WebGL.
< / canvas >
< script src = "main.js" type = "text/javascript" > < / script >
< / body >
< / html >