mirror of
https://github.com/s1lentq/ReGameDLL_CS.git
synced 2025-01-14 23:58:06 +03:00
3d252fe527
Fixed some critical bugs and typos (carrer_task, tutor, zbot and other) Added command line option `-bots` to run bots in CS 1.6 Removed the tests demo record/player from myself the project and also dependency of the steam library. Fixed the progress bar when generating a nav file.
393 lines
8.5 KiB
C++
393 lines
8.5 KiB
C++
#include "precompiled.h"
|
|
|
|
CBaseTutor *TheTutor = NULL;
|
|
|
|
TutorMessageEvent::TutorMessageEvent(int mid, int duplicateID, float time, float lifetime, int priority)
|
|
{
|
|
m_messageID = mid;
|
|
m_duplicateID = duplicateID;
|
|
m_activationTime = time;
|
|
m_lifetime = lifetime;
|
|
m_priority = priority;
|
|
|
|
m_paramList = NULL;
|
|
m_numParameters = 0;
|
|
m_next = NULL;
|
|
}
|
|
|
|
TutorMessageEvent::~TutorMessageEvent()
|
|
{
|
|
;
|
|
}
|
|
|
|
bool TutorMessageEvent::IsActive(float time)
|
|
{
|
|
return (m_lifetime + m_activationTime >= time);
|
|
}
|
|
|
|
int TutorMessageEvent::GetPriority()
|
|
{
|
|
return m_priority;
|
|
}
|
|
|
|
float TutorMessageEvent::GetTimeActive(float time)
|
|
{
|
|
return (time - m_activationTime);
|
|
}
|
|
|
|
void TutorMessageEvent::SetActivationTime(float time)
|
|
{
|
|
m_activationTime = time;
|
|
}
|
|
|
|
int TutorMessageEvent::GetID()
|
|
{
|
|
return m_messageID;
|
|
}
|
|
|
|
int TutorMessageEvent::GetDuplicateID()
|
|
{
|
|
return m_duplicateID;
|
|
}
|
|
|
|
void TutorMessageEvent::SetNext(TutorMessageEvent *next)
|
|
{
|
|
m_next = next;
|
|
}
|
|
|
|
TutorMessageEvent *TutorMessageEvent::GetNext()
|
|
{
|
|
return m_next;
|
|
}
|
|
|
|
void TutorMessageEvent::AddParameter(char *str)
|
|
{
|
|
if (str == NULL)
|
|
return;
|
|
|
|
TutorMessageEventParam *param = new TutorMessageEventParam;
|
|
|
|
param->m_next = NULL;
|
|
param->m_data = new char[Q_strlen(str) + 1];
|
|
|
|
if (param->m_data != NULL)
|
|
{
|
|
Q_strcpy(param->m_data, str);
|
|
param->m_data[Q_strlen(str)] = '\0';
|
|
++m_numParameters;
|
|
|
|
if (m_paramList != NULL)
|
|
{
|
|
TutorMessageEventParam *temp = m_paramList;
|
|
|
|
while (temp->m_next)
|
|
temp = temp->m_next;
|
|
|
|
temp->m_next = param;
|
|
}
|
|
else
|
|
m_paramList = param;
|
|
}
|
|
}
|
|
|
|
char *TutorMessageEvent::GetNextParameter(char *buf, int buflen)
|
|
{
|
|
TutorMessageEventParam *param = m_paramList;
|
|
|
|
if (param == NULL)
|
|
return NULL;
|
|
|
|
m_numParameters--;
|
|
m_paramList = param->m_next;
|
|
|
|
Q_strncpy(buf, param->m_data, buflen);
|
|
|
|
#ifdef REGAMEDLL_FIXES
|
|
buf[buflen] = '\0';
|
|
#endif
|
|
|
|
delete param;
|
|
return buf;
|
|
}
|
|
|
|
int TutorMessageEvent::GetNumParameters()
|
|
{
|
|
return m_numParameters;
|
|
}
|
|
|
|
CBaseTutor::CBaseTutor()
|
|
{
|
|
m_eventList = NULL;
|
|
m_deadAirStartTime = 0;
|
|
m_roundStartTime = 0;
|
|
}
|
|
|
|
CBaseTutor::~CBaseTutor()
|
|
{
|
|
TutorMessageEvent *event = m_eventList;
|
|
|
|
while (event != NULL)
|
|
{
|
|
TutorMessageEvent *temp = event;
|
|
event = event->GetNext();
|
|
|
|
delete temp;
|
|
}
|
|
}
|
|
|
|
void CBaseTutor::OnEvent(GameEventType event, CBaseEntity *entity, CBaseEntity *other)
|
|
{
|
|
CallEventHandler(event, entity, other);
|
|
CheckForStateTransition(event, entity, other);
|
|
}
|
|
|
|
void CBaseTutor::ShotFired(Vector source, Vector target)
|
|
{
|
|
HandleShotFired(source, target);
|
|
}
|
|
|
|
void CBaseTutor::CheckForStateTransition(GameEventType event, CBaseEntity *entity, CBaseEntity *other)
|
|
{
|
|
if (m_stateSystem->UpdateState(event, entity, other))
|
|
{
|
|
DisplayNewStateDescriptionToPlayer();
|
|
}
|
|
}
|
|
|
|
void CBaseTutor::StartFrame(float time)
|
|
{
|
|
TutorThink(time);
|
|
}
|
|
|
|
void CBaseTutor::DisplayMessageToPlayer(CBasePlayer *player, int id, const char *szMessage, TutorMessageEvent *event)
|
|
{
|
|
TutorMessage *definition;
|
|
int numArgs;
|
|
char param[512];
|
|
|
|
numArgs = event->GetNumParameters();
|
|
definition = GetTutorMessageDefinition(event->GetID());
|
|
|
|
MESSAGE_BEGIN(MSG_ONE, gmsgTutorText, NULL, player->pev);
|
|
WRITE_STRING(szMessage);
|
|
WRITE_BYTE(numArgs);
|
|
|
|
for (int arg = 0; arg < numArgs; ++arg)
|
|
{
|
|
char *str = event->GetNextParameter(param, sizeof(param));
|
|
|
|
if (str != NULL)
|
|
WRITE_STRING(str);
|
|
else
|
|
WRITE_STRING("");
|
|
}
|
|
|
|
WRITE_SHORT(id);
|
|
WRITE_SHORT(player->IsAlive() == FALSE);
|
|
|
|
if (definition != NULL)
|
|
WRITE_SHORT(definition->m_type);
|
|
else
|
|
WRITE_SHORT(TUTORMESSAGETYPE_DEFAULT);
|
|
MESSAGE_END();
|
|
|
|
m_deadAirStartTime = -1.0f;
|
|
|
|
if (definition != NULL)
|
|
{
|
|
if (gpGlobals->time - m_roundStartTime > 1.0f)
|
|
{
|
|
switch (definition->m_type)
|
|
{
|
|
case TUTORMESSAGETYPE_FRIEND_DEATH:
|
|
EMIT_SOUND_DYN(ENT(player->pev), CHAN_ITEM, "events/friend_died.wav", VOL_NORM, ATTN_NORM, 0, 120);
|
|
break;
|
|
case TUTORMESSAGETYPE_ENEMY_DEATH:
|
|
EMIT_SOUND_DYN(ENT(player->pev), CHAN_ITEM, "events/enemy_died.wav", VOL_NORM, ATTN_NORM, 0, 85);
|
|
break;
|
|
default:
|
|
EMIT_SOUND_DYN(ENT(player->pev), CHAN_ITEM, "events/tutor_msg.wav", VOL_NORM, ATTN_NORM, 0, 100);
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (definition->m_decay)
|
|
{
|
|
REGISTER_TUTOR_MESSAGE_SHOWN(id);
|
|
}
|
|
}
|
|
}
|
|
|
|
NOXREF void CBaseTutor::DrawLineToEntity(CBasePlayer *player, int entindex, int id)
|
|
{
|
|
MESSAGE_BEGIN(MSG_ONE, gmsgTutorLine, NULL, player->pev);
|
|
WRITE_SHORT(entindex);
|
|
WRITE_SHORT(id);
|
|
MESSAGE_END();
|
|
}
|
|
|
|
void CBaseTutor::DisplayNewStateDescriptionToPlayer()
|
|
{
|
|
CBasePlayer *localPlayer = UTIL_GetLocalPlayer();
|
|
|
|
if (localPlayer == NULL)
|
|
return;
|
|
|
|
char *desc = m_stateSystem->GetCurrentStateString();
|
|
if (!desc)
|
|
{
|
|
MESSAGE_BEGIN(MSG_ONE, gmsgTutorState, NULL, localPlayer->pev);
|
|
WRITE_STRING(NULL);
|
|
MESSAGE_END();
|
|
}
|
|
}
|
|
|
|
void CBaseTutor::CloseCurrentWindow()
|
|
{
|
|
CBasePlayer *localPlayer = (CBasePlayer *)UTIL_GetLocalPlayer();
|
|
|
|
if (localPlayer != NULL)
|
|
{
|
|
MESSAGE_BEGIN(MSG_ONE, gmsgTutorClose, NULL, localPlayer->pev);
|
|
MESSAGE_END();
|
|
|
|
m_deadAirStartTime = gpGlobals->time;
|
|
}
|
|
}
|
|
|
|
void CBaseTutor::CalculatePathForObjective(CBaseEntity *player)
|
|
{
|
|
;
|
|
}
|
|
|
|
bool CBaseTutor::__MAKE_VHOOK(IsEntityInViewOfPlayer)(CBaseEntity *entity, CBasePlayer *player)
|
|
{
|
|
if (entity == NULL || player == NULL)
|
|
return false;
|
|
|
|
if (cv_tutor_view_distance.value < (entity->pev->origin - player->pev->origin).Length())
|
|
return false;
|
|
|
|
if (player->FInViewCone(entity))
|
|
{
|
|
TraceResult result;
|
|
Vector eye = player->pev->view_ofs + player->pev->origin;
|
|
|
|
UTIL_TraceLine(eye, entity->pev->origin, ignore_monsters, ignore_glass, player->pev->pContainingEntity, &result);
|
|
|
|
if (result.flFraction == 1.0f)
|
|
{
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
bool CBaseTutor::__MAKE_VHOOK(IsPlayerLookingAtPosition)(Vector *origin, CBasePlayer *player)
|
|
{
|
|
if (origin == NULL || player == NULL)
|
|
return false;
|
|
|
|
if (cv_tutor_look_distance.value < (*origin - player->pev->origin).Length())
|
|
return false;
|
|
|
|
if (player->IsLookingAtPosition(origin, cv_tutor_look_angle.value))
|
|
{
|
|
TraceResult result;
|
|
Vector eye = player->pev->origin + player->pev->view_ofs;
|
|
|
|
UTIL_TraceLine(eye, *origin, ignore_monsters, ignore_glass, ENT(player->pev), &result);
|
|
|
|
if (result.flFraction == 1.0f)
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
bool CBaseTutor::__MAKE_VHOOK(IsPlayerLookingAtEntity)(CBaseEntity *entity, CBasePlayer *player)
|
|
{
|
|
if (entity == NULL || player == NULL)
|
|
return false;
|
|
|
|
UTIL_MakeVectors(player->pev->v_angle);
|
|
|
|
Vector srcVec = player->pev->view_ofs + player->pev->origin;
|
|
Vector destVec = gpGlobals->v_forward * cv_tutor_look_distance.value + srcVec;
|
|
|
|
TraceResult result;
|
|
UTIL_TraceLine(srcVec, destVec, dont_ignore_monsters, ignore_glass, ENT(player->pev), &result);
|
|
|
|
if (result.pHit != NULL)
|
|
{
|
|
if (!FNullEnt(result.pHit) && CBaseEntity::Instance(result.pHit) == entity)
|
|
{
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
bool CBaseTutor::__MAKE_VHOOK(IsBombsiteInViewOfPlayer)(CBaseEntity *entity, CBasePlayer *player)
|
|
{
|
|
if (entity == NULL || player == NULL)
|
|
return false;
|
|
|
|
Vector bombSiteCenter = (entity->pev->absmax + entity->pev->absmin) * 0.5f;
|
|
|
|
if (cv_tutor_view_distance.value < (bombSiteCenter - player->pev->origin).Length())
|
|
return false;
|
|
|
|
if (player->FInViewCone(entity))
|
|
{
|
|
TraceResult result;
|
|
Vector eye = player->pev->origin + player->pev->view_ofs;
|
|
|
|
UTIL_TraceLine(eye, bombSiteCenter, ignore_monsters, ignore_glass, ENT(player->pev), &result);
|
|
|
|
if (result.flFraction == 1.0f)
|
|
{
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
bool CBaseTutor::__MAKE_VHOOK(IsEntityInBombsite)(CBaseEntity *bombsite, CBaseEntity *entity)
|
|
{
|
|
if (bombsite == NULL || entity == NULL)
|
|
return false;
|
|
|
|
if (entity->pev->origin.x <= bombsite->pev->absmax.x
|
|
&& entity->pev->origin.y <= bombsite->pev->absmax.y
|
|
&& entity->pev->origin.z <= bombsite->pev->absmax.z
|
|
&& entity->pev->origin.x >= bombsite->pev->absmin.x
|
|
&& entity->pev->origin.y >= bombsite->pev->absmin.y
|
|
&& entity->pev->origin.z >= bombsite->pev->absmin.z)
|
|
{
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
bool CBaseTutor::DoMessagesHaveSameID(int id1, int id2)
|
|
{
|
|
if (id1 == id2)
|
|
return true;
|
|
|
|
TutorMessage *message1 = GetTutorMessageDefinition(id1);
|
|
TutorMessage *message2 = GetTutorMessageDefinition(id2);
|
|
|
|
if (message1 == NULL || message2 == NULL)
|
|
return false;
|
|
|
|
if (message1->m_duplicateID && message2->m_duplicateID)
|
|
return true;
|
|
|
|
return false;
|
|
}
|