Markers should still have collision if they have a NiRootCollisionNode

actorid
scrawl 12 years ago
parent 73278edf7e
commit e30af28860

@ -112,7 +112,7 @@ void ManualBulletShapeLoader::loadResource(Ogre::Resource *resource)
cShape->mHasCollisionNode = hasRootCollisionNode(node); cShape->mHasCollisionNode = hasRootCollisionNode(node);
//do a first pass //do a first pass
handleNode(mesh1, node,0,false,false); handleNode(mesh1, node,0,false,false,false);
if(mBoundingBox != NULL) if(mBoundingBox != NULL)
{ {
@ -136,7 +136,7 @@ void ManualBulletShapeLoader::loadResource(Ogre::Resource *resource)
btTriangleMesh* mesh2 = new btTriangleMesh(); btTriangleMesh* mesh2 = new btTriangleMesh();
handleNode(mesh2, node,0,true,true); handleNode(mesh2, node,0,true,true,false);
if(mBoundingBox != NULL) if(mBoundingBox != NULL)
{ {
@ -175,7 +175,7 @@ bool ManualBulletShapeLoader::hasRootCollisionNode(Nif::Node const * node)
void ManualBulletShapeLoader::handleNode(btTriangleMesh* mesh, const Nif::Node *node, int flags, void ManualBulletShapeLoader::handleNode(btTriangleMesh* mesh, const Nif::Node *node, int flags,
bool isCollisionNode, bool isCollisionNode,
bool raycasting) bool raycasting, bool isMarker)
{ {
// Accumulate the flags from all the child nodes. This works for all // Accumulate the flags from all the child nodes. This works for all
// the flags we currently use, at least. // the flags we currently use, at least.
@ -186,14 +186,12 @@ void ManualBulletShapeLoader::handleNode(btTriangleMesh* mesh, const Nif::Node *
else else
isCollisionNode = isCollisionNode && (node->recType != Nif::RC_RootCollisionNode); isCollisionNode = isCollisionNode && (node->recType != Nif::RC_RootCollisionNode);
// Marker objects: no collision // Marker objects
/// \todo don't do this in the editor /// \todo don't do this in the editor
std::string nodename = node->name; std::string nodename = node->name;
Misc::StringUtils::toLower(nodename); Misc::StringUtils::toLower(nodename);
if (nodename.find("marker") != std::string::npos) if (nodename.find("marker") != std::string::npos)
{ isMarker = true;
return;
}
// Check for extra data // Check for extra data
Nif::Extra const *e = node; Nif::Extra const *e = node;
@ -219,11 +217,12 @@ void ManualBulletShapeLoader::handleNode(btTriangleMesh* mesh, const Nif::Node *
// Marker objects. These are only visible in the // Marker objects. These are only visible in the
// editor. Until and unless we add an editor component to // editor. Until and unless we add an editor component to
// the engine, just skip this entire node. // the engine, just skip this entire node.
return; isMarker = true;
} }
} }
if (isCollisionNode || (!cShape->mHasCollisionNode && !raycasting)) if ( (isCollisionNode || (!cShape->mHasCollisionNode && !raycasting))
&& (!isMarker || (cShape->mHasCollisionNode && !raycasting)))
{ {
if(node->hasBounds) if(node->hasBounds)
{ {
@ -246,7 +245,7 @@ void ManualBulletShapeLoader::handleNode(btTriangleMesh* mesh, const Nif::Node *
for(size_t i = 0;i < list.length();i++) for(size_t i = 0;i < list.length();i++)
{ {
if(!list[i].empty()) if(!list[i].empty())
handleNode(mesh, list[i].getPtr(), flags, isCollisionNode, raycasting); handleNode(mesh, list[i].getPtr(), flags, isCollisionNode, raycasting, isMarker);
} }
} }
} }

@ -82,7 +82,7 @@ private:
/** /**
*Parse a node. *Parse a node.
*/ */
void handleNode(btTriangleMesh* mesh, Nif::Node const *node, int flags, bool isCollisionNode, bool raycasting); void handleNode(btTriangleMesh* mesh, Nif::Node const *node, int flags, bool isCollisionNode, bool raycasting, bool isMarker);
/** /**
*Helper function *Helper function

@ -1113,7 +1113,7 @@ public:
{ {
// Marker objects. These are only visible in the // Marker objects. These are only visible in the
// editor. // editor.
flags |= 0x01; return;
} }
} }
e = e->extra; e = e->extra;

Loading…
Cancel
Save