ruby-bullet 0.0.1-x86-linux
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/INSTALL.md +22 -0
- data/LICENSE +23 -0
- data/README.md +39 -0
- data/Rakefile +131 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/btAxisSweep3.i +30 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/btBroadphaseInterface.i +8 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/btBroadphaseProxy.i +8 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/btCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/btDbvt.i +10 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/btDbvtBroadphase.i +8 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/btDispatcher.i +8 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/btMultiSapBroadphase.i +10 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/btOverlappingPairCache.i +8 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/btOverlappingPairCallback.i +8 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/btQuantizedBvh.i +8 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/btSimpleBroadphase.i +8 -0
- data/bindings/bullet/interface/BulletCollision/BroadphaseCollision/local_btAxisSweep3Internal.h +191 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/SphereTriangleDetector.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btActivatingCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btBox2dBox2dCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btBoxBoxCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btBoxBoxDetector.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btCollisionConfiguration.i +21 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btCollisionCreateFunc.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btCollisionDispatcher.i +24 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btCollisionObject.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btCollisionWorld.i +82 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btCompoundCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btConvex2dConvex2dAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btConvexConcaveCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btConvexConvexAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btConvexPlaneCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btDefaultCollisionConfiguration.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btEmptyCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btGhostObject.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btInternalEdgeUtility.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btManifoldResult.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btSimulationIslandManager.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btSphereBoxCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btSphereSphereCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btSphereTriangleCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionDispatch/btUnionFind.i +10 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btBox2dShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btBoxShape.i +22 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btBvhTriangleMeshShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btCapsuleShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btCollisionMargin.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btCollisionShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btCompoundShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btConcaveShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btConeShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btConvex2dShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btConvexHullShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btConvexInternalShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btConvexPointCloudShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btConvexPolyhedron.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btConvexShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btConvexTriangleMeshShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btCylinderShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btEmptyShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btHeightfieldTerrainShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btMaterial.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btMinkowskiSumShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btMultiSphereShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btMultimaterialTriangleMeshShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btOptimizedBvh.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btPolyhedralConvexShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btScaledBvhTriangleMeshShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btShapeHull.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btSphereShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btStaticPlaneShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btStridingMeshInterface.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btTetrahedronShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btTriangleBuffer.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btTriangleCallback.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btTriangleIndexVertexArray.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btTriangleIndexVertexMaterialArray.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btTriangleInfoMap.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btTriangleMeshShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btTriangleShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/CollisionShapes/btUniformScalingShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/Gimpact/btBoxCollision.i +8 -0
- data/bindings/bullet/interface/BulletCollision/Gimpact/btClipPolygon.i +8 -0
- data/bindings/bullet/interface/BulletCollision/Gimpact/btContactProcessing.i +8 -0
- data/bindings/bullet/interface/BulletCollision/Gimpact/btGImpactBvh.i +8 -0
- data/bindings/bullet/interface/BulletCollision/Gimpact/btGImpactCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletCollision/Gimpact/btGImpactMassUtil.i +8 -0
- data/bindings/bullet/interface/BulletCollision/Gimpact/btGImpactQuantizedBvh.i +8 -0
- data/bindings/bullet/interface/BulletCollision/Gimpact/btGImpactShape.i +8 -0
- data/bindings/bullet/interface/BulletCollision/Gimpact/btGenericPoolAllocator.i +11 -0
- data/bindings/bullet/interface/BulletCollision/Gimpact/btGeometryOperations.i +8 -0
- data/bindings/bullet/interface/BulletCollision/Gimpact/btQuantization.i +8 -0
- data/bindings/bullet/interface/BulletCollision/Gimpact/btTriangleShapeEx.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btContinuousConvexCollision.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btConvexCast.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btConvexPenetrationDepthSolver.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btDiscreteCollisionDetectorInterface.i +11 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btGjkConvexCast.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btGjkEpa2.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btGjkEpaPenetrationDepthSolver.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btGjkPairDetector.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btManifoldPoint.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btMinkowskiPenetrationDepthSolver.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btPersistentManifold.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btPointCollector.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btPolyhedralContactClipping.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btRaycastCallback.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btSimplexSolverInterface.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btSubSimplexConvexCast.i +8 -0
- data/bindings/bullet/interface/BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/Character/btCharacterControllerInterface.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/Character/btKinematicCharacterController.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btConeTwistConstraint.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btConstraintSolver.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btContactConstraint.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btContactSolverInfo.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btGeneric6DofConstraint.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btGeneric6DofSpringConstraint.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btHinge2Constraint.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btHingeConstraint.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btJacobianEntry.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btPoint2PointConstraint.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btSequentialImpulseConstraintSolver.i +21 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btSliderConstraint.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btSolve2LinearConstraint.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btSolverBody.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btSolverConstraint.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btTypedConstraint.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/ConstraintSolver/btUniversalConstraint.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/Dynamics/btActionInterface.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/Dynamics/btDiscreteDynamicsWorld.i +23 -0
- data/bindings/bullet/interface/BulletDynamics/Dynamics/btDynamicsWorld.i +37 -0
- data/bindings/bullet/interface/BulletDynamics/Dynamics/btRigidBody.i +20 -0
- data/bindings/bullet/interface/BulletDynamics/Dynamics/btSimpleDynamicsWorld.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/Vehicle/btRaycastVehicle.i +12 -0
- data/bindings/bullet/interface/BulletDynamics/Vehicle/btVehicleRaycaster.i +8 -0
- data/bindings/bullet/interface/BulletDynamics/Vehicle/btWheelInfo.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btDefaultSoftBodySolver.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btSoftBody.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btSoftBodyConcaveCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btSoftBodyData.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btSoftBodyHelpers.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btSoftBodyInternals.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btSoftBodyRigidBodyCollisionConfiguration.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btSoftBodySolverVertexBuffer.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btSoftBodySolvers.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btSoftRigidCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btSoftRigidDynamicsWorld.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btSoftSoftCollisionAlgorithm.i +8 -0
- data/bindings/bullet/interface/BulletSoftBody/btSparseSDF.i +8 -0
- data/bindings/bullet/interface/LinearMath/btAabbUtil2.i +8 -0
- data/bindings/bullet/interface/LinearMath/btAlignedAllocator.i +8 -0
- data/bindings/bullet/interface/LinearMath/btAlignedObjectArray.i +8 -0
- data/bindings/bullet/interface/LinearMath/btConvexHull.i +8 -0
- data/bindings/bullet/interface/LinearMath/btConvexHullComputer.i +8 -0
- data/bindings/bullet/interface/LinearMath/btDefaultMotionState.i +10 -0
- data/bindings/bullet/interface/LinearMath/btGeometryUtil.i +10 -0
- data/bindings/bullet/interface/LinearMath/btGrahamScan2dConvexHull.i +8 -0
- data/bindings/bullet/interface/LinearMath/btHashMap.i +8 -0
- data/bindings/bullet/interface/LinearMath/btIDebugDraw.i +10 -0
- data/bindings/bullet/interface/LinearMath/btList.i +8 -0
- data/bindings/bullet/interface/LinearMath/btMatrix3x3.i +8 -0
- data/bindings/bullet/interface/LinearMath/btMinMax.i +8 -0
- data/bindings/bullet/interface/LinearMath/btMotionState.i +10 -0
- data/bindings/bullet/interface/LinearMath/btPoolAllocator.i +10 -0
- data/bindings/bullet/interface/LinearMath/btQuadWord.i +8 -0
- data/bindings/bullet/interface/LinearMath/btQuaternion.i +60 -0
- data/bindings/bullet/interface/LinearMath/btQuickprof.i +10 -0
- data/bindings/bullet/interface/LinearMath/btRandom.i +8 -0
- data/bindings/bullet/interface/LinearMath/btScalar.i +8 -0
- data/bindings/bullet/interface/LinearMath/btSerializer.i +10 -0
- data/bindings/bullet/interface/LinearMath/btStackAlloc.i +10 -0
- data/bindings/bullet/interface/LinearMath/btTransform.i +8 -0
- data/bindings/bullet/interface/LinearMath/btTransformUtil.i +8 -0
- data/bindings/bullet/interface/LinearMath/btVector3.i +42 -0
- data/bindings/bullet/interface/Makefile +19 -0
- data/bindings/bullet/interface/bullet.i +9 -0
- data/bindings/bullet/interface/bullet_all.i +186 -0
- data/bindings/bullet/interface/bullet_wrap.cpp +194161 -0
- data/bindings/bullet/interface/bullet_wrap.h +106 -0
- data/bindings/bullet/interface/bullet_wrap.o +0 -0
- data/bindings/bullet/src/TickListener.h +22 -0
- data/deps/include/bullet/Bullet-C-Api.h +176 -0
- data/deps/include/bullet/BulletCollision/BroadphaseCollision/btAxisSweep3.h +1051 -0
- data/deps/include/bullet/BulletCollision/BroadphaseCollision/btBroadphaseInterface.h +82 -0
- data/deps/include/bullet/BulletCollision/BroadphaseCollision/btBroadphaseProxy.h +270 -0
- data/deps/include/bullet/BulletCollision/BroadphaseCollision/btCollisionAlgorithm.h +80 -0
- data/deps/include/bullet/BulletCollision/BroadphaseCollision/btDbvt.h +1257 -0
- data/deps/include/bullet/BulletCollision/BroadphaseCollision/btDbvtBroadphase.h +146 -0
- data/deps/include/bullet/BulletCollision/BroadphaseCollision/btDispatcher.h +110 -0
- data/deps/include/bullet/BulletCollision/BroadphaseCollision/btMultiSapBroadphase.h +151 -0
- data/deps/include/bullet/BulletCollision/BroadphaseCollision/btOverlappingPairCache.h +469 -0
- data/deps/include/bullet/BulletCollision/BroadphaseCollision/btOverlappingPairCallback.h +40 -0
- data/deps/include/bullet/BulletCollision/BroadphaseCollision/btQuantizedBvh.h +579 -0
- data/deps/include/bullet/BulletCollision/BroadphaseCollision/btSimpleBroadphase.h +171 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/SphereTriangleDetector.h +51 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btActivatingCollisionAlgorithm.h +36 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btBox2dBox2dCollisionAlgorithm.h +66 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btBoxBoxCollisionAlgorithm.h +66 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btBoxBoxDetector.h +44 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btCollisionConfiguration.h +48 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btCollisionCreateFunc.h +45 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btCollisionDispatcher.h +172 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btCollisionObject.h +524 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btCollisionWorld.h +509 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btCompoundCollisionAlgorithm.h +86 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btConvex2dConvex2dAlgorithm.h +95 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btConvexConcaveCollisionAlgorithm.h +116 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btConvexConvexAlgorithm.h +109 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btConvexPlaneCollisionAlgorithm.h +84 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btDefaultCollisionConfiguration.h +137 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btEmptyCollisionAlgorithm.h +54 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btGhostObject.h +175 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btInternalEdgeUtility.h +46 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btManifoldResult.h +128 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btSimulationIslandManager.h +81 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btSphereBoxCollisionAlgorithm.h +75 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btSphereSphereCollisionAlgorithm.h +66 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btSphereTriangleCollisionAlgorithm.h +69 -0
- data/deps/include/bullet/BulletCollision/CollisionDispatch/btUnionFind.h +129 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btBox2dShape.h +369 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btBoxShape.h +312 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btBvhTriangleMeshShape.h +139 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btCapsuleShape.h +173 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btCollisionMargin.h +27 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btCollisionShape.h +150 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btCompoundShape.h +212 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btConcaveShape.h +60 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btConeShape.h +103 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btConvex2dShape.h +80 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btConvexHullShape.h +122 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btConvexInternalShape.h +224 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btConvexPointCloudShape.h +105 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btConvexPolyhedron.h +62 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btConvexShape.h +84 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btConvexTriangleMeshShape.h +75 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btCylinderShape.h +200 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btEmptyShape.h +70 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btHeightfieldTerrainShape.h +161 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btMaterial.h +35 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btMinkowskiSumShape.h +60 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btMultiSphereShape.h +99 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btMultimaterialTriangleMeshShape.h +120 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btOptimizedBvh.h +65 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btPolyhedralConvexShape.h +112 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btScaledBvhTriangleMeshShape.h +93 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btShapeHull.h +59 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btSphereShape.h +73 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btStaticPlaneShape.h +103 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btStridingMeshInterface.h +162 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btTetrahedronShape.h +74 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btTriangleBuffer.h +69 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btTriangleCallback.h +42 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btTriangleIndexVertexArray.h +133 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btTriangleIndexVertexMaterialArray.h +84 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btTriangleInfoMap.h +241 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btTriangleMesh.h +69 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btTriangleMeshShape.h +89 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btTriangleShape.h +182 -0
- data/deps/include/bullet/BulletCollision/CollisionShapes/btUniformScalingShape.h +87 -0
- data/deps/include/bullet/BulletCollision/Gimpact/btBoxCollision.h +647 -0
- data/deps/include/bullet/BulletCollision/Gimpact/btClipPolygon.h +182 -0
- data/deps/include/bullet/BulletCollision/Gimpact/btContactProcessing.h +145 -0
- data/deps/include/bullet/BulletCollision/Gimpact/btGImpactBvh.h +396 -0
- data/deps/include/bullet/BulletCollision/Gimpact/btGImpactCollisionAlgorithm.h +306 -0
- data/deps/include/bullet/BulletCollision/Gimpact/btGImpactMassUtil.h +60 -0
- data/deps/include/bullet/BulletCollision/Gimpact/btGImpactQuantizedBvh.h +372 -0
- data/deps/include/bullet/BulletCollision/Gimpact/btGImpactShape.h +1171 -0
- data/deps/include/bullet/BulletCollision/Gimpact/btGenericPoolAllocator.h +163 -0
- data/deps/include/bullet/BulletCollision/Gimpact/btGeometryOperations.h +212 -0
- data/deps/include/bullet/BulletCollision/Gimpact/btQuantization.h +88 -0
- data/deps/include/bullet/BulletCollision/Gimpact/btTriangleShapeEx.h +180 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_array.h +326 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_basic_geometry_operations.h +543 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_bitset.h +123 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_box_collision.h +590 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_box_set.h +674 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_clip_polygon.h +210 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_contact.h +164 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_geom_types.h +97 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_geometry.h +42 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_hash_table.h +902 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_linear_math.h +1573 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_math.h +157 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_memory.h +190 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_radixsort.h +406 -0
- data/deps/include/bullet/BulletCollision/Gimpact/gim_tri_collision.h +379 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btContinuousConvexCollision.h +59 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btConvexCast.h +73 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btConvexPenetrationDepthSolver.h +42 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btDiscreteCollisionDetectorInterface.h +91 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btGjkConvexCast.h +50 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btGjkEpa2.h +75 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btGjkEpaPenetrationDepthSolver.h +43 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btGjkPairDetector.h +103 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btManifoldPoint.h +158 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btMinkowskiPenetrationDepthSolver.h +40 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btPersistentManifold.h +228 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btPointCollector.h +64 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btPolyhedralContactClipping.h +46 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btRaycastCallback.h +72 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btSimplexSolverInterface.h +63 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btSubSimplexConvexCast.h +50 -0
- data/deps/include/bullet/BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h +179 -0
- data/deps/include/bullet/BulletCollision/btBulletCollisionCommon.h +69 -0
- data/deps/include/bullet/BulletDynamics/Character/btCharacterControllerInterface.h +46 -0
- data/deps/include/bullet/BulletDynamics/Character/btKinematicCharacterController.h +163 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btConeTwistConstraint.h +346 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btConstraintSolver.h +52 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btContactConstraint.h +71 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btContactSolverInfo.h +87 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btGeneric6DofConstraint.h +614 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btGeneric6DofSpringConstraint.h +99 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btHinge2Constraint.h +58 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btHingeConstraint.h +381 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btJacobianEntry.h +156 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btPoint2PointConstraint.h +161 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btSequentialImpulseConstraintSolver.h +130 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btSliderConstraint.h +333 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btSolve2LinearConstraint.h +107 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btSolverBody.h +191 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btSolverConstraint.h +98 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btTypedConstraint.h +452 -0
- data/deps/include/bullet/BulletDynamics/ConstraintSolver/btUniversalConstraint.h +62 -0
- data/deps/include/bullet/BulletDynamics/Dynamics/btActionInterface.h +46 -0
- data/deps/include/bullet/BulletDynamics/Dynamics/btDiscreteDynamicsWorld.h +203 -0
- data/deps/include/bullet/BulletDynamics/Dynamics/btDynamicsWorld.h +151 -0
- data/deps/include/bullet/BulletDynamics/Dynamics/btRigidBody.h +691 -0
- data/deps/include/bullet/BulletDynamics/Dynamics/btSimpleDynamicsWorld.h +89 -0
- data/deps/include/bullet/BulletDynamics/Vehicle/btRaycastVehicle.h +236 -0
- data/deps/include/bullet/BulletDynamics/Vehicle/btVehicleRaycaster.h +35 -0
- data/deps/include/bullet/BulletDynamics/Vehicle/btWheelInfo.h +119 -0
- data/deps/include/bullet/BulletDynamics/btBulletDynamicsCommon.h +48 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/DX11/btSoftBodySolverBuffer_DX11.h +323 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/DX11/btSoftBodySolverLinkData_DX11.h +103 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/DX11/btSoftBodySolverLinkData_DX11SIMDAware.h +173 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/DX11/btSoftBodySolverTriangleData_DX11.h +96 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/DX11/btSoftBodySolverVertexBuffer_DX11.h +107 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/DX11/btSoftBodySolverVertexData_DX11.h +63 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/DX11/btSoftBodySolver_DX11.h +691 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/DX11/btSoftBodySolver_DX11SIMDAware.h +81 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/btSoftBodySolverBuffer_OpenCL.h +209 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/btSoftBodySolverLinkData_OpenCL.h +99 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/btSoftBodySolverLinkData_OpenCLSIMDAware.h +169 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/btSoftBodySolverOutputCLtoGL.h +62 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/btSoftBodySolverTriangleData_OpenCL.h +84 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/btSoftBodySolverVertexBuffer_OpenGL.h +166 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/btSoftBodySolverVertexData_OpenCL.h +52 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/btSoftBodySolver_OpenCL.h +527 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/btSoftBodySolver_OpenCLSIMDAware.h +81 -0
- data/deps/include/bullet/BulletMultiThreaded/GpuSoftBodySolvers/Shared/btSoftBodySolverData.h +748 -0
- data/deps/include/bullet/BulletMultiThreaded/HeapManager.h +117 -0
- data/deps/include/bullet/BulletMultiThreaded/PlatformDefinitions.h +99 -0
- data/deps/include/bullet/BulletMultiThreaded/PosixThreadSupport.h +142 -0
- data/deps/include/bullet/BulletMultiThreaded/PpuAddressSpace.h +37 -0
- data/deps/include/bullet/BulletMultiThreaded/SequentialThreadSupport.h +96 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuCollisionObjectWrapper.h +40 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuCollisionTaskProcess.h +163 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuContactManifoldCollisionAlgorithm.h +120 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuDoubleBuffer.h +126 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuFakeDma.h +135 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuGatheringCollisionDispatcher.h +72 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuLibspe2Support.h +180 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/Box.h +167 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuCollisionShapes.h +128 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuContactResult.h +106 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuConvexPenetrationDepthSolver.h +51 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuGatheringCollisionTask.h +140 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuLocalSupport.h +19 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuMinkowskiPenetrationDepthSolver.h +48 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuPreferredPenetrationDirections.h +70 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/boxBoxDistance.h +65 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuSampleTask/SpuSampleTask.h +54 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuSampleTaskProcess.h +153 -0
- data/deps/include/bullet/BulletMultiThreaded/SpuSync.h +149 -0
- data/deps/include/bullet/BulletMultiThreaded/TrbDynBody.h +79 -0
- data/deps/include/bullet/BulletMultiThreaded/TrbStateVec.h +339 -0
- data/deps/include/bullet/BulletMultiThreaded/Win32ThreadSupport.h +138 -0
- data/deps/include/bullet/BulletMultiThreaded/btGpu3DGridBroadphase.h +138 -0
- data/deps/include/bullet/BulletMultiThreaded/btGpu3DGridBroadphaseSharedCode.h +430 -0
- data/deps/include/bullet/BulletMultiThreaded/btGpu3DGridBroadphaseSharedDefs.h +61 -0
- data/deps/include/bullet/BulletMultiThreaded/btGpu3DGridBroadphaseSharedTypes.h +67 -0
- data/deps/include/bullet/BulletMultiThreaded/btGpuDefines.h +211 -0
- data/deps/include/bullet/BulletMultiThreaded/btGpuUtilsSharedCode.h +55 -0
- data/deps/include/bullet/BulletMultiThreaded/btGpuUtilsSharedDefs.h +52 -0
- data/deps/include/bullet/BulletMultiThreaded/btParallelConstraintSolver.h +285 -0
- data/deps/include/bullet/BulletMultiThreaded/btThreadSupportInterface.h +85 -0
- data/deps/include/bullet/BulletMultiThreaded/vectormath2bullet.h +73 -0
- data/deps/include/bullet/BulletSoftBody/btDefaultSoftBodySolver.h +63 -0
- data/deps/include/bullet/BulletSoftBody/btSoftBody.h +987 -0
- data/deps/include/bullet/BulletSoftBody/btSoftBodyConcaveCollisionAlgorithm.h +153 -0
- data/deps/include/bullet/BulletSoftBody/btSoftBodyData.h +217 -0
- data/deps/include/bullet/BulletSoftBody/btSoftBodyHelpers.h +143 -0
- data/deps/include/bullet/BulletSoftBody/btSoftBodyInternals.h +930 -0
- data/deps/include/bullet/BulletSoftBody/btSoftBodyRigidBodyCollisionConfiguration.h +48 -0
- data/deps/include/bullet/BulletSoftBody/btSoftBodySolverVertexBuffer.h +165 -0
- data/deps/include/bullet/BulletSoftBody/btSoftBodySolvers.h +154 -0
- data/deps/include/bullet/BulletSoftBody/btSoftRigidCollisionAlgorithm.h +75 -0
- data/deps/include/bullet/BulletSoftBody/btSoftRigidDynamicsWorld.h +107 -0
- data/deps/include/bullet/BulletSoftBody/btSoftSoftCollisionAlgorithm.h +69 -0
- data/deps/include/bullet/BulletSoftBody/btSparseSDF.h +306 -0
- data/deps/include/bullet/LinearMath/btAabbUtil2.h +236 -0
- data/deps/include/bullet/LinearMath/btAlignedAllocator.h +107 -0
- data/deps/include/bullet/LinearMath/btAlignedObjectArray.h +494 -0
- data/deps/include/bullet/LinearMath/btConvexHull.h +241 -0
- data/deps/include/bullet/LinearMath/btConvexHullComputer.h +103 -0
- data/deps/include/bullet/LinearMath/btDefaultMotionState.h +40 -0
- data/deps/include/bullet/LinearMath/btGeometryUtil.h +42 -0
- data/deps/include/bullet/LinearMath/btGrahamScan2dConvexHull.h +110 -0
- data/deps/include/bullet/LinearMath/btHashMap.h +450 -0
- data/deps/include/bullet/LinearMath/btIDebugDraw.h +418 -0
- data/deps/include/bullet/LinearMath/btList.h +73 -0
- data/deps/include/bullet/LinearMath/btMatrix3x3.h +771 -0
- data/deps/include/bullet/LinearMath/btMinMax.h +71 -0
- data/deps/include/bullet/LinearMath/btMotionState.h +40 -0
- data/deps/include/bullet/LinearMath/btPoolAllocator.h +121 -0
- data/deps/include/bullet/LinearMath/btQuadWord.h +180 -0
- data/deps/include/bullet/LinearMath/btQuaternion.h +430 -0
- data/deps/include/bullet/LinearMath/btQuickprof.h +203 -0
- data/deps/include/bullet/LinearMath/btRandom.h +42 -0
- data/deps/include/bullet/LinearMath/btScalar.h +539 -0
- data/deps/include/bullet/LinearMath/btSerializer.h +639 -0
- data/deps/include/bullet/LinearMath/btStackAlloc.h +116 -0
- data/deps/include/bullet/LinearMath/btTransform.h +307 -0
- data/deps/include/bullet/LinearMath/btTransformUtil.h +228 -0
- data/deps/include/bullet/LinearMath/btVector3.h +766 -0
- data/deps/include/bullet/MiniCL/MiniCLTask/MiniCLTask.h +62 -0
- data/deps/include/bullet/MiniCL/MiniCLTaskScheduler.h +194 -0
- data/deps/include/bullet/MiniCL/cl.h +867 -0
- data/deps/include/bullet/MiniCL/cl_MiniCL_Defs.h +439 -0
- data/deps/include/bullet/MiniCL/cl_gl.h +113 -0
- data/deps/include/bullet/MiniCL/cl_platform.h +254 -0
- data/deps/include/bullet/btBulletCollisionCommon.h +69 -0
- data/deps/include/bullet/btBulletDynamicsCommon.h +48 -0
- data/deps/include/bullet/vectormath/scalar/boolInVec.h +225 -0
- data/deps/include/bullet/vectormath/scalar/floatInVec.h +343 -0
- data/deps/include/bullet/vectormath/scalar/mat_aos.h +1630 -0
- data/deps/include/bullet/vectormath/scalar/quat_aos.h +433 -0
- data/deps/include/bullet/vectormath/scalar/vec_aos.h +1426 -0
- data/deps/include/bullet/vectormath/scalar/vectormath_aos.h +1872 -0
- data/deps/include/bullet/vectormath/sse/boolInVec.h +247 -0
- data/deps/include/bullet/vectormath/sse/floatInVec.h +340 -0
- data/deps/include/bullet/vectormath/sse/mat_aos.h +2190 -0
- data/deps/include/bullet/vectormath/sse/quat_aos.h +579 -0
- data/deps/include/bullet/vectormath/sse/vec_aos.h +1455 -0
- data/deps/include/bullet/vectormath/sse/vecidx_aos.h +80 -0
- data/deps/include/bullet/vectormath/sse/vectormath_aos.h +2547 -0
- data/deps/include/bullet/vectormath/vmInclude.h +27 -0
- data/deps/lib/libBulletCollision.a +0 -0
- data/deps/lib/libBulletDynamics.a +0 -0
- data/deps/lib/libBulletMultiThreaded.a +0 -0
- data/deps/lib/libBulletSoftBody.a +0 -0
- data/deps/lib/libBulletSoftBodySolvers_OpenCL_Mini.a +0 -0
- data/deps/lib/libLinearMath.a +0 -0
- data/deps/lib/libMiniCL.a +0 -0
- data/lib/Bullet.so +0 -0
- data/lib/BulletConfig.rb +28 -0
- data/lib/Version.rb +5 -0
- data/sample/hello_bullet/HelloBullet.rb +144 -0
- metadata +504 -0
@@ -0,0 +1,590 @@
|
|
1
|
+
#ifndef GIM_BOX_COLLISION_H_INCLUDED
|
2
|
+
#define GIM_BOX_COLLISION_H_INCLUDED
|
3
|
+
|
4
|
+
/*! \file gim_box_collision.h
|
5
|
+
\author Francisco Leon Najera
|
6
|
+
*/
|
7
|
+
/*
|
8
|
+
-----------------------------------------------------------------------------
|
9
|
+
This source file is part of GIMPACT Library.
|
10
|
+
|
11
|
+
For the latest info, see http://gimpact.sourceforge.net/
|
12
|
+
|
13
|
+
Copyright (c) 2006 Francisco Leon Najera. C.C. 80087371.
|
14
|
+
email: projectileman@yahoo.com
|
15
|
+
|
16
|
+
This library is free software; you can redistribute it and/or
|
17
|
+
modify it under the terms of EITHER:
|
18
|
+
(1) The GNU Lesser General Public License as published by the Free
|
19
|
+
Software Foundation; either version 2.1 of the License, or (at
|
20
|
+
your option) any later version. The text of the GNU Lesser
|
21
|
+
General Public License is included with this library in the
|
22
|
+
file GIMPACT-LICENSE-LGPL.TXT.
|
23
|
+
(2) The BSD-style license that is included with this library in
|
24
|
+
the file GIMPACT-LICENSE-BSD.TXT.
|
25
|
+
(3) The zlib/libpng license that is included with this library in
|
26
|
+
the file GIMPACT-LICENSE-ZLIB.TXT.
|
27
|
+
|
28
|
+
This library is distributed in the hope that it will be useful,
|
29
|
+
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
30
|
+
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the files
|
31
|
+
GIMPACT-LICENSE-LGPL.TXT, GIMPACT-LICENSE-ZLIB.TXT and GIMPACT-LICENSE-BSD.TXT for more details.
|
32
|
+
|
33
|
+
-----------------------------------------------------------------------------
|
34
|
+
*/
|
35
|
+
#include "gim_basic_geometry_operations.h"
|
36
|
+
#include "LinearMath/btTransform.h"
|
37
|
+
|
38
|
+
|
39
|
+
|
40
|
+
//SIMD_FORCE_INLINE bool test_cross_edge_box(
|
41
|
+
// const btVector3 & edge,
|
42
|
+
// const btVector3 & absolute_edge,
|
43
|
+
// const btVector3 & pointa,
|
44
|
+
// const btVector3 & pointb, const btVector3 & extend,
|
45
|
+
// int dir_index0,
|
46
|
+
// int dir_index1
|
47
|
+
// int component_index0,
|
48
|
+
// int component_index1)
|
49
|
+
//{
|
50
|
+
// // dir coords are -z and y
|
51
|
+
//
|
52
|
+
// const btScalar dir0 = -edge[dir_index0];
|
53
|
+
// const btScalar dir1 = edge[dir_index1];
|
54
|
+
// btScalar pmin = pointa[component_index0]*dir0 + pointa[component_index1]*dir1;
|
55
|
+
// btScalar pmax = pointb[component_index0]*dir0 + pointb[component_index1]*dir1;
|
56
|
+
// //find minmax
|
57
|
+
// if(pmin>pmax)
|
58
|
+
// {
|
59
|
+
// GIM_SWAP_NUMBERS(pmin,pmax);
|
60
|
+
// }
|
61
|
+
// //find extends
|
62
|
+
// const btScalar rad = extend[component_index0] * absolute_edge[dir_index0] +
|
63
|
+
// extend[component_index1] * absolute_edge[dir_index1];
|
64
|
+
//
|
65
|
+
// if(pmin>rad || -rad>pmax) return false;
|
66
|
+
// return true;
|
67
|
+
//}
|
68
|
+
//
|
69
|
+
//SIMD_FORCE_INLINE bool test_cross_edge_box_X_axis(
|
70
|
+
// const btVector3 & edge,
|
71
|
+
// const btVector3 & absolute_edge,
|
72
|
+
// const btVector3 & pointa,
|
73
|
+
// const btVector3 & pointb, btVector3 & extend)
|
74
|
+
//{
|
75
|
+
//
|
76
|
+
// return test_cross_edge_box(edge,absolute_edge,pointa,pointb,extend,2,1,1,2);
|
77
|
+
//}
|
78
|
+
//
|
79
|
+
//
|
80
|
+
//SIMD_FORCE_INLINE bool test_cross_edge_box_Y_axis(
|
81
|
+
// const btVector3 & edge,
|
82
|
+
// const btVector3 & absolute_edge,
|
83
|
+
// const btVector3 & pointa,
|
84
|
+
// const btVector3 & pointb, btVector3 & extend)
|
85
|
+
//{
|
86
|
+
//
|
87
|
+
// return test_cross_edge_box(edge,absolute_edge,pointa,pointb,extend,0,2,2,0);
|
88
|
+
//}
|
89
|
+
//
|
90
|
+
//SIMD_FORCE_INLINE bool test_cross_edge_box_Z_axis(
|
91
|
+
// const btVector3 & edge,
|
92
|
+
// const btVector3 & absolute_edge,
|
93
|
+
// const btVector3 & pointa,
|
94
|
+
// const btVector3 & pointb, btVector3 & extend)
|
95
|
+
//{
|
96
|
+
//
|
97
|
+
// return test_cross_edge_box(edge,absolute_edge,pointa,pointb,extend,1,0,0,1);
|
98
|
+
//}
|
99
|
+
|
100
|
+
#define TEST_CROSS_EDGE_BOX_MCR(edge,absolute_edge,pointa,pointb,_extend,i_dir_0,i_dir_1,i_comp_0,i_comp_1)\
|
101
|
+
{\
|
102
|
+
const btScalar dir0 = -edge[i_dir_0];\
|
103
|
+
const btScalar dir1 = edge[i_dir_1];\
|
104
|
+
btScalar pmin = pointa[i_comp_0]*dir0 + pointa[i_comp_1]*dir1;\
|
105
|
+
btScalar pmax = pointb[i_comp_0]*dir0 + pointb[i_comp_1]*dir1;\
|
106
|
+
if(pmin>pmax)\
|
107
|
+
{\
|
108
|
+
GIM_SWAP_NUMBERS(pmin,pmax); \
|
109
|
+
}\
|
110
|
+
const btScalar abs_dir0 = absolute_edge[i_dir_0];\
|
111
|
+
const btScalar abs_dir1 = absolute_edge[i_dir_1];\
|
112
|
+
const btScalar rad = _extend[i_comp_0] * abs_dir0 + _extend[i_comp_1] * abs_dir1;\
|
113
|
+
if(pmin>rad || -rad>pmax) return false;\
|
114
|
+
}\
|
115
|
+
|
116
|
+
|
117
|
+
#define TEST_CROSS_EDGE_BOX_X_AXIS_MCR(edge,absolute_edge,pointa,pointb,_extend)\
|
118
|
+
{\
|
119
|
+
TEST_CROSS_EDGE_BOX_MCR(edge,absolute_edge,pointa,pointb,_extend,2,1,1,2);\
|
120
|
+
}\
|
121
|
+
|
122
|
+
#define TEST_CROSS_EDGE_BOX_Y_AXIS_MCR(edge,absolute_edge,pointa,pointb,_extend)\
|
123
|
+
{\
|
124
|
+
TEST_CROSS_EDGE_BOX_MCR(edge,absolute_edge,pointa,pointb,_extend,0,2,2,0);\
|
125
|
+
}\
|
126
|
+
|
127
|
+
#define TEST_CROSS_EDGE_BOX_Z_AXIS_MCR(edge,absolute_edge,pointa,pointb,_extend)\
|
128
|
+
{\
|
129
|
+
TEST_CROSS_EDGE_BOX_MCR(edge,absolute_edge,pointa,pointb,_extend,1,0,0,1);\
|
130
|
+
}\
|
131
|
+
|
132
|
+
|
133
|
+
|
134
|
+
//! Class for transforming a model1 to the space of model0
|
135
|
+
class GIM_BOX_BOX_TRANSFORM_CACHE
|
136
|
+
{
|
137
|
+
public:
|
138
|
+
btVector3 m_T1to0;//!< Transforms translation of model1 to model 0
|
139
|
+
btMatrix3x3 m_R1to0;//!< Transforms Rotation of model1 to model 0, equal to R0' * R1
|
140
|
+
btMatrix3x3 m_AR;//!< Absolute value of m_R1to0
|
141
|
+
|
142
|
+
SIMD_FORCE_INLINE void calc_absolute_matrix()
|
143
|
+
{
|
144
|
+
static const btVector3 vepsi(1e-6f,1e-6f,1e-6f);
|
145
|
+
m_AR[0] = vepsi + m_R1to0[0].absolute();
|
146
|
+
m_AR[1] = vepsi + m_R1to0[1].absolute();
|
147
|
+
m_AR[2] = vepsi + m_R1to0[2].absolute();
|
148
|
+
}
|
149
|
+
|
150
|
+
GIM_BOX_BOX_TRANSFORM_CACHE()
|
151
|
+
{
|
152
|
+
}
|
153
|
+
|
154
|
+
|
155
|
+
GIM_BOX_BOX_TRANSFORM_CACHE(mat4f trans1_to_0)
|
156
|
+
{
|
157
|
+
COPY_MATRIX_3X3(m_R1to0,trans1_to_0)
|
158
|
+
MAT_GET_TRANSLATION(trans1_to_0,m_T1to0)
|
159
|
+
calc_absolute_matrix();
|
160
|
+
}
|
161
|
+
|
162
|
+
//! Calc the transformation relative 1 to 0. Inverts matrics by transposing
|
163
|
+
SIMD_FORCE_INLINE void calc_from_homogenic(const btTransform & trans0,const btTransform & trans1)
|
164
|
+
{
|
165
|
+
|
166
|
+
m_R1to0 = trans0.getBasis().transpose();
|
167
|
+
m_T1to0 = m_R1to0 * (-trans0.getOrigin());
|
168
|
+
|
169
|
+
m_T1to0 += m_R1to0*trans1.getOrigin();
|
170
|
+
m_R1to0 *= trans1.getBasis();
|
171
|
+
|
172
|
+
calc_absolute_matrix();
|
173
|
+
}
|
174
|
+
|
175
|
+
//! Calcs the full invertion of the matrices. Useful for scaling matrices
|
176
|
+
SIMD_FORCE_INLINE void calc_from_full_invert(const btTransform & trans0,const btTransform & trans1)
|
177
|
+
{
|
178
|
+
m_R1to0 = trans0.getBasis().inverse();
|
179
|
+
m_T1to0 = m_R1to0 * (-trans0.getOrigin());
|
180
|
+
|
181
|
+
m_T1to0 += m_R1to0*trans1.getOrigin();
|
182
|
+
m_R1to0 *= trans1.getBasis();
|
183
|
+
|
184
|
+
calc_absolute_matrix();
|
185
|
+
}
|
186
|
+
|
187
|
+
SIMD_FORCE_INLINE btVector3 transform(const btVector3 & point)
|
188
|
+
{
|
189
|
+
return btVector3(m_R1to0[0].dot(point) + m_T1to0.x(),
|
190
|
+
m_R1to0[1].dot(point) + m_T1to0.y(),
|
191
|
+
m_R1to0[2].dot(point) + m_T1to0.z());
|
192
|
+
}
|
193
|
+
};
|
194
|
+
|
195
|
+
|
196
|
+
#define BOX_PLANE_EPSILON 0.000001f
|
197
|
+
|
198
|
+
//! Axis aligned box
|
199
|
+
class GIM_AABB
|
200
|
+
{
|
201
|
+
public:
|
202
|
+
btVector3 m_min;
|
203
|
+
btVector3 m_max;
|
204
|
+
|
205
|
+
GIM_AABB()
|
206
|
+
{}
|
207
|
+
|
208
|
+
|
209
|
+
GIM_AABB(const btVector3 & V1,
|
210
|
+
const btVector3 & V2,
|
211
|
+
const btVector3 & V3)
|
212
|
+
{
|
213
|
+
m_min[0] = GIM_MIN3(V1[0],V2[0],V3[0]);
|
214
|
+
m_min[1] = GIM_MIN3(V1[1],V2[1],V3[1]);
|
215
|
+
m_min[2] = GIM_MIN3(V1[2],V2[2],V3[2]);
|
216
|
+
|
217
|
+
m_max[0] = GIM_MAX3(V1[0],V2[0],V3[0]);
|
218
|
+
m_max[1] = GIM_MAX3(V1[1],V2[1],V3[1]);
|
219
|
+
m_max[2] = GIM_MAX3(V1[2],V2[2],V3[2]);
|
220
|
+
}
|
221
|
+
|
222
|
+
GIM_AABB(const btVector3 & V1,
|
223
|
+
const btVector3 & V2,
|
224
|
+
const btVector3 & V3,
|
225
|
+
GREAL margin)
|
226
|
+
{
|
227
|
+
m_min[0] = GIM_MIN3(V1[0],V2[0],V3[0]);
|
228
|
+
m_min[1] = GIM_MIN3(V1[1],V2[1],V3[1]);
|
229
|
+
m_min[2] = GIM_MIN3(V1[2],V2[2],V3[2]);
|
230
|
+
|
231
|
+
m_max[0] = GIM_MAX3(V1[0],V2[0],V3[0]);
|
232
|
+
m_max[1] = GIM_MAX3(V1[1],V2[1],V3[1]);
|
233
|
+
m_max[2] = GIM_MAX3(V1[2],V2[2],V3[2]);
|
234
|
+
|
235
|
+
m_min[0] -= margin;
|
236
|
+
m_min[1] -= margin;
|
237
|
+
m_min[2] -= margin;
|
238
|
+
m_max[0] += margin;
|
239
|
+
m_max[1] += margin;
|
240
|
+
m_max[2] += margin;
|
241
|
+
}
|
242
|
+
|
243
|
+
GIM_AABB(const GIM_AABB &other):
|
244
|
+
m_min(other.m_min),m_max(other.m_max)
|
245
|
+
{
|
246
|
+
}
|
247
|
+
|
248
|
+
GIM_AABB(const GIM_AABB &other,btScalar margin ):
|
249
|
+
m_min(other.m_min),m_max(other.m_max)
|
250
|
+
{
|
251
|
+
m_min[0] -= margin;
|
252
|
+
m_min[1] -= margin;
|
253
|
+
m_min[2] -= margin;
|
254
|
+
m_max[0] += margin;
|
255
|
+
m_max[1] += margin;
|
256
|
+
m_max[2] += margin;
|
257
|
+
}
|
258
|
+
|
259
|
+
SIMD_FORCE_INLINE void invalidate()
|
260
|
+
{
|
261
|
+
m_min[0] = G_REAL_INFINITY;
|
262
|
+
m_min[1] = G_REAL_INFINITY;
|
263
|
+
m_min[2] = G_REAL_INFINITY;
|
264
|
+
m_max[0] = -G_REAL_INFINITY;
|
265
|
+
m_max[1] = -G_REAL_INFINITY;
|
266
|
+
m_max[2] = -G_REAL_INFINITY;
|
267
|
+
}
|
268
|
+
|
269
|
+
SIMD_FORCE_INLINE void increment_margin(btScalar margin)
|
270
|
+
{
|
271
|
+
m_min[0] -= margin;
|
272
|
+
m_min[1] -= margin;
|
273
|
+
m_min[2] -= margin;
|
274
|
+
m_max[0] += margin;
|
275
|
+
m_max[1] += margin;
|
276
|
+
m_max[2] += margin;
|
277
|
+
}
|
278
|
+
|
279
|
+
SIMD_FORCE_INLINE void copy_with_margin(const GIM_AABB &other, btScalar margin)
|
280
|
+
{
|
281
|
+
m_min[0] = other.m_min[0] - margin;
|
282
|
+
m_min[1] = other.m_min[1] - margin;
|
283
|
+
m_min[2] = other.m_min[2] - margin;
|
284
|
+
|
285
|
+
m_max[0] = other.m_max[0] + margin;
|
286
|
+
m_max[1] = other.m_max[1] + margin;
|
287
|
+
m_max[2] = other.m_max[2] + margin;
|
288
|
+
}
|
289
|
+
|
290
|
+
template<typename CLASS_POINT>
|
291
|
+
SIMD_FORCE_INLINE void calc_from_triangle(
|
292
|
+
const CLASS_POINT & V1,
|
293
|
+
const CLASS_POINT & V2,
|
294
|
+
const CLASS_POINT & V3)
|
295
|
+
{
|
296
|
+
m_min[0] = GIM_MIN3(V1[0],V2[0],V3[0]);
|
297
|
+
m_min[1] = GIM_MIN3(V1[1],V2[1],V3[1]);
|
298
|
+
m_min[2] = GIM_MIN3(V1[2],V2[2],V3[2]);
|
299
|
+
|
300
|
+
m_max[0] = GIM_MAX3(V1[0],V2[0],V3[0]);
|
301
|
+
m_max[1] = GIM_MAX3(V1[1],V2[1],V3[1]);
|
302
|
+
m_max[2] = GIM_MAX3(V1[2],V2[2],V3[2]);
|
303
|
+
}
|
304
|
+
|
305
|
+
template<typename CLASS_POINT>
|
306
|
+
SIMD_FORCE_INLINE void calc_from_triangle_margin(
|
307
|
+
const CLASS_POINT & V1,
|
308
|
+
const CLASS_POINT & V2,
|
309
|
+
const CLASS_POINT & V3, btScalar margin)
|
310
|
+
{
|
311
|
+
m_min[0] = GIM_MIN3(V1[0],V2[0],V3[0]);
|
312
|
+
m_min[1] = GIM_MIN3(V1[1],V2[1],V3[1]);
|
313
|
+
m_min[2] = GIM_MIN3(V1[2],V2[2],V3[2]);
|
314
|
+
|
315
|
+
m_max[0] = GIM_MAX3(V1[0],V2[0],V3[0]);
|
316
|
+
m_max[1] = GIM_MAX3(V1[1],V2[1],V3[1]);
|
317
|
+
m_max[2] = GIM_MAX3(V1[2],V2[2],V3[2]);
|
318
|
+
|
319
|
+
m_min[0] -= margin;
|
320
|
+
m_min[1] -= margin;
|
321
|
+
m_min[2] -= margin;
|
322
|
+
m_max[0] += margin;
|
323
|
+
m_max[1] += margin;
|
324
|
+
m_max[2] += margin;
|
325
|
+
}
|
326
|
+
|
327
|
+
//! Apply a transform to an AABB
|
328
|
+
SIMD_FORCE_INLINE void appy_transform(const btTransform & trans)
|
329
|
+
{
|
330
|
+
btVector3 center = (m_max+m_min)*0.5f;
|
331
|
+
btVector3 extends = m_max - center;
|
332
|
+
// Compute new center
|
333
|
+
center = trans(center);
|
334
|
+
|
335
|
+
btVector3 textends(extends.dot(trans.getBasis().getRow(0).absolute()),
|
336
|
+
extends.dot(trans.getBasis().getRow(1).absolute()),
|
337
|
+
extends.dot(trans.getBasis().getRow(2).absolute()));
|
338
|
+
|
339
|
+
m_min = center - textends;
|
340
|
+
m_max = center + textends;
|
341
|
+
}
|
342
|
+
|
343
|
+
//! Merges a Box
|
344
|
+
SIMD_FORCE_INLINE void merge(const GIM_AABB & box)
|
345
|
+
{
|
346
|
+
m_min[0] = GIM_MIN(m_min[0],box.m_min[0]);
|
347
|
+
m_min[1] = GIM_MIN(m_min[1],box.m_min[1]);
|
348
|
+
m_min[2] = GIM_MIN(m_min[2],box.m_min[2]);
|
349
|
+
|
350
|
+
m_max[0] = GIM_MAX(m_max[0],box.m_max[0]);
|
351
|
+
m_max[1] = GIM_MAX(m_max[1],box.m_max[1]);
|
352
|
+
m_max[2] = GIM_MAX(m_max[2],box.m_max[2]);
|
353
|
+
}
|
354
|
+
|
355
|
+
//! Merges a point
|
356
|
+
template<typename CLASS_POINT>
|
357
|
+
SIMD_FORCE_INLINE void merge_point(const CLASS_POINT & point)
|
358
|
+
{
|
359
|
+
m_min[0] = GIM_MIN(m_min[0],point[0]);
|
360
|
+
m_min[1] = GIM_MIN(m_min[1],point[1]);
|
361
|
+
m_min[2] = GIM_MIN(m_min[2],point[2]);
|
362
|
+
|
363
|
+
m_max[0] = GIM_MAX(m_max[0],point[0]);
|
364
|
+
m_max[1] = GIM_MAX(m_max[1],point[1]);
|
365
|
+
m_max[2] = GIM_MAX(m_max[2],point[2]);
|
366
|
+
}
|
367
|
+
|
368
|
+
//! Gets the extend and center
|
369
|
+
SIMD_FORCE_INLINE void get_center_extend(btVector3 & center,btVector3 & extend) const
|
370
|
+
{
|
371
|
+
center = (m_max+m_min)*0.5f;
|
372
|
+
extend = m_max - center;
|
373
|
+
}
|
374
|
+
|
375
|
+
//! Finds the intersecting box between this box and the other.
|
376
|
+
SIMD_FORCE_INLINE void find_intersection(const GIM_AABB & other, GIM_AABB & intersection) const
|
377
|
+
{
|
378
|
+
intersection.m_min[0] = GIM_MAX(other.m_min[0],m_min[0]);
|
379
|
+
intersection.m_min[1] = GIM_MAX(other.m_min[1],m_min[1]);
|
380
|
+
intersection.m_min[2] = GIM_MAX(other.m_min[2],m_min[2]);
|
381
|
+
|
382
|
+
intersection.m_max[0] = GIM_MIN(other.m_max[0],m_max[0]);
|
383
|
+
intersection.m_max[1] = GIM_MIN(other.m_max[1],m_max[1]);
|
384
|
+
intersection.m_max[2] = GIM_MIN(other.m_max[2],m_max[2]);
|
385
|
+
}
|
386
|
+
|
387
|
+
|
388
|
+
SIMD_FORCE_INLINE bool has_collision(const GIM_AABB & other) const
|
389
|
+
{
|
390
|
+
if(m_min[0] > other.m_max[0] ||
|
391
|
+
m_max[0] < other.m_min[0] ||
|
392
|
+
m_min[1] > other.m_max[1] ||
|
393
|
+
m_max[1] < other.m_min[1] ||
|
394
|
+
m_min[2] > other.m_max[2] ||
|
395
|
+
m_max[2] < other.m_min[2])
|
396
|
+
{
|
397
|
+
return false;
|
398
|
+
}
|
399
|
+
return true;
|
400
|
+
}
|
401
|
+
|
402
|
+
/*! \brief Finds the Ray intersection parameter.
|
403
|
+
\param aabb Aligned box
|
404
|
+
\param vorigin A vec3f with the origin of the ray
|
405
|
+
\param vdir A vec3f with the direction of the ray
|
406
|
+
*/
|
407
|
+
SIMD_FORCE_INLINE bool collide_ray(const btVector3 & vorigin,const btVector3 & vdir)
|
408
|
+
{
|
409
|
+
btVector3 extents,center;
|
410
|
+
this->get_center_extend(center,extents);;
|
411
|
+
|
412
|
+
btScalar Dx = vorigin[0] - center[0];
|
413
|
+
if(GIM_GREATER(Dx, extents[0]) && Dx*vdir[0]>=0.0f) return false;
|
414
|
+
btScalar Dy = vorigin[1] - center[1];
|
415
|
+
if(GIM_GREATER(Dy, extents[1]) && Dy*vdir[1]>=0.0f) return false;
|
416
|
+
btScalar Dz = vorigin[2] - center[2];
|
417
|
+
if(GIM_GREATER(Dz, extents[2]) && Dz*vdir[2]>=0.0f) return false;
|
418
|
+
|
419
|
+
|
420
|
+
btScalar f = vdir[1] * Dz - vdir[2] * Dy;
|
421
|
+
if(btFabs(f) > extents[1]*btFabs(vdir[2]) + extents[2]*btFabs(vdir[1])) return false;
|
422
|
+
f = vdir[2] * Dx - vdir[0] * Dz;
|
423
|
+
if(btFabs(f) > extents[0]*btFabs(vdir[2]) + extents[2]*btFabs(vdir[0]))return false;
|
424
|
+
f = vdir[0] * Dy - vdir[1] * Dx;
|
425
|
+
if(btFabs(f) > extents[0]*btFabs(vdir[1]) + extents[1]*btFabs(vdir[0]))return false;
|
426
|
+
return true;
|
427
|
+
}
|
428
|
+
|
429
|
+
|
430
|
+
SIMD_FORCE_INLINE void projection_interval(const btVector3 & direction, btScalar &vmin, btScalar &vmax) const
|
431
|
+
{
|
432
|
+
btVector3 center = (m_max+m_min)*0.5f;
|
433
|
+
btVector3 extend = m_max-center;
|
434
|
+
|
435
|
+
btScalar _fOrigin = direction.dot(center);
|
436
|
+
btScalar _fMaximumExtent = extend.dot(direction.absolute());
|
437
|
+
vmin = _fOrigin - _fMaximumExtent;
|
438
|
+
vmax = _fOrigin + _fMaximumExtent;
|
439
|
+
}
|
440
|
+
|
441
|
+
SIMD_FORCE_INLINE ePLANE_INTERSECTION_TYPE plane_classify(const btVector4 &plane) const
|
442
|
+
{
|
443
|
+
btScalar _fmin,_fmax;
|
444
|
+
this->projection_interval(plane,_fmin,_fmax);
|
445
|
+
|
446
|
+
if(plane[3] > _fmax + BOX_PLANE_EPSILON)
|
447
|
+
{
|
448
|
+
return G_BACK_PLANE; // 0
|
449
|
+
}
|
450
|
+
|
451
|
+
if(plane[3]+BOX_PLANE_EPSILON >=_fmin)
|
452
|
+
{
|
453
|
+
return G_COLLIDE_PLANE; //1
|
454
|
+
}
|
455
|
+
return G_FRONT_PLANE;//2
|
456
|
+
}
|
457
|
+
|
458
|
+
SIMD_FORCE_INLINE bool overlapping_trans_conservative(const GIM_AABB & box, btTransform & trans1_to_0)
|
459
|
+
{
|
460
|
+
GIM_AABB tbox = box;
|
461
|
+
tbox.appy_transform(trans1_to_0);
|
462
|
+
return has_collision(tbox);
|
463
|
+
}
|
464
|
+
|
465
|
+
//! transcache is the transformation cache from box to this AABB
|
466
|
+
SIMD_FORCE_INLINE bool overlapping_trans_cache(
|
467
|
+
const GIM_AABB & box,const GIM_BOX_BOX_TRANSFORM_CACHE & transcache, bool fulltest)
|
468
|
+
{
|
469
|
+
|
470
|
+
//Taken from OPCODE
|
471
|
+
btVector3 ea,eb;//extends
|
472
|
+
btVector3 ca,cb;//extends
|
473
|
+
get_center_extend(ca,ea);
|
474
|
+
box.get_center_extend(cb,eb);
|
475
|
+
|
476
|
+
|
477
|
+
btVector3 T;
|
478
|
+
btScalar t,t2;
|
479
|
+
int i;
|
480
|
+
|
481
|
+
// Class I : A's basis vectors
|
482
|
+
for(i=0;i<3;i++)
|
483
|
+
{
|
484
|
+
T[i] = transcache.m_R1to0[i].dot(cb) + transcache.m_T1to0[i] - ca[i];
|
485
|
+
t = transcache.m_AR[i].dot(eb) + ea[i];
|
486
|
+
if(GIM_GREATER(T[i], t)) return false;
|
487
|
+
}
|
488
|
+
// Class II : B's basis vectors
|
489
|
+
for(i=0;i<3;i++)
|
490
|
+
{
|
491
|
+
t = MAT_DOT_COL(transcache.m_R1to0,T,i);
|
492
|
+
t2 = MAT_DOT_COL(transcache.m_AR,ea,i) + eb[i];
|
493
|
+
if(GIM_GREATER(t,t2)) return false;
|
494
|
+
}
|
495
|
+
// Class III : 9 cross products
|
496
|
+
if(fulltest)
|
497
|
+
{
|
498
|
+
int j,m,n,o,p,q,r;
|
499
|
+
for(i=0;i<3;i++)
|
500
|
+
{
|
501
|
+
m = (i+1)%3;
|
502
|
+
n = (i+2)%3;
|
503
|
+
o = i==0?1:0;
|
504
|
+
p = i==2?1:2;
|
505
|
+
for(j=0;j<3;j++)
|
506
|
+
{
|
507
|
+
q = j==2?1:2;
|
508
|
+
r = j==0?1:0;
|
509
|
+
t = T[n]*transcache.m_R1to0[m][j] - T[m]*transcache.m_R1to0[n][j];
|
510
|
+
t2 = ea[o]*transcache.m_AR[p][j] + ea[p]*transcache.m_AR[o][j] +
|
511
|
+
eb[r]*transcache.m_AR[i][q] + eb[q]*transcache.m_AR[i][r];
|
512
|
+
if(GIM_GREATER(t,t2)) return false;
|
513
|
+
}
|
514
|
+
}
|
515
|
+
}
|
516
|
+
return true;
|
517
|
+
}
|
518
|
+
|
519
|
+
//! Simple test for planes.
|
520
|
+
SIMD_FORCE_INLINE bool collide_plane(
|
521
|
+
const btVector4 & plane)
|
522
|
+
{
|
523
|
+
ePLANE_INTERSECTION_TYPE classify = plane_classify(plane);
|
524
|
+
return (classify == G_COLLIDE_PLANE);
|
525
|
+
}
|
526
|
+
|
527
|
+
//! test for a triangle, with edges
|
528
|
+
SIMD_FORCE_INLINE bool collide_triangle_exact(
|
529
|
+
const btVector3 & p1,
|
530
|
+
const btVector3 & p2,
|
531
|
+
const btVector3 & p3,
|
532
|
+
const btVector4 & triangle_plane)
|
533
|
+
{
|
534
|
+
if(!collide_plane(triangle_plane)) return false;
|
535
|
+
|
536
|
+
btVector3 center,extends;
|
537
|
+
this->get_center_extend(center,extends);
|
538
|
+
|
539
|
+
const btVector3 v1(p1 - center);
|
540
|
+
const btVector3 v2(p2 - center);
|
541
|
+
const btVector3 v3(p3 - center);
|
542
|
+
|
543
|
+
//First axis
|
544
|
+
btVector3 diff(v2 - v1);
|
545
|
+
btVector3 abs_diff = diff.absolute();
|
546
|
+
//Test With X axis
|
547
|
+
TEST_CROSS_EDGE_BOX_X_AXIS_MCR(diff,abs_diff,v1,v3,extends);
|
548
|
+
//Test With Y axis
|
549
|
+
TEST_CROSS_EDGE_BOX_Y_AXIS_MCR(diff,abs_diff,v1,v3,extends);
|
550
|
+
//Test With Z axis
|
551
|
+
TEST_CROSS_EDGE_BOX_Z_AXIS_MCR(diff,abs_diff,v1,v3,extends);
|
552
|
+
|
553
|
+
|
554
|
+
diff = v3 - v2;
|
555
|
+
abs_diff = diff.absolute();
|
556
|
+
//Test With X axis
|
557
|
+
TEST_CROSS_EDGE_BOX_X_AXIS_MCR(diff,abs_diff,v2,v1,extends);
|
558
|
+
//Test With Y axis
|
559
|
+
TEST_CROSS_EDGE_BOX_Y_AXIS_MCR(diff,abs_diff,v2,v1,extends);
|
560
|
+
//Test With Z axis
|
561
|
+
TEST_CROSS_EDGE_BOX_Z_AXIS_MCR(diff,abs_diff,v2,v1,extends);
|
562
|
+
|
563
|
+
diff = v1 - v3;
|
564
|
+
abs_diff = diff.absolute();
|
565
|
+
//Test With X axis
|
566
|
+
TEST_CROSS_EDGE_BOX_X_AXIS_MCR(diff,abs_diff,v3,v2,extends);
|
567
|
+
//Test With Y axis
|
568
|
+
TEST_CROSS_EDGE_BOX_Y_AXIS_MCR(diff,abs_diff,v3,v2,extends);
|
569
|
+
//Test With Z axis
|
570
|
+
TEST_CROSS_EDGE_BOX_Z_AXIS_MCR(diff,abs_diff,v3,v2,extends);
|
571
|
+
|
572
|
+
return true;
|
573
|
+
}
|
574
|
+
};
|
575
|
+
|
576
|
+
|
577
|
+
//! Compairison of transformation objects
|
578
|
+
SIMD_FORCE_INLINE bool btCompareTransformsEqual(const btTransform & t1,const btTransform & t2)
|
579
|
+
{
|
580
|
+
if(!(t1.getOrigin() == t2.getOrigin()) ) return false;
|
581
|
+
|
582
|
+
if(!(t1.getBasis().getRow(0) == t2.getBasis().getRow(0)) ) return false;
|
583
|
+
if(!(t1.getBasis().getRow(1) == t2.getBasis().getRow(1)) ) return false;
|
584
|
+
if(!(t1.getBasis().getRow(2) == t2.getBasis().getRow(2)) ) return false;
|
585
|
+
return true;
|
586
|
+
}
|
587
|
+
|
588
|
+
|
589
|
+
|
590
|
+
#endif // GIM_BOX_COLLISION_H_INCLUDED
|