hlsdk-portable/dlls/spectator.cpp

149 lines
3.0 KiB
C++
Raw Normal View History

2017-12-18 02:39:44 +03:00
/***
*
* Copyright (c) 1996-2002, Valve LLC. All rights reserved.
*
* This product contains software technology licensed from Id
* Software, Inc. ("Id Technology"). Id Technology (c) 1996 Id Software, Inc.
* All Rights Reserved.
*
* Use, distribution, and modification of this source code and/or resulting
* object code is restricted to non-commercial enhancements to products from
* Valve LLC. All other use, distribution, or modification is prohibited
* without written permission from Valve LLC.
*
****/
// CBaseSpectator
// YWB: UNDONE
// Spectator functions
//
2017-12-18 02:39:44 +03:00
#include "extdll.h"
#include "util.h"
#include "cbase.h"
#include "monsters.h"
#include "spectator.h"
/*
===========
SpectatorConnect
called when a spectator connects to a server
============
*/
2016-07-31 18:48:50 +05:00
void CBaseSpectator::SpectatorConnect( void )
2017-12-18 02:39:44 +03:00
{
pev->flags = FL_SPECTATOR;
pev->solid = SOLID_NOT;
pev->movetype = MOVETYPE_NOCLIP;
2017-12-18 02:39:44 +03:00
m_pGoalEnt = NULL;
}
/*
===========
SpectatorDisconnect
called when a spectator disconnects from a server
============
*/
2016-07-31 18:48:50 +05:00
void CBaseSpectator::SpectatorDisconnect( void )
2017-12-18 02:39:44 +03:00
{
}
/*
================
SpectatorImpulseCommand
Called by SpectatorThink if the spectator entered an impulse
================
*/
2016-07-31 18:48:50 +05:00
void CBaseSpectator::SpectatorImpulseCommand( void )
2017-12-18 02:39:44 +03:00
{
2016-07-31 18:48:50 +05:00
static edict_t *pGoal = NULL;
2017-12-18 02:39:44 +03:00
CBaseEntity *pPreviousGoal;
CBaseEntity *pCurrentGoal;
2016-07-31 18:48:50 +05:00
BOOL bFound;
2016-07-31 18:48:50 +05:00
switch( pev->impulse )
2017-12-18 02:39:44 +03:00
{
case 1:
// teleport the spectator to the next spawn point; note that if the spectator is
// tracking, this doesn't do much
pPreviousGoal = (CBaseEntity*)GET_PRIVATE(pGoal);
pCurrentGoal = (CBaseEntity*)GET_PRIVATE(pGoal);
// Start at the current goal, skip the world, and stop if we looped back around
bFound = FALSE;
2016-07-31 18:48:50 +05:00
while( 1 )
2017-12-18 02:39:44 +03:00
{
pCurrentGoal = UTIL_FindEntityByClassname(pCurrentGoal, "info_player_deathmatch");
// Looped around, failure
2016-07-31 18:48:50 +05:00
if( pCurrentGoal == pPreviousGoal )
2017-12-18 02:39:44 +03:00
{
2016-07-31 18:48:50 +05:00
ALERT( at_console, "Could not find a spawn spot.\n" );
2017-12-18 02:39:44 +03:00
break;
}
// Found a non-world entity, set success, otherwise, look for the next one.
if ( pCurrentGoal )
{
bFound = TRUE;
break;
}
}
2016-07-31 18:48:50 +05:00
if( !bFound ) // Didn't find a good spot.
2017-12-18 02:39:44 +03:00
break;
2017-12-18 02:39:44 +03:00
pGoal = ENT(pCurrentGoal->pev);
UTIL_SetOrigin( this, pGoal->v.origin );
pev->angles = pGoal->v.angles;
pev->fixangle = FALSE;
break;
default:
2016-07-31 18:48:50 +05:00
ALERT( at_console, "Unknown spectator impulse\n" );
2017-12-18 02:39:44 +03:00
break;
}
pev->impulse = 0;
}
/*
================
SpectatorThink
Called every frame after physics are run
================
*/
2016-07-31 18:48:50 +05:00
void CBaseSpectator::SpectatorThink( void )
2017-12-18 02:39:44 +03:00
{
2016-07-31 18:48:50 +05:00
if( !( pev->flags & FL_SPECTATOR ) )
2017-12-18 02:39:44 +03:00
{
pev->flags = FL_SPECTATOR;
}
2016-07-31 18:48:50 +05:00
pev->solid = SOLID_NOT;
pev->movetype = MOVETYPE_NOCLIP;
2017-12-18 02:39:44 +03:00
2016-07-31 18:48:50 +05:00
if( pev->impulse )
2017-12-18 02:39:44 +03:00
SpectatorImpulseCommand();
}
/*
===========
Spawn
Called when spectator is initialized:
UNDONE: Is this actually being called because spectators are not allocated in normal fashion?
============
*/
void CBaseSpectator::Spawn()
{
pev->flags = FL_SPECTATOR;
pev->solid = SOLID_NOT;
pev->movetype = MOVETYPE_NOCLIP;
2017-12-18 02:39:44 +03:00
m_pGoalEnt = NULL;
}