|
|
@ -1234,8 +1234,8 @@ namespace MWMechanics
|
|
|
|
const float maxTimeToCheck = 2.0f;
|
|
|
|
const float maxTimeToCheck = 2.0f;
|
|
|
|
static const bool giveWayWhenIdle = Settings::Manager::getBool("NPCs give way", "Game");
|
|
|
|
static const bool giveWayWhenIdle = Settings::Manager::getBool("NPCs give way", "Game");
|
|
|
|
|
|
|
|
|
|
|
|
MWWorld::Ptr player = getPlayer();
|
|
|
|
const MWWorld::Ptr player = getPlayer();
|
|
|
|
MWBase::World* world = MWBase::Environment::get().getWorld();
|
|
|
|
const MWBase::World* world = MWBase::Environment::get().getWorld();
|
|
|
|
for(PtrActorMap::iterator iter(mActors.begin()); iter != mActors.end(); ++iter)
|
|
|
|
for(PtrActorMap::iterator iter(mActors.begin()); iter != mActors.end(); ++iter)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
const MWWorld::Ptr& ptr = iter->first;
|
|
|
|
const MWWorld::Ptr& ptr = iter->first;
|
|
|
@ -1260,23 +1260,26 @@ namespace MWMechanics
|
|
|
|
bool shouldTurnToApproachingActor = !isMoving;
|
|
|
|
bool shouldTurnToApproachingActor = !isMoving;
|
|
|
|
MWWorld::Ptr currentTarget; // Combat or pursue target (NPCs should not avoid collision with their targets).
|
|
|
|
MWWorld::Ptr currentTarget; // Combat or pursue target (NPCs should not avoid collision with their targets).
|
|
|
|
const auto& aiSequence = ptr.getClass().getCreatureStats(ptr).getAiSequence();
|
|
|
|
const auto& aiSequence = ptr.getClass().getCreatureStats(ptr).getAiSequence();
|
|
|
|
for (const auto& package : aiSequence)
|
|
|
|
if (!aiSequence.isEmpty())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (package->getTypeId() == AiPackageTypeId::Follow)
|
|
|
|
const auto& package = aiSequence.getActivePackage();
|
|
|
|
|
|
|
|
if (package.getTypeId() == AiPackageTypeId::Follow)
|
|
|
|
|
|
|
|
{
|
|
|
|
shouldAvoidCollision = true;
|
|
|
|
shouldAvoidCollision = true;
|
|
|
|
else if (package->getTypeId() == AiPackageTypeId::Wander && giveWayWhenIdle)
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (package.getTypeId() == AiPackageTypeId::Wander && giveWayWhenIdle)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (!static_cast<const AiWander*>(package.get())->isStationary())
|
|
|
|
if (!static_cast<const AiWander&>(package).isStationary())
|
|
|
|
shouldGiveWay = true;
|
|
|
|
shouldGiveWay = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (package->getTypeId() == AiPackageTypeId::Combat || package->getTypeId() == AiPackageTypeId::Pursue)
|
|
|
|
else if (package.getTypeId() == AiPackageTypeId::Combat || package.getTypeId() == AiPackageTypeId::Pursue)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
currentTarget = package->getTarget();
|
|
|
|
currentTarget = package.getTarget();
|
|
|
|
shouldAvoidCollision = isMoving;
|
|
|
|
shouldAvoidCollision = isMoving;
|
|
|
|
shouldTurnToApproachingActor = false;
|
|
|
|
shouldTurnToApproachingActor = false;
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (!shouldAvoidCollision && !shouldGiveWay)
|
|
|
|
if (!shouldAvoidCollision && !shouldGiveWay)
|
|
|
|
continue;
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
|
|