summaryrefslogtreecommitdiffstats
path: root/modules/raycast/raycast_occlusion_cull.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'modules/raycast/raycast_occlusion_cull.cpp')
-rw-r--r--modules/raycast/raycast_occlusion_cull.cpp31
1 files changed, 7 insertions, 24 deletions
diff --git a/modules/raycast/raycast_occlusion_cull.cpp b/modules/raycast/raycast_occlusion_cull.cpp
index 94d8b267d1..3609f5a554 100644
--- a/modules/raycast/raycast_occlusion_cull.cpp
+++ b/modules/raycast/raycast_occlusion_cull.cpp
@@ -90,18 +90,11 @@ void RaycastOcclusionCull::RaycastHZBuffer::update_camera_rays(const Transform3D
td.camera_dir = -p_cam_transform.basis.get_column(2);
td.camera_orthogonal = p_cam_orthogonal;
- Projection inv_camera_matrix = p_cam_projection.inverse();
- Vector3 camera_corner_proj = Vector3(-1.0f, -1.0f, -1.0f);
- Vector3 camera_corner_view = inv_camera_matrix.xform(camera_corner_proj);
- td.pixel_corner = p_cam_transform.xform(camera_corner_view);
-
- Vector3 top_corner_proj = Vector3(-1.0f, 1.0f, -1.0f);
- Vector3 top_corner_view = inv_camera_matrix.xform(top_corner_proj);
- Vector3 top_corner_world = p_cam_transform.xform(top_corner_view);
-
- Vector3 left_corner_proj = Vector3(1.0f, -1.0f, -1.0f);
- Vector3 left_corner_view = inv_camera_matrix.xform(left_corner_proj);
- Vector3 left_corner_world = p_cam_transform.xform(left_corner_view);
+ // Calculate the world coordinates of the viewport.
+ Vector2 viewport_half = p_cam_projection.get_viewport_half_extents();
+ td.pixel_corner = p_cam_transform.xform(Vector3(-viewport_half.x, -viewport_half.y, -p_cam_projection.get_z_near()));
+ Vector3 top_corner_world = p_cam_transform.xform(Vector3(-viewport_half.x, viewport_half.y, -p_cam_projection.get_z_near()));
+ Vector3 left_corner_world = p_cam_transform.xform(Vector3(viewport_half.x, -viewport_half.y, -p_cam_projection.get_z_near()));
td.pixel_u_interp = left_corner_world - td.pixel_corner;
td.pixel_v_interp = top_corner_world - td.pixel_corner;
@@ -140,7 +133,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;
@@ -181,17 +174,7 @@ void RaycastOcclusionCull::RaycastHZBuffer::sort_rays(const Vector3 &p_camera_di
}
int k = tile_i * TILE_SIZE + tile_j;
int tile_index = i * tile_grid_size.x + j;
- float d = camera_rays[tile_index].ray.tfar[k];
-
- if (!p_orthogonal) {
- const float &dir_x = camera_rays[tile_index].ray.dir_x[k];
- const float &dir_y = camera_rays[tile_index].ray.dir_y[k];
- const float &dir_z = camera_rays[tile_index].ray.dir_z[k];
- float cos_theta = p_camera_dir.x * dir_x + p_camera_dir.y * dir_y + p_camera_dir.z * dir_z;
- d *= cos_theta;
- }
-
- mips[0][y * buffer_size.x + x] = d;
+ mips[0][y * buffer_size.x + x] = camera_rays[tile_index].ray.tfar[k];
}
}
}