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
use crate::math::{Isometry, Point, Vector};
use na::{RealField, Unit};
pub trait SupportMap<N: RealField> {
fn local_support_point(&self, dir: &Vector<N>) -> Point<N>;
fn local_support_point_toward(&self, dir: &Unit<Vector<N>>) -> Point<N> {
self.local_support_point(dir.as_ref())
}
fn support_point(&self, transform: &Isometry<N>, dir: &Vector<N>) -> Point<N> {
let local_dir = transform.inverse_transform_vector(dir);
transform * self.local_support_point(&local_dir)
}
fn support_point_toward(&self, transform: &Isometry<N>, dir: &Unit<Vector<N>>) -> Point<N> {
let local_dir = Unit::new_unchecked(transform.inverse_transform_vector(dir));
transform * self.local_support_point_toward(&local_dir)
}
}