2012-03-19 19:38:44 -04:00
# include "trace.h"
# include <map>
void newtrace ( traceResults * const results , const Ogre : : Vector3 & start , const Ogre : : Vector3 & end , const Ogre : : Vector3 & BBHalfExtents , const float rotation , bool isInterior , OEngine : : Physic : : PhysicEngine * enginePass ) //Traceobj was a Aedra Object
{
2012-09-23 19:36:37 +02:00
//static float lastyaw = 0.0f;
//static float lastpitch = 0.0f;
2012-03-19 19:38:44 -04:00
//if (!traceobj)
// return;
//if (!traceobj->incellptr)
// return;
2012-08-14 18:04:58 -04:00
2012-03-19 19:38:44 -04:00
const Ogre : : Vector3 rayDir = end - start ;
2012-08-04 15:43:33 -04:00
2012-03-19 19:38:44 -04:00
2012-08-04 15:43:33 -04:00
2012-03-19 19:38:44 -04:00
NewPhysTraceResults out ;
//std::cout << "Starting trace\n";
2012-03-25 15:16:02 -04:00
//Ogre::Vector3 startReplace = Ogre::Vector3(650,950, 45);
//Ogre::Vector3 endReplace = startReplace;
//endReplace.z -= .25;
2012-03-19 19:38:44 -04:00
2012-09-05 17:44:11 -04:00
const bool hasHit = NewPhysicsTrace < collisionWorldTrace > ( & out , start , end , BBHalfExtents , Ogre : : Vector3 ( 0.0f , 0.0f , 0.0f ) , isInterior , enginePass ) ;
2012-03-27 20:17:54 -04:00
2012-03-19 19:38:44 -04:00
if ( out . fraction < 0.001f )
results - > startsolid = true ;
else
results - > startsolid = false ;
//results->allsolid = out.startSolid;
// If outside and underground, we're solid
/*if (isInterior)
{
const Ogre : : Vector3 height = GetGroundPosition ( start , CellCoords ( traceCell - > data - > gridX , traceCell - > data - > gridY ) ) ;
if ( start . yPos - height . yPos < ( - 2.0f * BBHalfExtents . yPos ) )
{
results - > allsolid = true ;
}
else
results - > allsolid = false ;
} */
// If inside and out of the tree, we're solid
//else
//{
results - > allsolid = out . startSolid ;
//std::cout << "allsolid" << results->allsolid << "\n";
//}
if ( ! hasHit )
{
results - > endpos = end ;
2012-03-25 15:16:02 -04:00
results - > planenormal = Ogre : : Vector3 ( 0.0f , 0.0f , 1.0f ) ;
2012-03-19 19:38:44 -04:00
results - > entityNum = ENTITYNUM_NONE ;
results - > fraction = 1.0f ;
}
else
{
results - > fraction = out . fraction ;
results - > planenormal = out . hitNormal ;
results - > endpos = rayDir * results - > fraction + start ;
results - > entityNum = ENTITYNUM_WORLD ;
/*bprintf("Start: (%f, %f, %f) End: (%f, %f, %f) TraceDir: (%f, %f, %f) HitNormal: (%f, %f, %f) Fraction: %f Hitpos: (%f, %f, %f) CompensatedHitpos: (%f, %f, %f)\n",
start . xPos , start . yPos , start . zPos ,
end . xPos , end . yPos , end . zPos ,
rayDir . xPos , rayDir . yPos , rayDir . zPos ,
results - > planenormal . xPos , results - > planenormal . yPos , results - > planenormal . zPos , results - > fraction ,
out . endPos . xPos , out . endPos . yPos , out . endPos . zPos ,
results - > endpos . xPos , results - > endpos . yPos , results - > endpos . zPos ) ; */
}
}
template < const traceWorldType traceType >
const bool NewPhysicsTrace ( NewPhysTraceResults * const out , const Ogre : : Vector3 & start , const Ogre : : Vector3 & end ,
const Ogre : : Vector3 & BBHalfExtents , const Ogre : : Vector3 & rotation , bool isInterior , OEngine : : Physic : : PhysicEngine * enginePass )
{
//if (!traceobj->incellptr)
// return false;
//if(enginePass->dynamicsWorld->getCollisionObjectArray().at(60)->getCollisionShape()->isConvex())
// std::cout << "It's convex\n";
2012-09-05 17:44:11 -04:00
2012-03-19 19:38:44 -04:00
2012-08-16 15:42:03 +04:00
const btVector3 btstart ( start . x , start . y , start . z + BBHalfExtents . z ) ;
const btVector3 btend ( end . x , end . y , end . z + BBHalfExtents . z ) ;
2012-03-26 21:35:20 -04:00
const btQuaternion btrot ( rotation . y , rotation . x , rotation . z ) ; //y, x, z
2012-03-19 19:38:44 -04:00
2012-08-14 18:04:58 -04:00
const btBoxShape newshape ( btVector3 ( BBHalfExtents . x , BBHalfExtents . y , BBHalfExtents . z ) ) ;
//const btCapsuleShapeZ newshape(BBHalfExtents.x, BBHalfExtents.z * 2 - BBHalfExtents.x * 2);
2012-03-19 19:38:44 -04:00
const btTransform from ( btrot , btstart ) ;
2012-04-30 18:46:51 +02:00
const btTransform to ( btrot , btend ) ;
// warning: unused variable ...
/*
2012-03-19 19:38:44 -04:00
float x = from . getOrigin ( ) . getX ( ) ;
float y = from . getOrigin ( ) . getY ( ) ;
float z = from . getOrigin ( ) . getZ ( ) ;
float x2 = to . getOrigin ( ) . getX ( ) ;
float y2 = to . getOrigin ( ) . getY ( ) ;
float z2 = to . getOrigin ( ) . getZ ( ) ;
2012-04-30 18:46:51 +02:00
*/
2012-03-19 19:38:44 -04:00
2012-03-24 22:03:08 -04:00
//std::cout << "BtFrom: " << x << "," << y << "," << z << "\n";
//std::cout << "BtTo: " << x2 << "," << y2 << "," << z2 << "\n";
2012-03-19 19:38:44 -04:00
//std::cout << "BtTo: " << to.getOrigin().getX() << "," << to.getOrigin().getY() << "," << to.getOrigin().getZ() << "\n";
btCollisionWorld : : ClosestConvexResultCallback
newTraceCallback ( btstart , btend ) ;
newTraceCallback . m_collisionFilterMask = ( traceType = = collisionWorldTrace ) ? Only_Collision : Only_Pickup ;
enginePass - > dynamicsWorld - > convexSweepTest ( & newshape , from , to , newTraceCallback ) ;
//newTraceCallback.
//std::cout << "NUM: " << enginePass->dynamicsWorld->getNumCollisionObjects() << "\n";
// Copy the hit data over to our trace results struct:
out - > fraction = newTraceCallback . m_closestHitFraction ;
Ogre : : Vector3 & outhitnormal = out - > hitNormal ;
const btVector3 & tracehitnormal = newTraceCallback . m_hitNormalWorld ;
outhitnormal . x = tracehitnormal . x ( ) ;
outhitnormal . y = tracehitnormal . y ( ) ;
outhitnormal . z = tracehitnormal . z ( ) ;
Ogre : : Vector3 & outhitpos = out - > endPos ;
const btVector3 & tracehitpos = newTraceCallback . m_hitPointWorld ;
outhitpos . x = tracehitpos . x ( ) ;
outhitpos . y = tracehitpos . y ( ) ;
outhitpos . z = tracehitpos . z ( ) ;
// StartSolid test:
{
out - > startSolid = false ;
//btCollisionObject collision;
//collision.setCollisionShape(const_cast<btBoxShape* const>(&newshape) );
//CustomContactCallback crb;
//world.world->contactTest(&collision, crb);
//out->startSolid = crb.hit;
// If outside and underground, we're solid
if ( ! isInterior ) //Check if we are interior
{
}
// If inside and out of the tree, we're solid
else
{
btVector3 aabbMin , aabbMax ;
enginePass - > broadphase - > getBroadphaseAabb ( aabbMin , aabbMax ) ;
//std::cout << "AABBMIN" << aabbMin.getX() <<"," <<aabbMin.getY() << "," << aabbMin.getZ() << "\n";
//std::cout << "AABBMAX" << aabbMax.getX() <<"," <<aabbMax.getY() << "," << aabbMax.getZ() << "\n";
//std::cout << "AABBMAX" << aabbMax << "\n";
if ( ! TestPointAgainstAabb2 ( aabbMin , aabbMax , * ( const btVector3 * const ) & ( start ) ) )
{
//We're solid
2012-09-15 22:48:24 -04:00
//THIS NEEDS TO BE TURNED OFF IF WE WANT FALLING IN EXTERIORS TO WORK CORRECTLY!!!!!!!
//out->startSolid = true;
2012-03-19 19:38:44 -04:00
}
}
}
const bool hasHit = newTraceCallback . hasHit ( ) ;
2012-03-27 20:17:54 -04:00
2012-03-19 19:38:44 -04:00
return hasHit ;
}