diff options
author | Rudolph Bester <Rudolph.f.bester@gmail.com> | 2024-10-26 20:07:34 +0200 |
---|---|---|
committer | Rudolph Bester <Rudolph.f.bester@gmail.com> | 2024-10-26 20:07:34 +0200 |
commit | 76c20383d107598ce7c9f7ccddff54a6a0002ea8 (patch) | |
tree | 8dceafb956077bc9857fac2e00760665f8d867c3 | |
parent | 61accf060515416da07d913580419fd8c8490f7b (diff) | |
download | redot-engine-76c20383d107598ce7c9f7ccddff54a6a0002ea8.tar.gz |
Fix Occlusion Culling not working for an orthogonal camera.
-rw-r--r-- | modules/raycast/raycast_occlusion_cull.cpp | 2 | ||||
-rw-r--r-- | servers/rendering/renderer_scene_occlusion_cull.h | 2 |
2 files changed, 2 insertions, 2 deletions
diff --git a/modules/raycast/raycast_occlusion_cull.cpp b/modules/raycast/raycast_occlusion_cull.cpp index 54dc040583..634c370b05 100644 --- a/modules/raycast/raycast_occlusion_cull.cpp +++ b/modules/raycast/raycast_occlusion_cull.cpp @@ -140,7 +140,7 @@ void RaycastOcclusionCull::RaycastHZBuffer::_generate_camera_rays(const CameraRa Vector3 dir; if (p_data->camera_orthogonal) { - dir = -p_data->camera_dir; + dir = p_data->camera_dir; tile.ray.org_x[j] = pixel_pos.x - dir.x * p_data->z_near; tile.ray.org_y[j] = pixel_pos.y - dir.y * p_data->z_near; tile.ray.org_z[j] = pixel_pos.z - dir.z * p_data->z_near; diff --git a/servers/rendering/renderer_scene_occlusion_cull.h b/servers/rendering/renderer_scene_occlusion_cull.h index 0ef92dd9ff..a59ec7b952 100644 --- a/servers/rendering/renderer_scene_occlusion_cull.h +++ b/servers/rendering/renderer_scene_occlusion_cull.h @@ -84,7 +84,7 @@ public: Vector3 view = p_cam_inv_transform.xform(corner); if (p_cam_projection.is_orthogonal()) { - min_depth = MIN(min_depth, view.z); + min_depth = MIN(min_depth, -view.z); } Plane vp = Plane(view, 1.0); |