|
|
@ -596,17 +596,23 @@ namespace MWPhysics
|
|
|
|
int recIndex = it->first;
|
|
|
|
int recIndex = it->first;
|
|
|
|
int shapeIndex = it->second;
|
|
|
|
int shapeIndex = it->second;
|
|
|
|
|
|
|
|
|
|
|
|
NifOsg::FindGroupByRecIndex visitor(recIndex);
|
|
|
|
std::map<int, osg::NodePath>::iterator nodePathFound = mRecIndexToNodePath.find(recIndex);
|
|
|
|
mPtr.getRefData().getBaseNode()->accept(visitor);
|
|
|
|
if (nodePathFound == mRecIndexToNodePath.end())
|
|
|
|
if (!visitor.mFound)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::cerr << "animateCollisionShapes: Can't find node " << recIndex << std::endl;
|
|
|
|
NifOsg::FindGroupByRecIndex visitor(recIndex);
|
|
|
|
return;
|
|
|
|
mPtr.getRefData().getBaseNode()->accept(visitor);
|
|
|
|
|
|
|
|
if (!visitor.mFound)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
std::cerr << "animateCollisionShapes: Can't find node " << recIndex << std::endl;
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
osg::NodePath nodePath = visitor.mFoundPath;
|
|
|
|
|
|
|
|
nodePath.erase(nodePath.begin());
|
|
|
|
|
|
|
|
nodePathFound = mRecIndexToNodePath.insert(std::make_pair(recIndex, nodePath)).first;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
osg::NodePath path = visitor.mFoundPath;
|
|
|
|
osg::NodePath& nodePath = nodePathFound->second;
|
|
|
|
path.erase(path.begin());
|
|
|
|
osg::Matrixf matrix = osg::computeLocalToWorld(nodePath);
|
|
|
|
osg::Matrixf matrix = osg::computeLocalToWorld(path);
|
|
|
|
|
|
|
|
osg::Vec3f scale = matrix.getScale();
|
|
|
|
osg::Vec3f scale = matrix.getScale();
|
|
|
|
matrix.orthoNormalize(matrix);
|
|
|
|
matrix.orthoNormalize(matrix);
|
|
|
|
|
|
|
|
|
|
|
@ -626,6 +632,7 @@ namespace MWPhysics
|
|
|
|
private:
|
|
|
|
private:
|
|
|
|
std::auto_ptr<btCollisionObject> mCollisionObject;
|
|
|
|
std::auto_ptr<btCollisionObject> mCollisionObject;
|
|
|
|
osg::ref_ptr<Resource::BulletShapeInstance> mShapeInstance;
|
|
|
|
osg::ref_ptr<Resource::BulletShapeInstance> mShapeInstance;
|
|
|
|
|
|
|
|
std::map<int, osg::NodePath> mRecIndexToNodePath;
|
|
|
|
bool mSolid;
|
|
|
|
bool mSolid;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|