aboutsummaryrefslogtreecommitdiff
path: root/src/geometry
diff options
context:
space:
mode:
authorSébastien Crozet <developer@crozet.re>2022-06-24 11:56:12 +0200
committerSébastien Crozet <developer@crozet.re>2022-06-24 11:56:12 +0200
commit9e431fb392fe85228b695fd5e58c61da7bef1dd2 (patch)
treeef4dc0a8744b8d33fe44a8b8bc582bc68fbe3506 /src/geometry
parentd708ca01d980e7920103ad81feffbf39c6611e5e (diff)
downloadrapier-9e431fb392fe85228b695fd5e58c61da7bef1dd2.tar.gz
rapier-9e431fb392fe85228b695fd5e58c61da7bef1dd2.tar.bz2
rapier-9e431fb392fe85228b695fd5e58c61da7bef1dd2.zip
Address rounding errors resulting in AABBProxy being added to a disjoint region.
Diffstat (limited to 'src/geometry')
-rw-r--r--src/geometry/broad_phase_multi_sap/sap_layer.rs7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/geometry/broad_phase_multi_sap/sap_layer.rs b/src/geometry/broad_phase_multi_sap/sap_layer.rs
index 216ea05..4316ecd 100644
--- a/src/geometry/broad_phase_multi_sap/sap_layer.rs
+++ b/src/geometry/broad_phase_multi_sap/sap_layer.rs
@@ -240,6 +240,13 @@ impl SAPLayer {
let region_proxy = &mut proxies[region_id];
let region = region_proxy.data.as_region_mut();
+ // NOTE: sometimes, rounding errors will generate start/end indices
+ // that lie outside of the actual region’s AABB.
+ // TODO: is there a smarter, more efficient way of dealing with this?
+ if !region_proxy.aabb.intersects(aabb_to_discretize) {
+ continue;
+ }
+
if let Some(actual_aabb) = actual_aabb {
// NOTE: if the actual AABB doesn't intersect the
// region’s AABB, then we need to delete the