[Client] Initialize and update LocalActors while their cells are active

0.6.1
David Cernat 8 years ago
parent 8df9d55331
commit 9beaf9b7a1

@ -418,6 +418,16 @@ namespace MWBase
End of tes3mp addition End of tes3mp addition
*/ */
/*
Start of tes3mp addition
Make it possible to check whether a cell is active
*/
virtual bool isCellActive(MWWorld::CellStore* cell) = 0;
/*
End of tes3mp addition
*/
virtual bool getPlayerStandingOn (const MWWorld::ConstPtr& object) = 0; ///< @return true if the player is standing on \a object virtual bool getPlayerStandingOn (const MWWorld::ConstPtr& object) = 0; ///< @return true if the player is standing on \a object
virtual bool getActorStandingOn (const MWWorld::ConstPtr& object) = 0; ///< @return true if any actor is standing on \a object virtual bool getActorStandingOn (const MWWorld::ConstPtr& object) = 0; ///< @return true if any actor is standing on \a object
virtual bool getPlayerCollidingWith(const MWWorld::ConstPtr& object) = 0; ///< @return true if the player is colliding with \a object virtual bool getPlayerCollidingWith(const MWWorld::ConstPtr& object) = 0; ///< @return true if the player is colliding with \a object

@ -8,6 +8,10 @@
#include "CellController.hpp" #include "CellController.hpp"
#include "Main.hpp" #include "Main.hpp"
#include "LocalPlayer.hpp" #include "LocalPlayer.hpp"
using namespace mwmp;
std::map<std::string, LocalActor *> CellController::localActors;
std::map<std::string, DedicatedActor *> CellController::dedicatedActors;
mwmp::CellController::CellController() mwmp::CellController::CellController()
{ {
@ -19,6 +23,53 @@ mwmp::CellController::~CellController()
} }
void CellController::update()
{
for (std::map<std::string, LocalActor *>::iterator it = localActors.begin(); it != localActors.end();)
{
LocalActor *actor = it->second;
if (!MWBase::Environment::get().getWorld()->isCellActive(getCell(actor->cell)))
{
localActors.erase(it++);
}
else
{
printf("Updating %s\n", it->first.c_str());
++it;
}
}
}
void CellController::initializeLocalActors(const ESM::Cell& cell)
{
MWWorld::CellStore *cellStore = getCell(cell);
if (!cellStore) return;
MWWorld::CellRefList<ESM::NPC> *npcList = cellStore->getNpcs();
for (typename MWWorld::CellRefList<ESM::NPC>::List::iterator listIter(npcList->mList.begin());
listIter != npcList->mList.end(); ++listIter)
{
MWWorld::Ptr ptr(&*listIter, 0);
std::string mapIndex = generateMapIndex(ptr);
localActors[mapIndex] = new LocalActor();
localActors[mapIndex]->cell = cell;
printf("Initialized local actor %s\n", mapIndex.c_str());
}
}
std::string CellController::generateMapIndex(MWWorld::Ptr ptr)
{
std::string mapIndex = "";
mapIndex += ptr.getCellRef().getRefId();
mapIndex += "-" + std::to_string(ptr.getCellRef().getRefNum().mIndex);
mapIndex += "-" + std::to_string(ptr.getCellRef().getMpNum());
return mapIndex;
}
int mwmp::CellController::getCellSize() const int mwmp::CellController::getCellSize() const
{ {
return 8192; return 8192;

@ -1,6 +1,8 @@
#ifndef OPENMW_CELLCONTROLLER_HPP #ifndef OPENMW_CELLCONTROLLER_HPP
#define OPENMW_CELLCONTROLLER_HPP #define OPENMW_CELLCONTROLLER_HPP
#include "LocalActor.hpp"
#include "DedicatedActor.hpp"
#include "../mwworld/cellstore.hpp" #include "../mwworld/cellstore.hpp"
namespace mwmp namespace mwmp
@ -12,12 +14,19 @@ namespace mwmp
CellController(); CellController();
~CellController(); ~CellController();
int getCellSize() const; void update();
void initializeLocalActors(const ESM::Cell& cell);
std::string generateMapIndex(MWWorld::Ptr ptr);
int getCellSize() const;
virtual MWWorld::CellStore *getCell(const ESM::Cell& cell); virtual MWWorld::CellStore *getCell(const ESM::Cell& cell);
void openContainer(const MWWorld::Ptr& container, bool loot); void openContainer(const MWWorld::Ptr& container, bool loot);
void closeContainer(const MWWorld::Ptr& container); void closeContainer(const MWWorld::Ptr& container);
private:
static std::map<std::string, mwmp::LocalActor *> localActors;
static std::map<std::string, mwmp::DedicatedActor *> dedicatedActors;
}; };
} }

@ -210,6 +210,7 @@ void Main::updateWorld(float dt) const
else else
{ {
mLocalPlayer->update(); mLocalPlayer->update();
mCellController->update();
} }
} }

@ -857,11 +857,10 @@ void Networking::processWorldPacket(RakNet::Packet *packet)
} }
case ID_ACTOR_AUTHORITY: case ID_ACTOR_AUTHORITY:
{ {
MWWorld::CellStore *ptrCellStore = Main::get().getCellController()->getCell(worldEvent.cell); LOG_MESSAGE_SIMPLE(Log::LOG_VERBOSE, "Received ID_ACTOR_AUTHORITY about %s", worldEvent.cell.getDescription().c_str());
if (!ptrCellStore) return; Main::get().getCellController()->initializeLocalActors(worldEvent.cell);
LOG_MESSAGE_SIMPLE(Log::LOG_VERBOSE, "Received ID_ACTOR_AUTHORITY about %s", worldEvent.cell.getDescription().c_str());
break; break;
} }
case ID_ACTOR_FRAME: case ID_ACTOR_FRAME:

@ -2368,6 +2368,19 @@ namespace MWWorld
End of tes3mp addition End of tes3mp addition
*/ */
/*
Start of tes3mp addition
Make it possible to check whether a cell is active
*/
bool World::isCellActive(MWWorld::CellStore* cell)
{
return mWorldScene->isCellActive(*cell);
}
/*
End of tes3mp addition
*/
bool World::getPlayerStandingOn (const MWWorld::ConstPtr& object) bool World::getPlayerStandingOn (const MWWorld::ConstPtr& object)
{ {
MWWorld::Ptr player = getPlayerPtr(); MWWorld::Ptr player = getPlayerPtr();

@ -534,6 +534,16 @@ namespace MWWorld
End of tes3mp addition End of tes3mp addition
*/ */
/*
Start of tes3mp addition
Make it possible to check whether a cell is active
*/
virtual bool isCellActive(MWWorld::CellStore* cell);
/*
End of tes3mp addition
*/
virtual bool getPlayerStandingOn (const MWWorld::ConstPtr& object); ///< @return true if the player is standing on \a object virtual bool getPlayerStandingOn (const MWWorld::ConstPtr& object); ///< @return true if the player is standing on \a object
virtual bool getActorStandingOn (const MWWorld::ConstPtr& object); ///< @return true if any actor is standing on \a object virtual bool getActorStandingOn (const MWWorld::ConstPtr& object); ///< @return true if any actor is standing on \a object
virtual bool getPlayerCollidingWith(const MWWorld::ConstPtr& object); ///< @return true if the player is colliding with \a object virtual bool getPlayerCollidingWith(const MWWorld::ConstPtr& object); ///< @return true if the player is colliding with \a object

Loading…
Cancel
Save