From e35aee0f89766599a27c7652f0c27da5f3b38ae7 Mon Sep 17 00:00:00 2001 From: Jason Hooks Date: Fri, 13 Jan 2012 02:19:28 -0500 Subject: [PATCH] Disjointed free part fix --- apps/openmw/mwrender/animation.cpp | 14 +++++++++----- apps/openmw/mwrender/renderingmanager.cpp | 2 -- 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/apps/openmw/mwrender/animation.cpp b/apps/openmw/mwrender/animation.cpp index fbe30bbb05..3bd160e6da 100644 --- a/apps/openmw/mwrender/animation.cpp +++ b/apps/openmw/mwrender/animation.cpp @@ -9,11 +9,15 @@ namespace MWRender{ std::string Animation::getUniqueID(std::string mesh){ int counter; - if(mUniqueIDs.find(mesh) == mUniqueIDs.end()){ - counter = mUniqueIDs[mesh] = 0; + std::string copy = mesh; + std::transform(copy.begin(), copy.end(), copy.begin(), ::tolower); + if(mUniqueIDs.find(copy) == mUniqueIDs.end()){ + counter = mUniqueIDs[copy] = 0; + } + else{ + mUniqueIDs[copy] = mUniqueIDs[copy] + 1; + counter = mUniqueIDs[copy]; } - else - counter = mUniqueIDs[mesh]++; std::stringstream out; if(counter > 99 && counter < 1000) @@ -463,7 +467,7 @@ namespace MWRender{ base->getAllAnimationStates()->_notifyDirty(); //base->_updateAnimation(); - base->_notifyMoved(); + base->_notifyMoved(); for(unsigned int i = 0; i < entityparts.size(); i++){ Ogre::SkeletonInstance* skel = entityparts[i]->getSkeleton(); diff --git a/apps/openmw/mwrender/renderingmanager.cpp b/apps/openmw/mwrender/renderingmanager.cpp index ae2e0f7910..fff1412631 100644 --- a/apps/openmw/mwrender/renderingmanager.cpp +++ b/apps/openmw/mwrender/renderingmanager.cpp @@ -233,13 +233,11 @@ void RenderingManager::toggleLight() void RenderingManager::playAnimationGroup (const MWWorld::Ptr& ptr, const std::string& groupName, int mode, int number) { -std::cout<<"play animation " << groupName << ", " << mode << ", " << number << std::endl; mActors.playAnimationGroup(ptr, groupName, mode, number); } void RenderingManager::skipAnimation (const MWWorld::Ptr& ptr) { -std::cout<<"skip animation"<