1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
use crate::math::{Isometry, Real};
use crate::query::ClosestPoints;
use crate::shape::{Ball, Shape};
#[inline]
pub fn closest_points_ball_convex_polyhedron(
pos12: &Isometry<Real>,
ball1: &Ball,
shape2: &(impl Shape + ?Sized),
prediction: Real,
) -> ClosestPoints {
match crate::query::details::contact_ball_convex_polyhedron(pos12, ball1, shape2, prediction) {
Some(contact) => {
if contact.dist <= 0.0 {
ClosestPoints::Intersecting
} else {
ClosestPoints::WithinMargin(contact.point1, contact.point2)
}
}
None => ClosestPoints::Disjoint,
}
}
#[inline]
pub fn closest_points_convex_polyhedron_ball(
pos12: &Isometry<Real>,
shape1: &(impl Shape + ?Sized),
ball2: &Ball,
prediction: Real,
) -> ClosestPoints {
match crate::query::details::contact_convex_polyhedron_ball(pos12, shape1, ball2, prediction) {
Some(contact) => {
if contact.dist <= 0.0 {
ClosestPoints::Intersecting
} else {
ClosestPoints::WithinMargin(contact.point1, contact.point2)
}
}
None => ClosestPoints::Disjoint,
}
}