trying strict

actorid
Jason Hooks 14 years ago
parent 3a9007849d
commit 65cc0e8317

@ -93,51 +93,6 @@ bool OMW::Engine::frameRenderingQueued (const Ogre::FrameEvent& evt)
std::string effect; std::string effect;
MWWorld::Ptr::CellStore *current = mEnvironment.mWorld->getPlayer().getPlayer().getCell(); MWWorld::Ptr::CellStore *current = mEnvironment.mWorld->getPlayer().getPlayer().getCell();
/*
ESMS::CellRefList<ESM::Creature,MWWorld::RefData>::List creatureData = (current->creatures).list;
ESMS::CellRefList<ESM::Creature,MWWorld::RefData>::List::iterator creaturedataiter = creatureData.begin();
for(int i = 0; i < creatureData.size(); i++)
{
//std::cout << "Testing" << i < "\n";
ESMS::LiveCellRef<ESM::Creature,MWWorld::RefData> item = *creaturedataiter;
Ogre::Entity* creaturemodel = item.model;
if(evt.timeSinceLastFrame == 0)
creaturemodel->getSkeleton()->setBindingPose();
creaturemodel->getSkeleton()->setBlendMode(Ogre::SkeletonAnimationBlendMode::ANIMBLEND_AVERAGE); //ANIMBLEND_AVERAGE
Ogre::AnimationState *mAnimationState = creaturemodel->getAnimationState("WholeThing");
mAnimationState->setWeight(.5);
mAnimationState->setLoop(true);
//npcmodel->getSkeleton()->
mAnimationState->setEnabled(true);
Ogre::AnimationState *mAnimationState2 = creaturemodel->getAnimationState("WholeThing2");
mAnimationState2->setLoop(true);
mAnimationState2->setWeight(.5);
mAnimationState2->setEnabled(true);
mAnimationState2->createBlendMask(creaturemodel->getSkeleton()->getNumBones(),1);
mAnimationState->createBlendMask(creaturemodel->getSkeleton()->getNumBones(),1);
for(int j = 2; j < creaturemodel->getSkeleton()->getNumBones(); j++)
{
mAnimationState->setBlendMaskEntry(j,1);
mAnimationState2->setBlendMaskEntry(j,1);
}
// set skeleton
std::cout << "TimePosition:" << mAnimationState->getTimePosition() << "\n";
mAnimationState->addTime(evt.timeSinceLastFrame);
mAnimationState2->addTime(evt.timeSinceLastFrame);
//npcmodel->_updateAnimation();
//mAnimationState2->setEnabled(true);
creaturedataiter++;
}*/
//If the region has changed //If the region has changed
@ -299,9 +254,7 @@ void OMW::Engine::loadBSA()
std::string m = mDataDir.string(); std::string m = mDataDir.string();
std::cout << "Data dir" << m << "\n"; std::cout << "Data dir" << m << "\n";
addDir(m); addDir(m, mFSStrict);
//std::string s = "f\n";
//std::cout <<"S: " << s.size() << "\n";
} }

