Lazarus - OpenGL 3.3 Tutorial - Beleuchtung - Point Light Kugel: Unterschied zwischen den Versionen
Aus DGL Wiki
(Die Seite wurde neu angelegt: „200px<br><br> =Beleuchtung - Point Light Kugel = == Einleitung == In diesem Beisp…“) |
(→Vertex-Shader:) |
||
Zeile 37: | Zeile 37: | ||
vec3 r1 = normalize(p); // Vektoren normalisieren, so das die Länge des Vektors immer 1.0 ist. | vec3 r1 = normalize(p); // Vektoren normalisieren, so das die Länge des Vektors immer 1.0 ist. | ||
vec3 r2 = normalize(q); | vec3 r2 = normalize(q); | ||
− | float d | + | float d = dot(r1, r2); // Skalarprodukt aus beiden Vektoren berechnen. |
return clamp(d, 0.0, 1.0); | return clamp(d, 0.0, 1.0); | ||
} | } | ||
Zeile 46: | Zeile 46: | ||
vec3 Normal = mat3(Matrix) * inNormal; | vec3 Normal = mat3(Matrix) * inNormal; | ||
− | + | vec3 pos = (ModelMatrix * vec4(inPos, 1.0)).xyz; | |
− | vec3 pos = (ModelMatrix * vec4(inPos, 1.0)).xyz; | + | pos.z *= -1.0; |
− | pos.z *= -1.0; | ||
vec3 colRed = light(RedLightPos - pos, Normal) * red; | vec3 colRed = light(RedLightPos - pos, Normal) * red; | ||
Zeile 67: | Zeile 66: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<br><br> | <br><br> | ||
+ | |||
==Fragment-Shader== | ==Fragment-Shader== | ||
<syntaxhighlight lang="glsl">#version 330 | <syntaxhighlight lang="glsl">#version 330 |
Version vom 6. Januar 2018, 22:16 Uhr
Inhaltsverzeichnis
Beleuchtung - Point Light Kugel
Einleitung
In diesem Beispiel sieht man die Punkt-Beleuchtung gut, man kann beobachten, wie sich das Licht innerhalb der Kugeln bewegt.
Am besten man schaltet nur eine Lichtquelle ein.
Der Unterschied zum Directional-Light, man muss noch die Position des Vertex der Lichtposition abziehen.
Wen die Vertex-Position grösser als die Lichtposition ist, dann werschwindet der Vertex im Schatten und wird dunkel.
Hier sieht man, das die Vertex-Position der Lichtposition abgezogen wird.
Vertex-Shader:
#version 330
#define ambient vec3(0.2, 0.2, 0.2)
#define red vec3(1.0, 0.0, 0.0)
#define green vec3(0.0, 1.0, 0.0)
#define blue vec3(0.0, 0.0, 1.0)
layout (location = 0) in vec3 inPos; // Vertex-Koordinaten
layout (location = 1) in vec3 inNormal; // Normale
out vec4 Color; // Farbe, an Fragment-Shader übergeben.
uniform mat4 ModelMatrix;
uniform mat4 Matrix; // Matrix für die Drehbewegung und Frustum.
uniform bool RedOn;
uniform bool GreenOn;
uniform bool BlueOn;
uniform vec3 RedLightPos;
uniform vec3 GreenLightPos;
uniform vec3 BlueLightPos;
float light(vec3 p, vec3 q){
vec3 r1 = normalize(p); // Vektoren normalisieren, so das die Länge des Vektors immer 1.0 ist.
vec3 r2 = normalize(q);
float d = dot(r1, r2); // Skalarprodukt aus beiden Vektoren berechnen.
return clamp(d, 0.0, 1.0);
}
void main(void)
{
gl_Position = Matrix * vec4(inPos, 1.0);
vec3 Normal = mat3(Matrix) * inNormal;
vec3 pos = (ModelMatrix * vec4(inPos, 1.0)).xyz;
pos.z *= -1.0;
vec3 colRed = light(RedLightPos - pos, Normal) * red;
vec3 colGreen = light(GreenLightPos - pos, Normal) * green;
vec3 colBlue = light(BlueLightPos - pos, Normal) * blue;
Color = vec4(ambient, 1.0);
if (RedOn) {
Color.rgb += colRed;
}
if (GreenOn) {
Color.rgb += colGreen;
}
if (BlueOn) {
Color.rgb += colBlue;
}
}
Fragment-Shader
#version 330
in vec4 Color; // interpolierte Farbe vom Vertexshader
out vec4 outColor; // ausgegebene Farbe
void main(void)
{
outColor = Color; // Die Ausgabe der Farbe
}
Autor: Mathias
Siehe auch
- Übersichtseite Lazarus - OpenGL 3.3 Tutorial