1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-26 09:35:28 +00:00
OpenMW/apps/openmw/mwmechanics/aitravel.cpp

105 lines
3.3 KiB
C++
Raw Normal View History

2012-11-14 18:42:04 +01:00
#include "aitravel.hpp"
2012-11-15 22:15:20 +01:00
#include <iostream>
2012-11-14 18:42:04 +01:00
#include "character.hpp"
#include "../mwworld/class.hpp"
#include "../mwbase/world.hpp"
#include "../mwbase/environment.hpp"
#include "movement.hpp"
#include "../mwworld/player.hpp"
#include <boost/graph/astar_search.hpp>
#include <boost/graph/adjacency_list.hpp>
#include "boost/tuple/tuple.hpp"
2012-11-16 20:28:20 +01:00
MWMechanics::AiTravel::AiTravel(float x, float y, float z)
2013-03-31 17:30:03 +00:00
: mX(x),mY(y),mZ(z),mPathFinder()
2012-11-14 18:42:04 +01:00
{
}
2012-11-15 22:15:20 +01:00
2012-11-14 18:42:04 +01:00
MWMechanics::AiTravel * MWMechanics::AiTravel::clone() const
{
2012-11-15 22:15:20 +01:00
return new AiTravel(*this);
2012-11-14 18:42:04 +01:00
}
2012-11-15 22:15:20 +01:00
float sgn(float a)
{
if(a>0) return 1.;
else return -1.;
}
2012-11-14 18:42:04 +01:00
bool MWMechanics::AiTravel::execute (const MWWorld::Ptr& actor)
{
const ESM::Pathgrid *pathgrid =
MWBase::Environment::get().getWorld()->getStore().get<ESM::Pathgrid>().search(*actor.getCell()->mCell);
2013-03-31 17:30:03 +00:00
ESM::Position pos = actor.getRefData().getPosition();
bool cellChange = actor.getCell()->mCell->mData.mX != cellX || actor.getCell()->mCell->mData.mY != cellY;
MWWorld::Ptr player = MWBase::Environment::get().getWorld()->getPlayer().getPlayer();
if(actor.getCell()->mCell->mData.mX != player.getCell()->mCell->mData.mX)
{
2013-03-14 18:05:00 +00:00
int sideX = sgn(actor.getCell()->mCell->mData.mX - player.getCell()->mCell->mData.mX);
//check if actor is near the border of an inactive cell. If so, disable aitravel.
if(sideX*(pos.pos[0] - actor.getCell()->mCell->mData.mX * ESM::Land::REAL_SIZE) > sideX*(ESM::Land::REAL_SIZE/2. - 2000))
{
MWWorld::Class::get(actor).getMovementSettings(actor).mForwardBackward = 0;
return true;
}
}
if(actor.getCell()->mCell->mData.mY != player.getCell()->mCell->mData.mY)
{
2013-03-14 18:05:00 +00:00
int sideY = sgn(actor.getCell()->mCell->mData.mY - player.getCell()->mCell->mData.mY);
//check if actor is near the border of an inactive cell. If so, disable aitravel.
if(sideY*(pos.pos[1] - actor.getCell()->mCell->mData.mY * ESM::Land::REAL_SIZE) > sideY*(ESM::Land::REAL_SIZE/2. - 2000))
{
MWWorld::Class::get(actor).getMovementSettings(actor).mForwardBackward = 0;
return true;
}
}
2013-03-14 18:05:00 +00:00
2013-04-01 12:38:13 +00:00
if(!mPathFinder.isPathConstructed() ||cellChange)
{
cellX = actor.getCell()->mCell->mData.mX;
cellY = actor.getCell()->mCell->mData.mY;
float xCell = 0;
float yCell = 0;
if (actor.getCell()->mCell->isExterior())
{
xCell = actor.getCell()->mCell->mData.mX * ESM::Land::REAL_SIZE;
yCell = actor.getCell()->mCell->mData.mY * ESM::Land::REAL_SIZE;
}
2013-03-06 21:17:33 +00:00
ESM::Pathgrid::Point dest;
dest.mX = mX;
dest.mY = mY;
dest.mZ = mZ;
2013-03-31 17:30:03 +00:00
ESM::Pathgrid::Point start;
dest.mX = pos.pos[0];
dest.mY = pos.pos[1];
dest.mZ = pos.pos[2];
2013-04-01 12:38:13 +00:00
mPathFinder.buildPath(start,dest,pathgrid,xCell,yCell);
}
2013-03-31 17:30:03 +00:00
if(mPathFinder.checkIfNextPointReached(pos.pos[0],pos.pos[1],pos.pos[2]))
{
MWWorld::Class::get(actor).getMovementSettings(actor).mForwardBackward = 0;
return true;
}
2013-03-31 17:30:03 +00:00
float zAngle = mPathFinder.getZAngleToNext(pos.pos[0],pos.pos[1],pos.pos[2]);
MWBase::Environment::get().getWorld()->rotateObject(actor,0,0,zAngle,false);
MWWorld::Class::get(actor).getMovementSettings(actor).mForwardBackward = 1;
return false;
2012-11-14 18:42:04 +01:00
}
2012-11-15 22:15:20 +01:00
2012-11-14 18:42:04 +01:00
int MWMechanics::AiTravel::getTypeId() const
{
return 1;
}