mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-02-04 03:40:14 +00:00
Have createEntities' caller retrieve the text keys as needed
This commit is contained in:
parent
761914bdaa
commit
58d35dbfcf
@ -1,6 +1,6 @@
|
|||||||
#include "animation.hpp"
|
#include "animation.hpp"
|
||||||
|
|
||||||
#include <OgreHardwarePixelBuffer.h>
|
#include <OgreSkeletonManager.h>
|
||||||
#include <OgreSkeletonInstance.h>
|
#include <OgreSkeletonInstance.h>
|
||||||
#include <OgreEntity.h>
|
#include <OgreEntity.h>
|
||||||
#include <OgreBone.h>
|
#include <OgreBone.h>
|
||||||
@ -36,7 +36,7 @@ void Animation::createEntityList(Ogre::SceneNode *node, const std::string &model
|
|||||||
mInsert = node;
|
mInsert = node;
|
||||||
assert(mInsert);
|
assert(mInsert);
|
||||||
|
|
||||||
mEntityList = NifOgre::NIFLoader::createEntities(mInsert, &mTextKeys, model);
|
mEntityList = NifOgre::NIFLoader::createEntities(mInsert, model);
|
||||||
if(mEntityList.mSkelBase)
|
if(mEntityList.mSkelBase)
|
||||||
{
|
{
|
||||||
Ogre::AnimationStateSet *aset = mEntityList.mSkelBase->getAllAnimationStates();
|
Ogre::AnimationStateSet *aset = mEntityList.mSkelBase->getAllAnimationStates();
|
||||||
@ -49,6 +49,21 @@ void Animation::createEntityList(Ogre::SceneNode *node, const std::string &model
|
|||||||
if(!mAnimState)
|
if(!mAnimState)
|
||||||
mAnimState = state;
|
mAnimState = state;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Would be nice if Ogre::SkeletonInstance allowed access to the 'master' Ogre::SkeletonPtr.
|
||||||
|
Ogre::SkeletonManager &skelMgr = Ogre::SkeletonManager::getSingleton();
|
||||||
|
Ogre::SkeletonPtr skel = skelMgr.getByName(mEntityList.mSkelBase->getSkeleton()->getName());
|
||||||
|
Ogre::Skeleton::BoneIterator iter = skel->getBoneIterator();
|
||||||
|
while(iter.hasMoreElements())
|
||||||
|
{
|
||||||
|
Ogre::Bone *bone = iter.getNext();
|
||||||
|
const Ogre::Any &data = bone->getUserObjectBindings().getUserAny(NifOgre::sTextKeyExtraDataID);
|
||||||
|
if(!data.isEmpty())
|
||||||
|
{
|
||||||
|
mTextKeys = Ogre::any_cast<NifOgre::TextKeyMap>(data);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -94,7 +94,7 @@ void Objects::insertMesh (const MWWorld::Ptr& ptr, const std::string& mesh)
|
|||||||
assert(insert);
|
assert(insert);
|
||||||
|
|
||||||
Ogre::AxisAlignedBox bounds = Ogre::AxisAlignedBox::BOX_NULL;
|
Ogre::AxisAlignedBox bounds = Ogre::AxisAlignedBox::BOX_NULL;
|
||||||
NifOgre::EntityList entities = NifOgre::NIFLoader::createEntities(insert, NULL, mesh);
|
NifOgre::EntityList entities = NifOgre::NIFLoader::createEntities(insert, mesh);
|
||||||
for(size_t i = 0;i < entities.mEntities.size();i++)
|
for(size_t i = 0;i < entities.mEntities.size();i++)
|
||||||
{
|
{
|
||||||
const Ogre::AxisAlignedBox &tmp = entities.mEntities[i]->getBoundingBox();
|
const Ogre::AxisAlignedBox &tmp = entities.mEntities[i]->getBoundingBox();
|
||||||
|
@ -329,7 +329,7 @@ void buildBones(Ogre::Skeleton *skel, const Nif::Node *node, std::vector<Nif::Ni
|
|||||||
if(e->recType == Nif::RC_NiTextKeyExtraData)
|
if(e->recType == Nif::RC_NiTextKeyExtraData)
|
||||||
{
|
{
|
||||||
const Nif::NiTextKeyExtraData *tk = static_cast<const Nif::NiTextKeyExtraData*>(e.getPtr());
|
const Nif::NiTextKeyExtraData *tk = static_cast<const Nif::NiTextKeyExtraData*>(e.getPtr());
|
||||||
bone->getUserObjectBindings().setUserAny("TextKeyExtraData", Ogre::Any(extractTextKeys(tk)));
|
bone->getUserObjectBindings().setUserAny(sTextKeyExtraDataID, Ogre::Any(extractTextKeys(tk)));
|
||||||
}
|
}
|
||||||
e = e->extra;
|
e = e->extra;
|
||||||
}
|
}
|
||||||
@ -1083,7 +1083,7 @@ MeshPairList NIFLoader::load(std::string name, std::string skelName, const std::
|
|||||||
return meshes;
|
return meshes;
|
||||||
}
|
}
|
||||||
|
|
||||||
EntityList NIFLoader::createEntities(Ogre::SceneNode *parent, TextKeyMap *textkeys, const std::string &name, const std::string &group)
|
EntityList NIFLoader::createEntities(Ogre::SceneNode *parentNode, const std::string &name, const std::string &group)
|
||||||
{
|
{
|
||||||
EntityList entitylist;
|
EntityList entitylist;
|
||||||
|
|
||||||
@ -1091,7 +1091,7 @@ EntityList NIFLoader::createEntities(Ogre::SceneNode *parent, TextKeyMap *textke
|
|||||||
if(meshes.size() == 0)
|
if(meshes.size() == 0)
|
||||||
return entitylist;
|
return entitylist;
|
||||||
|
|
||||||
Ogre::SceneManager *sceneMgr = parent->getCreator();
|
Ogre::SceneManager *sceneMgr = parentNode->getCreator();
|
||||||
for(size_t i = 0;i < meshes.size();i++)
|
for(size_t i = 0;i < meshes.size();i++)
|
||||||
{
|
{
|
||||||
entitylist.mEntities.push_back(sceneMgr->createEntity(meshes[i].first));
|
entitylist.mEntities.push_back(sceneMgr->createEntity(meshes[i].first));
|
||||||
@ -1100,34 +1100,16 @@ EntityList NIFLoader::createEntities(Ogre::SceneNode *parent, TextKeyMap *textke
|
|||||||
entitylist.mSkelBase = entity;
|
entitylist.mSkelBase = entity;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(entitylist.mSkelBase && textkeys)
|
|
||||||
{
|
|
||||||
// Would be nice if Ogre::SkeletonInstance allowed access to the 'master' Ogre::SkeletonPtr.
|
|
||||||
Ogre::SkeletonManager &skelMgr = Ogre::SkeletonManager::getSingleton();
|
|
||||||
Ogre::SkeletonPtr skel = skelMgr.getByName(entitylist.mSkelBase->getSkeleton()->getName());
|
|
||||||
Ogre::Skeleton::BoneIterator iter = skel->getBoneIterator();
|
|
||||||
while(iter.hasMoreElements())
|
|
||||||
{
|
|
||||||
Ogre::Bone *bone = iter.getNext();
|
|
||||||
const Ogre::Any &data = bone->getUserObjectBindings().getUserAny("TextKeyExtraData");
|
|
||||||
if(!data.isEmpty())
|
|
||||||
{
|
|
||||||
*textkeys = Ogre::any_cast<TextKeyMap>(data);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(entitylist.mSkelBase)
|
if(entitylist.mSkelBase)
|
||||||
{
|
{
|
||||||
parent->attachObject(entitylist.mSkelBase);
|
parentNode->attachObject(entitylist.mSkelBase);
|
||||||
for(size_t i = 0;i < entitylist.mEntities.size();i++)
|
for(size_t i = 0;i < entitylist.mEntities.size();i++)
|
||||||
{
|
{
|
||||||
Ogre::Entity *entity = entitylist.mEntities[i];
|
Ogre::Entity *entity = entitylist.mEntities[i];
|
||||||
if(entity != entitylist.mSkelBase && entity->hasSkeleton())
|
if(entity != entitylist.mSkelBase && entity->hasSkeleton())
|
||||||
{
|
{
|
||||||
entity->shareSkeletonInstanceWith(entitylist.mSkelBase);
|
entity->shareSkeletonInstanceWith(entitylist.mSkelBase);
|
||||||
parent->attachObject(entity);
|
parentNode->attachObject(entity);
|
||||||
}
|
}
|
||||||
else if(entity != entitylist.mSkelBase)
|
else if(entity != entitylist.mSkelBase)
|
||||||
entitylist.mSkelBase->attachObjectToBone(meshes[i].second, entity);
|
entitylist.mSkelBase->attachObjectToBone(meshes[i].second, entity);
|
||||||
@ -1136,7 +1118,7 @@ EntityList NIFLoader::createEntities(Ogre::SceneNode *parent, TextKeyMap *textke
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
for(size_t i = 0;i < entitylist.mEntities.size();i++)
|
for(size_t i = 0;i < entitylist.mEntities.size();i++)
|
||||||
parent->attachObject(entitylist.mEntities[i]);
|
parentNode->attachObject(entitylist.mEntities[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return entitylist;
|
return entitylist;
|
||||||
|
@ -43,6 +43,7 @@ namespace NifOgre
|
|||||||
|
|
||||||
// FIXME: These should not be in NifOgre, it works agnostic of what model format is used
|
// FIXME: These should not be in NifOgre, it works agnostic of what model format is used
|
||||||
typedef std::multimap<float,std::string> TextKeyMap;
|
typedef std::multimap<float,std::string> TextKeyMap;
|
||||||
|
static const char sTextKeyExtraDataID[] = "TextKeyExtraData";
|
||||||
struct EntityList {
|
struct EntityList {
|
||||||
std::vector<Ogre::Entity*> mEntities;
|
std::vector<Ogre::Entity*> mEntities;
|
||||||
Ogre::Entity *mSkelBase;
|
Ogre::Entity *mSkelBase;
|
||||||
@ -77,8 +78,7 @@ public:
|
|||||||
const std::string &name,
|
const std::string &name,
|
||||||
const std::string &group="General");
|
const std::string &group="General");
|
||||||
|
|
||||||
static EntityList createEntities(Ogre::SceneNode *parent,
|
static EntityList createEntities(Ogre::SceneNode *parentNode,
|
||||||
TextKeyMap *textkeys,
|
|
||||||
const std::string &name,
|
const std::string &name,
|
||||||
const std::string &group="General");
|
const std::string &group="General");
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user