//========= Copyright © 1996-2005, Valve Corporation, All rights reserved. ============// // // Purpose: Hooks and classes for the support of humanoid NPCs with // groovy facial animation capabilities, aka, "Actors" // //=============================================================================// #include "cbase.h" #include "AI_Interest_Target.h" // memdbgon must be the last include file in a .cpp file!!! #include "tier0/memdbgon.h" bool CAI_InterestTarget_t::IsThis( CBaseEntity *pThis ) { return (pThis == m_hTarget); }; const Vector &CAI_InterestTarget_t::GetPosition( void ) { if (m_eType == LOOKAT_ENTITY && m_hTarget != NULL) { m_vecPosition = m_hTarget->EyePosition(); } return m_vecPosition; }; bool CAI_InterestTarget_t::IsActive( void ) { if (m_flEndTime < gpGlobals->curtime) return false; if (m_eType == LOOKAT_ENTITY && m_hTarget == NULL) return false; return true; }; float CAI_InterestTarget_t::Interest( void ) { float t = (gpGlobals->curtime - m_flStartTime) / (m_flEndTime - m_flStartTime); if (t < 0.0f || t > 1.0f) return 0.0f; if (m_flRamp && t < 1 - m_flRamp) { //t = t / m_flRamp; t = 1.0 - ExponentialDecay( 0.2, m_flRamp, t ); //t = 1.0 - ExponentialDecay( 0.01, 1 - m_flRamp, t ); } else if (t > 1.0f - m_flRamp) { t = (1.0 - t) / m_flRamp; t = 3.0f * t * t - 2.0f * t * t * t; } else { t = 1.0f; } // ramp t *= m_flInterest; return t; } void CAI_InterestTarget::Add( CBaseEntity *pTarget, float flImportance, float flDuration, float flRamp ) { int i; for (i = 0; i < Count(); i++) { CAI_InterestTarget_t &target = Element( i ); if (target.m_hTarget == pTarget && target.m_flRamp == 0) { if (target.m_flStartTime == gpGlobals->curtime) { flImportance = max( flImportance, target.m_flInterest ); } Remove( i ); break; } } Add( CAI_InterestTarget_t::LOOKAT_ENTITY, pTarget, Vector( 0, 0, 0 ), flImportance, flDuration, flRamp ); } void CAI_InterestTarget::Add( const Vector &vecPosition, float flImportance, float flDuration, float flRamp ) { int i; for (i = 0; i < Count(); i++) { CAI_InterestTarget_t &target = Element( i ); if (target.m_vecPosition == vecPosition) { Remove( i ); break; } } Add( CAI_InterestTarget_t::LOOKAT_POSITION, NULL, vecPosition, flImportance, flDuration, flRamp ); } void CAI_InterestTarget::Add( CBaseEntity *pTarget, const Vector &vecPosition, float flImportance, float flDuration, float flRamp ) { int i; for (i = 0; i < Count(); i++) { CAI_InterestTarget_t &target = Element( i ); if (target.m_hTarget == pTarget) { if (target.m_flStartTime == gpGlobals->curtime) { flImportance = max( flImportance, target.m_flInterest ); } Remove( i ); break; } } Add( CAI_InterestTarget_t::LOOKAT_BOTH, pTarget, vecPosition, flImportance, flDuration, flRamp ); } void CAI_InterestTarget::Add( CAI_InterestTarget_t::CAI_InterestTarget_e type, CBaseEntity *pTarget, const Vector &vecPosition, float flImportance, float flDuration, float flRamp ) { int i = AddToTail(); CAI_InterestTarget_t &target = Element( i ); target.m_eType = type; target.m_hTarget = pTarget; target.m_vecPosition = vecPosition; target.m_flInterest = flImportance; target.m_flStartTime = gpGlobals->curtime; target.m_flEndTime = gpGlobals->curtime + flDuration; target.m_flRamp = flRamp / flDuration; }