|
|
@ -163,7 +163,8 @@ namespace MWWorld
|
|
|
|
ToUTF8::Utf8Encoder* encoder, const std::map<std::string,std::string>& fallbackMap, int mActivationDistanceOverride)
|
|
|
|
ToUTF8::Utf8Encoder* encoder, const std::map<std::string,std::string>& fallbackMap, int mActivationDistanceOverride)
|
|
|
|
: mPlayer (0), mLocalScripts (mStore), mGlobalVariables (0),
|
|
|
|
: mPlayer (0), mLocalScripts (mStore), mGlobalVariables (0),
|
|
|
|
mSky (true), mCells (mStore, mEsm),
|
|
|
|
mSky (true), mCells (mStore, mEsm),
|
|
|
|
mNumFacing(0), mActivationDistanceOverride (mActivationDistanceOverride),mFallback(fallbackMap)
|
|
|
|
mNumFacing(0), mActivationDistanceOverride (mActivationDistanceOverride),
|
|
|
|
|
|
|
|
mFallback(fallbackMap), mNewGame(newGame)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mPhysics = new PhysicsSystem(renderer);
|
|
|
|
mPhysics = new PhysicsSystem(renderer);
|
|
|
|
mPhysEngine = mPhysics->getEngine();
|
|
|
|
mPhysEngine = mPhysics->getEngine();
|
|
|
@ -214,7 +215,7 @@ namespace MWWorld
|
|
|
|
// global variables
|
|
|
|
// global variables
|
|
|
|
mGlobalVariables = new Globals (mStore);
|
|
|
|
mGlobalVariables = new Globals (mStore);
|
|
|
|
|
|
|
|
|
|
|
|
if (newGame)
|
|
|
|
if (mNewGame)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// set new game mark
|
|
|
|
// set new game mark
|
|
|
|
mGlobalVariables->setInt ("chargenstate", 1);
|
|
|
|
mGlobalVariables->setInt ("chargenstate", 1);
|
|
|
@ -1465,12 +1466,12 @@ namespace MWWorld
|
|
|
|
return mRendering->vanityRotateCamera(rot);
|
|
|
|
return mRendering->vanityRotateCamera(rot);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void World::setupPlayer(bool newGame)
|
|
|
|
void World::setupPlayer()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
const ESM::NPC* player = mStore.get<ESM::NPC>().find ("player");
|
|
|
|
const ESM::NPC* player = mStore.get<ESM::NPC>().find ("player");
|
|
|
|
mPlayer = new MWWorld::Player (player, *this);
|
|
|
|
mPlayer = new MWWorld::Player (player, *this);
|
|
|
|
mRendering->attachCameraTo(mPlayer->getPlayer());
|
|
|
|
mRendering->attachCameraTo(mPlayer->getPlayer());
|
|
|
|
if (newGame)
|
|
|
|
if (mNewGame)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::Class::get(mPlayer->getPlayer()).getContainerStore(mPlayer->getPlayer()).fill(player->mInventory, "", mStore);
|
|
|
|
MWWorld::Class::get(mPlayer->getPlayer()).getContainerStore(mPlayer->getPlayer()).fill(player->mInventory, "", mStore);
|
|
|
|
MWWorld::Class::get(mPlayer->getPlayer()).getInventoryStore(mPlayer->getPlayer()).autoEquip (mPlayer->getPlayer());
|
|
|
|
MWWorld::Class::get(mPlayer->getPlayer()).getInventoryStore(mPlayer->getPlayer()).autoEquip (mPlayer->getPlayer());
|
|
|
@ -1481,6 +1482,8 @@ namespace MWWorld
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mRendering->renderPlayer(mPlayer->getPlayer());
|
|
|
|
mRendering->renderPlayer(mPlayer->getPlayer());
|
|
|
|
mPhysics->addActor(mPlayer->getPlayer());
|
|
|
|
mPhysics->addActor(mPlayer->getPlayer());
|
|
|
|
|
|
|
|
if (mNewGame)
|
|
|
|
|
|
|
|
toggleCollisionMode();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void World::setupExternalRendering (MWRender::ExternalRendering& rendering)
|
|
|
|
void World::setupExternalRendering (MWRender::ExternalRendering& rendering)
|
|
|
|