| Bullet Collision Detection & Physics Library
    | 
Class for colliding triangles. More...
#include <gim_tri_collision.h>

| Public Member Functions | |
| GIM_TRIANGLE () | |
| GIM_AABB | get_box () const | 
| void | get_normal (btVector3 &normal) const | 
| void | get_plane (btVector4 &plane) const | 
| void | apply_transform (const btTransform &trans) | 
| void | get_edge_plane (GUINT edge_index, const btVector3 &triangle_normal, btVector4 &plane) const | 
| void | get_triangle_transform (btTransform &triangle_transform) const | 
| Gets the relative transformation of this triangle. | |
| bool | collide_triangle_hard_test (const GIM_TRIANGLE &other, GIM_TRIANGLE_CONTACT_DATA &contact_data) const | 
| Test triangles by finding separating axis. | |
| bool | collide_triangle (const GIM_TRIANGLE &other, GIM_TRIANGLE_CONTACT_DATA &contact_data) const | 
| Test boxes before doing hard test. | |
| bool | get_uv_parameters (const btVector3 &point, const btVector3 &tri_plane, GREAL &u, GREAL &v) const | 
| bool | is_point_inside (const btVector3 &point, const btVector3 &tri_normal) const | 
| is point in triangle beam? | |
| bool | ray_collision (const btVector3 &vPoint, const btVector3 &vDir, btVector3 &pout, btVector3 &triangle_normal, GREAL &tparam, GREAL tmax=G_REAL_INFINITY) | 
| Bidireccional ray collision. | |
| bool | ray_collision_front_side (const btVector3 &vPoint, const btVector3 &vDir, btVector3 &pout, btVector3 &triangle_normal, GREAL &tparam, GREAL tmax=G_REAL_INFINITY) | 
| one direccion ray collision | |
| Public Attributes | |
| btScalar | m_margin | 
| btVector3 | m_vertices [3] | 
Class for colliding triangles.
Definition at line 120 of file gim_tri_collision.h.
| 
 | inline | 
Definition at line 126 of file gim_tri_collision.h.
| 
 | inline | 
Definition at line 146 of file gim_tri_collision.h.
| 
 | inline | 
Test boxes before doing hard test.
| other | Triangle for collide | 
| contact_data | Structure for holding contact points, normal and penetration depth; The normal is pointing toward this triangle from the other triangle \ | 
Definition at line 201 of file gim_tri_collision.h.
| bool GIM_TRIANGLE::collide_triangle_hard_test | ( | const GIM_TRIANGLE & | other, | 
| GIM_TRIANGLE_CONTACT_DATA & | contact_data ) const | 
Test triangles by finding separating axis.
| other | Triangle for collide | 
| contact_data | Structure for holding contact points, normal and penetration depth; The normal is pointing toward this triangle from the other triangle | 
Definition at line 610 of file gim_tri_collision.cpp.
| 
 | inline | 
Definition at line 130 of file gim_tri_collision.h.
| 
 | inline | 
Definition at line 153 of file gim_tri_collision.h.
| 
 | inline | 
Definition at line 135 of file gim_tri_collision.h.
| 
 | inline | 
Definition at line 140 of file gim_tri_collision.h.
| 
 | inline | 
Gets the relative transformation of this triangle.
The transformation is oriented to the triangle normal , and aligned to the 1st edge of this triangle. The position corresponds to vertice 0:
Definition at line 167 of file gim_tri_collision.h.
| 
 | inline | 
Solve the System for u,v parameters:
u*axe1[i1] + v*axe2[i1] = vecproj[i1] u*axe1[i2] + v*axe2[i2] = vecproj[i2]
sustitute: v = (vecproj[i2] - u*axe1[i2])/axe2[i2]
then the first equation in terms of 'u':
--> u*axe1[i1] + ((vecproj[i2] - u*axe1[i2])/axe2[i2])*axe2[i1] = vecproj[i1]
--> u*axe1[i1] + vecproj[i2]*axe2[i1]/axe2[i2] - u*axe1[i2]*axe2[i1]/axe2[i2] = vecproj[i1]
--> u*(axe1[i1] - axe1[i2]*axe2[i1]/axe2[i2]) = vecproj[i1] - vecproj[i2]*axe2[i1]/axe2[i2]
--> u*((axe1[i1]*axe2[i2] - axe1[i2]*axe2[i1])/axe2[i2]) = (vecproj[i1]*axe2[i2] - vecproj[i2]*axe2[i1])/axe2[i2]
--> u*(axe1[i1]*axe2[i2] - axe1[i2]*axe2[i1]) = vecproj[i1]*axe2[i2] - vecproj[i2]*axe2[i1]
--> u = (vecproj[i1]*axe2[i2] - vecproj[i2]*axe2[i1]) /(axe1[i1]*axe2[i2] - axe1[i2]*axe2[i1])
if 0.0<= u+v <=1.0 then they are inside of triangle
\return false if the point is outside of triangle.This function doesn't take the margin
Definition at line 242 of file gim_tri_collision.h.
| 
 | inline | 
is point in triangle beam?
Test if point is in triangle, with m_margin tolerance
Definition at line 291 of file gim_tri_collision.h.
| 
 | inline | 
Bidireccional ray collision.
Definition at line 310 of file gim_tri_collision.h.
| 
 | inline | 
one direccion ray collision
Definition at line 342 of file gim_tri_collision.h.
| btScalar GIM_TRIANGLE::m_margin | 
Definition at line 123 of file gim_tri_collision.h.
| btVector3 GIM_TRIANGLE::m_vertices[3] | 
Definition at line 124 of file gim_tri_collision.h.