mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-25 06:35:30 +00:00
12de0afb03
Fix a bug in copyObjectToCell. Make actor rotations more consistent.
52 lines
1.7 KiB
C++
52 lines
1.7 KiB
C++
|
|
#include "actionteleport.hpp"
|
|
|
|
#include "../mwbase/environment.hpp"
|
|
#include "../mwbase/world.hpp"
|
|
#include "../mwbase/mechanicsmanager.hpp"
|
|
#include "player.hpp"
|
|
|
|
namespace MWWorld
|
|
{
|
|
ActionTeleport::ActionTeleport (const std::string& cellName,
|
|
const ESM::Position& position)
|
|
: Action (true), mCellName (cellName), mPosition (position)
|
|
{
|
|
}
|
|
|
|
void ActionTeleport::executeImp (const Ptr& actor)
|
|
{
|
|
MWBase::World* world = MWBase::Environment::get().getWorld();
|
|
|
|
//find any NPC that is following the actor and teleport him too
|
|
std::list<MWWorld::Ptr> followers = MWBase::Environment::get().getMechanicsManager()->getActorsFollowing(actor);
|
|
for(std::list<MWWorld::Ptr>::iterator it = followers.begin();it != followers.end();it++)
|
|
{
|
|
std::cout << "teleporting someone!" << (*it).getCellRef().mRefID;
|
|
executeImp(*it);
|
|
}
|
|
|
|
if(actor == world->getPlayerPtr())
|
|
{
|
|
world->getPlayer().setTeleported(true);
|
|
if (mCellName.empty())
|
|
world->changeToExteriorCell (mPosition);
|
|
else
|
|
world->changeToInteriorCell (mCellName, mPosition);
|
|
}
|
|
else
|
|
{
|
|
if (mCellName.empty())
|
|
{
|
|
int cellX;
|
|
int cellY;
|
|
world->positionToIndex(mPosition.pos[0],mPosition.pos[1],cellX,cellY);
|
|
world->moveObject(actor,world->getExterior(cellX,cellY),
|
|
mPosition.pos[0],mPosition.pos[1],mPosition.pos[2]);
|
|
}
|
|
else
|
|
world->moveObject(actor,world->getInterior(mCellName),mPosition.pos[0],mPosition.pos[1],mPosition.pos[2]);
|
|
}
|
|
}
|
|
}
|