|
|
|
@ -158,7 +158,7 @@ void ManualBulletShapeLoader::loadResource(Ogre::Resource *resource)
|
|
|
|
|
mShape->mAutogenerated = hasAutoGeneratedCollision(node);
|
|
|
|
|
|
|
|
|
|
//do a first pass
|
|
|
|
|
handleNode(node,0,false,false,false);
|
|
|
|
|
handleNode(node,0,false,false);
|
|
|
|
|
|
|
|
|
|
if(mBoundingBox != NULL)
|
|
|
|
|
{
|
|
|
|
@ -232,7 +232,7 @@ bool ManualBulletShapeLoader::hasAutoGeneratedCollision(Nif::Node const * rootNo
|
|
|
|
|
|
|
|
|
|
void ManualBulletShapeLoader::handleNode(const Nif::Node *node, int flags,
|
|
|
|
|
bool isCollisionNode,
|
|
|
|
|
bool raycasting, bool isMarker, bool isAnimated)
|
|
|
|
|
bool raycasting, bool isAnimated)
|
|
|
|
|
{
|
|
|
|
|
// Accumulate the flags from all the child nodes. This works for all
|
|
|
|
|
// the flags we currently use, at least.
|
|
|
|
@ -254,13 +254,6 @@ void ManualBulletShapeLoader::handleNode(const Nif::Node *node, int flags,
|
|
|
|
|
if(node->recType == Nif::RC_AvoidNode)
|
|
|
|
|
flags |= 0x800;
|
|
|
|
|
|
|
|
|
|
// Marker objects
|
|
|
|
|
/// \todo don't do this in the editor
|
|
|
|
|
std::string nodename = node->name;
|
|
|
|
|
Misc::StringUtils::toLower(nodename);
|
|
|
|
|
if (nodename.find("marker") != std::string::npos)
|
|
|
|
|
isMarker = true;
|
|
|
|
|
|
|
|
|
|
// Check for extra data
|
|
|
|
|
Nif::Extra const *e = node;
|
|
|
|
|
while (!e->extra.empty())
|
|
|
|
@ -281,16 +274,14 @@ void ManualBulletShapeLoader::handleNode(const Nif::Node *node, int flags,
|
|
|
|
|
// No collision. Use an internal flag setting to mark this.
|
|
|
|
|
flags |= 0x800;
|
|
|
|
|
}
|
|
|
|
|
else if (sd->string == "MRK")
|
|
|
|
|
else if (sd->string == "MRK" && !mShowMarkers)
|
|
|
|
|
// Marker objects. These are only visible in the
|
|
|
|
|
// editor. Until and unless we add an editor component to
|
|
|
|
|
// the engine, just skip this entire node.
|
|
|
|
|
isMarker = true;
|
|
|
|
|
// editor.
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ( (isCollisionNode || (mShape->mAutogenerated && !raycasting))
|
|
|
|
|
&& (!isMarker || (!mShape->mAutogenerated && !raycasting)))
|
|
|
|
|
if (isCollisionNode || (mShape->mAutogenerated && !raycasting))
|
|
|
|
|
{
|
|
|
|
|
// NOTE: a trishape with hasBounds=true, but no BBoxCollision flag should NOT go through handleNiTriShape!
|
|
|
|
|
// It must be ignored completely.
|
|
|
|
@ -319,7 +310,7 @@ void ManualBulletShapeLoader::handleNode(const Nif::Node *node, int flags,
|
|
|
|
|
for(size_t i = 0;i < list.length();i++)
|
|
|
|
|
{
|
|
|
|
|
if(!list[i].empty())
|
|
|
|
|
handleNode(list[i].getPtr(), flags, isCollisionNode, raycasting, isMarker, isAnimated);
|
|
|
|
|
handleNode(list[i].getPtr(), flags, isCollisionNode, raycasting, isAnimated);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
@ -374,10 +365,17 @@ void ManualBulletShapeLoader::handleNiTriShape(const Nif::NiTriShape *shape, int
|
|
|
|
|
|
|
|
|
|
TriangleMeshShape* childShape = new TriangleMeshShape(childMesh,true);
|
|
|
|
|
|
|
|
|
|
childShape->setLocalScaling(btVector3(transform[0][0], transform[1][1], transform[2][2]));
|
|
|
|
|
|
|
|
|
|
float scale = shape->trafo.scale;
|
|
|
|
|
const Nif::Node* parent = shape;
|
|
|
|
|
while (parent->parent)
|
|
|
|
|
{
|
|
|
|
|
parent = parent->parent;
|
|
|
|
|
scale *= parent->trafo.scale;
|
|
|
|
|
}
|
|
|
|
|
Ogre::Quaternion q = transform.extractQuaternion();
|
|
|
|
|
Ogre::Vector3 v = transform.getTrans();
|
|
|
|
|
childShape->setLocalScaling(btVector3(scale, scale, scale));
|
|
|
|
|
|
|
|
|
|
btTransform trans(btQuaternion(q.x, q.y, q.z, q.w), btVector3(v.x, v.y, v.z));
|
|
|
|
|
|
|
|
|
|
if (raycasting)
|
|
|
|
|