aboutsummaryrefslogtreecommitdiff
path: root/src/geometry/proximity_detector
diff options
context:
space:
mode:
authorCrozet Sébastien <developer@crozet.re>2020-10-06 10:46:59 +0200
committerCrozet Sébastien <developer@crozet.re>2020-10-06 10:46:59 +0200
commit8e432b298bd71df7d1b776b77c15713d9bea280e (patch)
tree5f3490e347286d1a4c2301d3fe43346869d1449e /src/geometry/proximity_detector
parent721db2d49e06de38a16320425f77986b308445dc (diff)
downloadrapier-8e432b298bd71df7d1b776b77c15713d9bea280e.tar.gz
rapier-8e432b298bd71df7d1b776b77c15713d9bea280e.tar.bz2
rapier-8e432b298bd71df7d1b776b77c15713d9bea280e.zip
Make the WQuadTree more generic and use it as the trimesh acceleration structure.
Diffstat (limited to 'src/geometry/proximity_detector')
-rw-r--r--src/geometry/proximity_detector/trimesh_shape_proximity_detector.rs12
1 files changed, 5 insertions, 7 deletions
diff --git a/src/geometry/proximity_detector/trimesh_shape_proximity_detector.rs b/src/geometry/proximity_detector/trimesh_shape_proximity_detector.rs
index 3dd7381..0a3ff44 100644
--- a/src/geometry/proximity_detector/trimesh_shape_proximity_detector.rs
+++ b/src/geometry/proximity_detector/trimesh_shape_proximity_detector.rs
@@ -5,7 +5,7 @@ use crate::geometry::{Collider, Proximity, Shape, Trimesh, WAABBHierarchyInterse
use crate::ncollide::bounding_volume::{BoundingVolume, AABB};
pub struct TrimeshShapeProximityDetectorWorkspace {
- interferences: WAABBHierarchyIntersections,
+ interferences: Vec<usize>,
local_aabb2: AABB<f32>,
old_interferences: Vec<usize>,
}
@@ -13,7 +13,7 @@ pub struct TrimeshShapeProximityDetectorWorkspace {
impl TrimeshShapeProximityDetectorWorkspace {
pub fn new() -> Self {
Self {
- interferences: WAABBHierarchyIntersections::new(),
+ interferences: Vec::new(),
local_aabb2: AABB::new_invalid(),
old_interferences: Vec::new(),
}
@@ -67,19 +67,17 @@ fn do_detect_proximity(
let local_aabb2 = new_local_aabb2; // .loosened(ctxt.prediction_distance * 2.0); // FIXME: what would be the best value?
std::mem::swap(
&mut workspace.old_interferences,
- &mut workspace.interferences.computed_interferences_mut(),
+ &mut workspace.interferences,
);
- trimesh1
- .waabbs()
- .compute_interferences_with(local_aabb2, &mut workspace.interferences);
+ workspace.interferences = trimesh1.waabbs().intersect_aabb(&local_aabb2);
workspace.local_aabb2 = local_aabb2;
}
/*
* Dispatch to the specific solver by keeping the previous manifold if we already had one.
*/
- let new_interferences = workspace.interferences.computed_interferences();
+ let new_interferences = &workspace.interferences;
let mut old_inter_it = workspace.old_interferences.drain(..).peekable();
let mut best_proximity = Proximity::Disjoint;