rms/resources/shaders/algorithms/normal.frag
2020-07-09 13:02:31 +02:00

24 lines
No EOL
973 B
GLSL

// Requirements:
// #define NORMAL_ACCURACY 0.01
// GetDist: (vec3 position) => float
// GetDist should return the closest object point distance from position (in the whole scene)
/**
* Compute the normal of an object at a given surface point
* this can be usefull for lighting etc..
* This function exploit the fact that the gradient on a given surface point in 3D space
* given the normal direction (source: https://fr.wikipedia.org/wiki/Gradient#Dimension_3_:_gradient_normal_%C3%A0_une_surface_en_un_point,_plan_tangent)
*
*
*/
vec3 GetNormal(vec3 point_position) {
float point_distance = GetDist(point_position);
vec2 epsilon = vec2(NORMAL_ACCURACY, 0); // Just a convenient way to use NORMAL_ACCURACY and 0
// Compute the gradient
vec3 gradient = point_distance - vec3(
GetDist(point_position-epsilon.xyy),
GetDist(point_position-epsilon.yxy),
GetDist(point_position-epsilon.yyx));
return normalize(gradient);
}