From ce51e1f5346fd10b32c4cc9d1588ec55acaa8dbe Mon Sep 17 00:00:00 2001 From: Jozufozu Date: Thu, 5 Sep 2024 13:45:24 -0500 Subject: [PATCH] Near stability - Fix near plane rejection logic - Fix lod clamp --- .../assets/flywheel/flywheel/internal/indirect/cull.glsl | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/common/src/backend/resources/assets/flywheel/flywheel/internal/indirect/cull.glsl b/common/src/backend/resources/assets/flywheel/flywheel/internal/indirect/cull.glsl index 1b6436a42..c1ab067bd 100644 --- a/common/src/backend/resources/assets/flywheel/flywheel/internal/indirect/cull.glsl +++ b/common/src/backend/resources/assets/flywheel/flywheel/internal/indirect/cull.glsl @@ -43,7 +43,8 @@ bool _flw_testSphere(vec3 center, float radius) { } bool projectSphere(vec3 c, float r, float znear, float P00, float P11, out vec4 aabb) { - if (c.z > r + znear) { + // Closest point on the sphere is between the camera and the near plane, don't even attempt to cull. + if (c.z + r > -znear) { return false; } @@ -91,7 +92,7 @@ bool _flw_isVisible(uint instanceIndex, uint modelIndex) { float width = (aabb.z - aabb.x) * _flw_cullData.pyramidWidth; float height = (aabb.w - aabb.y) * _flw_cullData.pyramidHeight; - int level = clamp(0, int(ceil(log2(max(width, height)))), _flw_cullData.pyramidLevels); + int level = clamp(int(ceil(log2(max(width, height)))), 0, _flw_cullData.pyramidLevels); ivec2 levelSize = textureSize(_flw_depthPyramid, level);