24 lines
No EOL
973 B
GLSL
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);
|
|
} |