2015-06-30 15:46:07 +06:00
|
|
|
#include "precompiled.h"
|
|
|
|
|
2016-01-21 23:36:05 +06:00
|
|
|
// Move towards currently heard noise
|
2016-01-25 23:02:57 +06:00
|
|
|
void InvestigateNoiseState::AttendCurrentNoise(CCSBot *me)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2016-01-25 23:02:57 +06:00
|
|
|
if (!me->IsNoiseHeard() && me->GetNoisePosition())
|
|
|
|
return;
|
|
|
|
|
|
|
|
// remember where the noise we heard was
|
|
|
|
m_checkNoisePosition = *me->GetNoisePosition();
|
|
|
|
|
|
|
|
// tell our teammates (unless the noise is obvious, like gunfire)
|
|
|
|
if (me->IsWellPastSafe() && me->HasNotSeenEnemyForLongTime() && me->GetNoisePriority() != PRIORITY_HIGH)
|
|
|
|
me->GetChatter()->HeardNoise(me->GetNoisePosition());
|
|
|
|
|
2016-02-04 06:18:26 +06:00
|
|
|
// figure out how to get to the noise
|
2016-01-25 23:02:57 +06:00
|
|
|
me->PrintIfWatched("Attending to noise...\n");
|
|
|
|
me->ComputePath(me->GetNoiseArea(), &m_checkNoisePosition, SAFEST_ROUTE);
|
|
|
|
|
|
|
|
// consume the noise
|
|
|
|
me->ForgetNoise();
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
2016-01-25 23:02:57 +06:00
|
|
|
void InvestigateNoiseState::__MAKE_VHOOK(OnEnter)(CCSBot *me)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2016-01-25 23:02:57 +06:00
|
|
|
AttendCurrentNoise(me);
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
2016-01-25 23:02:57 +06:00
|
|
|
// Use TravelDistance instead of distance...
|
|
|
|
void InvestigateNoiseState::__MAKE_VHOOK(OnUpdate)(CCSBot *me)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2016-01-25 23:02:57 +06:00
|
|
|
float newNoiseDist;
|
|
|
|
if (me->ShouldInvestigateNoise(&newNoiseDist))
|
|
|
|
{
|
|
|
|
Vector toOldNoise = m_checkNoisePosition - me->pev->origin;
|
|
|
|
const float muchCloserDist = 100.0f;
|
|
|
|
if (toOldNoise.IsLengthGreaterThan(newNoiseDist + muchCloserDist))
|
|
|
|
{
|
|
|
|
// new sound is closer
|
|
|
|
AttendCurrentNoise(me);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// if the pathfind fails, give up
|
|
|
|
if (!me->HasPath())
|
|
|
|
{
|
|
|
|
me->Idle();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// look around
|
|
|
|
me->UpdateLookAround();
|
|
|
|
|
|
|
|
// get distance remaining on our path until we reach the source of the noise
|
|
|
|
float noiseDist = (m_checkNoisePosition - me->pev->origin).Length();
|
|
|
|
|
|
|
|
if (me->IsUsingKnife())
|
|
|
|
{
|
|
|
|
if (me->IsHurrying())
|
|
|
|
me->Run();
|
|
|
|
else
|
|
|
|
me->Walk();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
const float closeToNoiseRange = 1500.0f;
|
|
|
|
if (noiseDist < closeToNoiseRange)
|
|
|
|
{
|
|
|
|
// if we dont have many friends left, or we are alone, and we are near noise source, sneak quietly
|
|
|
|
if (me->GetFriendsRemaining() <= 2 && !me->IsHurrying())
|
|
|
|
{
|
|
|
|
me->Walk();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
me->Run();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
me->Run();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// if we can see the noise position and we're close enough to it and looking at it,
|
|
|
|
// we don't need to actually move there (it's checked enough)
|
|
|
|
const float closeRange = 200.0f;
|
|
|
|
if (noiseDist < closeRange)
|
|
|
|
{
|
|
|
|
if (me->IsLookingAtPosition(&m_checkNoisePosition) && me->IsVisible(&m_checkNoisePosition))
|
|
|
|
{
|
|
|
|
// can see noise position
|
|
|
|
me->PrintIfWatched("Noise location is clear.\n");
|
|
|
|
//me->ForgetNoise();
|
|
|
|
me->Idle();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// move towards noise
|
|
|
|
if (me->UpdatePathMovement() != CCSBot::PROGRESSING)
|
|
|
|
{
|
|
|
|
me->Idle();
|
|
|
|
}
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
2016-01-25 23:02:57 +06:00
|
|
|
void InvestigateNoiseState::__MAKE_VHOOK(OnExit)(CCSBot *me)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2016-01-25 23:02:57 +06:00
|
|
|
// reset to run mode in case we were sneaking about
|
|
|
|
me->Run();
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|