@ -118,7 +118,7 @@ namespace MWClass
Ogre::Vector3 pos2 = Ogre::Vector3( 0, .5, 75); Ogre::Vector3 pos2 = Ogre::Vector3( 0, .5, 75);
if (groin){ if (groin){
cellRender.insertMesh("Meshes\\2\\red_MJ_hat_org.nif"); //w/W_6th_Hammer.NIF cellRender.insertMesh("meshes\\2\\red_MJ_hat_ORg.nif"); //w/W_6th_Hammer.NIF
//bald_MJ_hat.NIF //bald_MJ_hat.NIF
cellRender.insertMesh("meshes\\" + groin->model, pos2, axis, kOgrePi, npcName + "groin", addresses, numbers); cellRender.insertMesh("meshes\\" + groin->model, pos2, axis, kOgrePi, npcName + "groin", addresses, numbers);
addresses2[numbers] = npcName + "groin"; addresses2[numbers] = npcName + "groin";

@ -41,6 +41,8 @@ struct ciLessBoost : std::binary_function<std::string, std::string, bool>
} }
}; };
static bool fsstrict = false;
/// An OGRE Archive wrapping a BSAFile archive /// An OGRE Archive wrapping a BSAFile archive
class DirArchive: public Ogre::FileSystemArchive class DirArchive: public Ogre::FileSystemArchive
{ {
@ -70,7 +72,7 @@ class DirArchive: public Ogre::FileSystemArchive
std::string s = name; std::string s = name;
cutoff = s.size() + 1; cutoff = s.size() + 1;
//std::cout << "Cut off:" << cutoff; //std::cout << "Cut off:" << cutoff;
if(fsstrict == false)
populateMap(currentdir); populateMap(currentdir);
} }
@ -111,7 +113,7 @@ class DirArchive: public Ogre::FileSystemArchive
} }
bool isCaseSensitive() const { return false; } bool isCaseSensitive() const { return fsstrict; }
// The archive is loaded in the constructor, and never unloaded. // The archive is loaded in the constructor, and never unloaded.
void load() {} void load() {}
@ -134,7 +136,13 @@ class DirArchive: public Ogre::FileSystemArchive
copy.replace(i, 1, "/"); copy.replace(i, 1, "/");
} }
} }
if(fsstrict == true)
{
std::cout << "fsstrict " << copy << "\n";
return FileSystemArchive::exists(copy);
}
std::cout << "afterstrict\n";
if(copy.at(0) == '\\' || copy.at(0) == '/') if(copy.at(0) == '\\' || copy.at(0) == '/')
{ {
@ -145,7 +153,6 @@ class DirArchive: public Ogre::FileSystemArchive
} }
//boost::filesystem::path p = copy;
int last = copy.size() - 1; int last = copy.size() - 1;
int i = last; int i = last;
@ -196,7 +203,11 @@ class DirArchive: public Ogre::FileSystemArchive
copy.replace(i, 1, "/"); copy.replace(i, 1, "/");
} }
} }
if(fsstrict == true){
std::cout << "fsstrict " << copy << "\n";
return FileSystemArchive::open(copy, readonly);
}
std::cout << "afterstrict\n";
if(copy.at(0) == '\\' || copy.at(0) == '/') if(copy.at(0) == '\\' || copy.at(0) == '/')
{ {
@ -205,6 +216,9 @@ class DirArchive: public Ogre::FileSystemArchive
//std::cout << "The copy" << copy << "\n"; //std::cout << "The copy" << copy << "\n";
//std::cout << "After:" << copy.size(); //std::cout << "After:" << copy.size();
} }
//boost::filesystem::path p = copy; //boost::filesystem::path p = copy;
int last = copy.size() - 1; int last = copy.size() - 1;
@ -374,6 +388,7 @@ public:
static bool init = false; static bool init = false;
static bool init2 = false; static bool init2 = false;
static void insertBSAFactory() static void insertBSAFactory()
{ {
if(!init) if(!init)
@ -400,9 +415,11 @@ void addBSA(const std::string& name, const std::string& group)
ResourceGroupManager::getSingleton(). ResourceGroupManager::getSingleton().
addResourceLocation(name, "BSA", group); addResourceLocation(name, "BSA", group);
} }
void addDir(const std::string& name, const std::string& group) void addDir(const std::string& name, const bool& fs, const std::string& group)
{ {
fsstrict = fs;
insertDirFactory(); insertDirFactory();
ResourceGroupManager::getSingleton(). ResourceGroupManager::getSingleton().
addResourceLocation(name, "Dir", group); addResourceLocation(name, "Dir", group);
} }

@ -32,6 +32,6 @@
/// Add the given BSA file as an input archive in the Ogre resource /// Add the given BSA file as an input archive in the Ogre resource
/// system. /// system.
void addBSA(const std::string& file, const std::string& group="General"); void addBSA(const std::string& file, const std::string& group="General");
void addDir(const std::string& file, const std::string& group="General"); void addDir(const std::string& file, const bool& fs, const std::string& group="General");
#endif #endif

Loading…
Cancel
Save