Clean up TraceRay function and remove old code (should have been in last commit tbh)

This commit is contained in:
Jarrod Doyle 2024-10-28 08:07:10 +00:00
parent 19882dcff2
commit c64343f574
Signed by: Jayrude
GPG Key ID: 38B57B16E7C0ADF7
1 changed files with 4 additions and 34 deletions

View File

@ -484,31 +484,9 @@ class Program
continue; continue;
} }
var hit = TraceRay(scene, pos, light.Position); // We cast from the light to the pixel because the light has
if (!hit) // no mesh in the scene to hit
{ var hit = TraceRay(scene, light.Position, pos);
// TODO: This is still wrong because it clips when a ray should
// be missing, potentially leading to uneven shadows along a
// shadow edge
// We need to clip the point to slightly inside of the poly
// and retrace to avoid three problems:
// 1. Darkened spots from lightmap pixels who's center is outside
// of the polygon but is partially contained in the polygon
// 2. Darkened spots from linear filtering of points outside of the
// polygon which have missed
// 3. Darkened spots where centers are on the exact edge of a poly
// which can sometimes cause Embree to miss casts
//
// The reason we don't do this before the first cast is because it can
// cause incorrect shadows along cell edges on a flat plane.
var p2d = planeMapper.MapTo2d(pos);
p2d = MathUtils.ClipPointToPoly2d(p2d, v2ds);
pos = planeMapper.MapTo3d(p2d);
hit = TraceRay(scene, pos, light.Position, light.R2);
}
if (hit) if (hit)
{ {
// If we're an anim light there's a lot of stuff we need to update // If we're an anim light there's a lot of stuff we need to update
@ -540,17 +518,9 @@ class Program
}); });
} }
private static bool TraceRay(Raytracer scene, Vector3 target, Vector3 origin, float radius2 = float.MaxValue) private static bool TraceRay(Raytracer scene, Vector3 origin, Vector3 target)
{ {
// If we're out of range there's no point casting a ray
var direction = target - origin; var direction = target - origin;
if (direction.LengthSquared() > radius2)
{
return false;
}
// We cast from the light to the pixel because the light has
// no mesh in the scene to hit
var hitResult = scene.Trace(new Ray var hitResult = scene.Trace(new Ray
{ {
Origin = origin, Origin = origin,