59 lines
1.7 KiB
Plaintext
59 lines
1.7 KiB
Plaintext
|
#version 430
|
||
|
layout(binding = 0) uniform sampler2D diffuse_tex;
|
||
|
layout(location = 1) uniform float time;
|
||
|
|
||
|
layout(std140, binding = 0) uniform SceneUniforms
|
||
|
{
|
||
|
mat4 PV; //camera projection * view matrix
|
||
|
vec4 eye_w; //world-space eye position
|
||
|
};
|
||
|
|
||
|
layout(std140, binding = 1) uniform LightUniforms
|
||
|
{
|
||
|
vec4 La; //ambient light color
|
||
|
vec4 Ld; //diffuse light color
|
||
|
vec4 Ls; //specular light color
|
||
|
vec4 light_w; //world-space light position
|
||
|
};
|
||
|
|
||
|
layout(std140, binding = 2) uniform MaterialUniforms
|
||
|
{
|
||
|
vec4 ka; //ambient material color
|
||
|
vec4 kd; //diffuse material color
|
||
|
vec4 ks; //specular material color
|
||
|
float shininess; //specular exponent
|
||
|
};
|
||
|
|
||
|
in VertexData
|
||
|
{
|
||
|
vec2 tex_coord;
|
||
|
vec3 pw; //world-space vertex position
|
||
|
vec3 nw; //world-space normal vector
|
||
|
} inData; //block is named 'inData'
|
||
|
|
||
|
out vec4 fragcolor; //the output color for this fragment
|
||
|
|
||
|
void main(void)
|
||
|
{
|
||
|
//Compute per-fragment Phong lighting
|
||
|
vec4 ktex = texture(diffuse_tex, inData.tex_coord);
|
||
|
|
||
|
vec4 ambient_term = ka*ktex*La;
|
||
|
|
||
|
const float eps = 1e-8; //small value to avoid division by 0
|
||
|
float d = distance(light_w.xyz, inData.pw.xyz);
|
||
|
float atten = 1.0/(d*d+eps); //d-squared attenuation
|
||
|
|
||
|
vec3 nw = normalize(inData.nw); //world-space unit normal vector
|
||
|
vec3 lw = normalize(light_w.xyz - inData.pw.xyz); //world-space unit light vector
|
||
|
vec4 diffuse_term = atten*kd*ktex*Ld*max(0.0, dot(nw, lw));
|
||
|
|
||
|
vec3 vw = normalize(eye_w.xyz - inData.pw.xyz); //world-space unit view vector
|
||
|
vec3 rw = reflect(-lw, nw); //world-space unit reflection vector
|
||
|
|
||
|
vec4 specular_term = atten*ks*Ls*pow(max(0.0, dot(rw, vw)), shininess);
|
||
|
|
||
|
fragcolor = ambient_term + diffuse_term + specular_term;
|
||
|
}
|
||
|
|