2024-07-21 16:39:45 +05:30
|
|
|
// For in depth ray marching or sphere tracing info check out the playlist
|
|
|
|
// https://www.youtube.com/watch?v=68G3V5Yr8FY&list=PLaE0_uENxXqvzte-A0Ux2pav0zrUrTJ1V
|
|
|
|
|
2024-03-27 11:23:17 +05:30
|
|
|
float sdf_custom(vec3 p) {
|
|
|
|
// Basic example of Sphere SDF with radius of .3
|
|
|
|
// Put your custom logic here
|
|
|
|
float radius = .3;
|
|
|
|
return length(p) - radius;
|
|
|
|
}
|
|
|
|
|
|
|
|
float ray_march_custom(vec3 ray_origin, vec3 ray_dir, int max_steps, float max_dist, float dist_threshold) {
|
2024-03-26 10:59:07 +05:30
|
|
|
ray_dir = normalize(ray_dir);
|
|
|
|
dist_threshold = abs(dist_threshold);
|
|
|
|
float dist_from_origin = 0.;
|
|
|
|
float dist_to_surface;
|
|
|
|
for(int i = 0; i < max_steps; i++) {
|
|
|
|
vec3 point = ray_origin + dist_from_origin * ray_dir;
|
2024-03-27 11:23:17 +05:30
|
|
|
dist_to_surface = sdf_custom(point);
|
2024-03-26 10:59:07 +05:30
|
|
|
dist_from_origin += dist_to_surface;
|
|
|
|
if(dist_to_surface < dist_threshold || dist_to_surface > max_dist)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return dist_from_origin;
|
|
|
|
}
|