2015-06-30 15:46:07 +06:00
/*
*
* This program is free software ; you can redistribute it and / or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation ; either version 2 of the License , or ( at
* your option ) any later version .
*
* This program is distributed in the hope that it will be useful , but
* WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software Foundation ,
* Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*
* In addition , as a special exception , the author gives permission to
* link the code of this program with the Half - Life Game Engine ( " HL
* Engine " ) and Modified Game Libraries ( " MODs " ) developed by Valve,
* L . L . C ( " Valve " ) . You must obey the GNU General Public License in all
* respects for all of the code used other than the HL Engine and MODs
* from Valve . If you modify this file , you may extend this exception
* to your version of the file , but you are not obligated to do so . If
* you do not wish to do so , delete this exception statement from your
* version .
*
*/
# ifndef TRIGGERS_H
# define TRIGGERS_H
# ifdef _WIN32
# pragma once
# endif
2015-08-20 16:35:01 +06:00
# define GRENADETYPE_SMOKE 1
# define GRENADETYPE_FLASH 2
2015-06-30 15:46:07 +06:00
2015-08-20 16:35:01 +06:00
# define MAX_ITEM_COUNTS 32
# define MAX_ENTITY 512 // We can only ever move 512 entities across a transition
2015-06-30 15:46:07 +06:00
2015-12-09 04:39:54 +06:00
// triggers
2016-03-13 19:11:22 +06:00
# define SF_TRIGGER_ALLOWMONSTERS 1 // monsters allowed to fire this trigger
# define SF_TRIGGER_NOCLIENTS 2 // players not allowed to fire this trigger
2015-09-17 02:19:21 +06:00
# define SF_TRIGGER_PUSHABLES 4 // only pushables can fire this trigger
2016-03-13 19:11:22 +06:00
# define SF_TRIGGER_PUSH_START_OFF 2 // spawnflag that makes trigger_push spawn turned OFF
2015-12-09 04:39:54 +06:00
# define SF_TRIGGER_HURT_TARGETONCE 1 // Only fire hurt target once
2016-03-13 19:11:22 +06:00
# define SF_TRIGGER_HURT_START_OFF 2 // spawnflag that makes trigger_push spawn turned OFF
# define SF_TRIGGER_HURT_NO_CLIENTS 8 // spawnflag that makes trigger_push spawn turned OFF
2015-12-09 04:39:54 +06:00
# define SF_TRIGGER_HURT_CLIENTONLYFIRE 16 // trigger hurt will only fire its target if it is hurting a client
2015-09-17 02:19:21 +06:00
# define SF_TRIGGER_HURT_CLIENTONLYTOUCH 32 // only clients may touch this trigger.
2015-06-30 15:46:07 +06:00
2015-08-20 16:35:01 +06:00
# define SF_AUTO_FIREONCE 0x0001
# define SF_RELAY_FIREONCE 0x0001
2015-09-17 02:19:21 +06:00
# define SF_ENDSECTION_USEONLY 0x0001
2015-06-30 15:46:07 +06:00
2015-08-20 16:35:01 +06:00
# define SF_MULTIMAN_CLONE 0x80000000
# define SF_MULTIMAN_THREAD 0x00000001
2015-06-30 15:46:07 +06:00
2015-08-20 16:35:01 +06:00
# define SF_CHANGELEVEL_USEONLY 0x0002
# define SF_CAMERA_PLAYER_POSITION 1
# define SF_CAMERA_PLAYER_TARGET 2
# define SF_CAMERA_PLAYER_TAKECONTROL 4
2015-06-30 15:46:07 +06:00
2015-12-09 04:39:54 +06:00
// Flags to indicate masking off various render parameters that are normally copied to the targets
# define SF_RENDER_MASKFX (1 << 0)
# define SF_RENDER_MASKAMT (1 << 1)
# define SF_RENDER_MASKMODE (1 << 2)
# define SF_RENDER_MASKCOLOR (1 << 3)
2015-09-17 02:19:21 +06:00
2015-06-30 15:46:07 +06:00
class CFrictionModifier : public CBaseEntity
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
virtual int Save ( CSave & save ) ;
virtual int Restore ( CRestore & restore ) ;
2016-02-04 06:18:26 +06:00
virtual int ObjectCaps ( ) { return ( CBaseEntity : : ObjectCaps ( ) & ~ FCAP_ACROSS_TRANSITION ) ; }
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-06-30 15:46:07 +06:00
void KeyValue_ ( KeyValueData * pkvd ) ;
int Save_ ( CSave & save ) ;
int Restore_ ( CRestore & restore ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
public :
2015-09-17 02:19:21 +06:00
void EXPORT ChangeFriction ( CBaseEntity * pOther ) ;
2015-12-09 04:39:54 +06:00
static TYPEDESCRIPTION IMPL ( m_SaveData ) [ 1 ] ;
2015-06-30 15:46:07 +06:00
float m_frictionFraction ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
2015-12-09 04:39:54 +06:00
// This trigger will fire when the level spawns (or respawns if not fire once)
2015-09-17 02:19:21 +06:00
// It will check a global state before firing. It supports delay and killtargets
2015-06-30 15:46:07 +06:00
class CAutoTrigger : public CBaseDelay
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
virtual void Precache ( ) ;
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
virtual int Save ( CSave & save ) ;
virtual int Restore ( CRestore & restore ) ;
2016-02-04 06:18:26 +06:00
virtual int ObjectCaps ( ) { return ( CBaseDelay : : ObjectCaps ( ) & ~ FCAP_ACROSS_TRANSITION ) ; }
virtual void Think ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
void Precache_ ( ) ;
2015-06-30 15:46:07 +06:00
void KeyValue_ ( KeyValueData * pkvd ) ;
int Save_ ( CSave & save ) ;
int Restore_ ( CRestore & restore ) ;
2016-02-04 06:18:26 +06:00
void Think_ ( ) ;
2015-06-30 15:46:07 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
public :
2015-12-09 04:39:54 +06:00
static TYPEDESCRIPTION IMPL ( m_SaveData ) [ 2 ] ;
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
int m_globalstate ;
USE_TYPE triggerType ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CTriggerRelay : public CBaseDelay
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
virtual int Save ( CSave & save ) ;
virtual int Restore ( CRestore & restore ) ;
2016-02-04 06:18:26 +06:00
virtual int ObjectCaps ( ) { return ( CBaseDelay : : ObjectCaps ( ) & ~ FCAP_ACROSS_TRANSITION ) ; }
2015-09-17 02:19:21 +06:00
virtual void Use ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-06-30 15:46:07 +06:00
void KeyValue_ ( KeyValueData * pkvd ) ;
int Save_ ( CSave & save ) ;
int Restore_ ( CRestore & restore ) ;
void Use_ ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2015-07-05 17:05:26 +06:00
public :
2015-12-09 04:39:54 +06:00
static TYPEDESCRIPTION IMPL ( m_SaveData ) [ 1 ] ;
2015-06-30 15:46:07 +06:00
USE_TYPE triggerType ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
2015-12-09 04:39:54 +06:00
// The Multimanager Entity - when fired, will fire up to 16 targets
// at specified times.
// FLAG: THREAD (create clones when triggered)
2015-09-17 02:19:21 +06:00
// FLAG: CLONE (this is a clone for a threaded execution)
2015-06-30 15:46:07 +06:00
class CMultiManager : public CBaseToggle
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
virtual void Restart ( ) ;
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
virtual int Save ( CSave & save ) ;
virtual int Restore ( CRestore & restore ) ;
2016-02-04 06:18:26 +06:00
virtual int ObjectCaps ( ) { return ( CBaseToggle : : ObjectCaps ( ) & ~ FCAP_ACROSS_TRANSITION ) ; }
2015-09-17 02:19:21 +06:00
virtual BOOL HasTarget ( string_t targetname ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
void Restart_ ( ) ;
2015-06-30 15:46:07 +06:00
void KeyValue_ ( KeyValueData * pkvd ) ;
int Save_ ( CSave & save ) ;
int Restore_ ( CRestore & restore ) ;
BOOL HasTarget_ ( string_t targetname ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
public :
2016-02-04 06:18:26 +06:00
void EXPORT ManagerThink ( ) ;
2015-09-17 02:19:21 +06:00
void EXPORT ManagerUse ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2015-07-05 17:05:26 +06:00
2015-06-30 15:46:07 +06:00
private :
2016-02-04 06:18:26 +06:00
BOOL IsClone ( )
2015-06-30 15:46:07 +06:00
{
2015-07-13 02:32:09 +06:00
if ( pev - > spawnflags & SF_MULTIMAN_CLONE )
2015-09-17 02:19:21 +06:00
{
2015-06-30 15:46:07 +06:00
return TRUE ;
2015-09-17 02:19:21 +06:00
}
2015-06-30 15:46:07 +06:00
return FALSE ;
}
2016-02-04 06:18:26 +06:00
BOOL ShouldClone ( )
2015-06-30 15:46:07 +06:00
{
2015-07-13 02:32:09 +06:00
if ( IsClone ( ) )
2015-09-17 02:19:21 +06:00
{
2015-06-30 15:46:07 +06:00
return FALSE ;
2015-09-17 02:19:21 +06:00
}
2015-07-13 02:32:09 +06:00
if ( pev - > spawnflags & SF_MULTIMAN_THREAD )
2015-09-17 02:19:21 +06:00
{
2015-06-30 15:46:07 +06:00
return TRUE ;
2015-09-17 02:19:21 +06:00
}
2015-06-30 15:46:07 +06:00
return FALSE ;
}
2016-02-04 06:18:26 +06:00
CMultiManager * Clone ( ) ;
2015-06-30 15:46:07 +06:00
2015-07-05 17:05:26 +06:00
public :
2015-12-09 04:39:54 +06:00
static TYPEDESCRIPTION IMPL ( m_SaveData ) [ 5 ] ;
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
int m_cTargets ;
2015-06-30 15:46:07 +06:00
int m_index ;
float m_startTime ;
int m_iTargetName [ MAX_MULTI_TARGETS ] ;
float m_flTargetDelay [ MAX_MULTI_TARGETS ] ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
2015-12-09 04:39:54 +06:00
// Render parameters trigger
//
// This entity will copy its render parameters (renderfx, rendermode, rendercolor, renderamt)
2015-09-17 02:19:21 +06:00
// to its targets when triggered.
2015-06-30 15:46:07 +06:00
class CRenderFxManager : public CBaseEntity
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-09-17 02:19:21 +06:00
virtual void Use ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-06-30 15:46:07 +06:00
void Use_ ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CBaseTrigger : public CBaseToggle
{
public :
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
2016-02-04 06:18:26 +06:00
virtual int ObjectCaps ( ) { return ( CBaseToggle : : ObjectCaps ( ) & ~ FCAP_ACROSS_TRANSITION ) ; }
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
void KeyValue_ ( KeyValueData * pkvd ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
public :
2015-09-17 02:19:21 +06:00
void EXPORT TeleportTouch ( CBaseEntity * pOther ) ;
void EXPORT MultiTouch ( CBaseEntity * pOther ) ;
void EXPORT HurtTouch ( CBaseEntity * pOther ) ;
2016-02-23 05:13:52 +06:00
void EXPORT CDAudioTouch ( CBaseEntity * pOther ) ;
2015-09-17 02:19:21 +06:00
void ActivateMultiTrigger ( CBaseEntity * pActivator ) ;
2016-02-04 06:18:26 +06:00
void EXPORT MultiWaitOver ( ) ;
2015-09-17 02:19:21 +06:00
void EXPORT CounterUse ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
void EXPORT ToggleUse ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2016-02-04 06:18:26 +06:00
void InitTrigger ( ) ;
} ;
2015-06-30 15:46:07 +06:00
2015-12-09 04:39:54 +06:00
// trigger_hurt - hurts anything that touches it. if the trigger has a targetname, firing it will toggle state
2015-09-17 02:19:21 +06:00
// int gfToggleState = 0; // used to determine when all radiation trigger hurts have called 'RadiationThink'
2015-06-30 15:46:07 +06:00
class CTriggerHurt : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-06-30 15:46:07 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
void EXPORT RadiationThink ( ) ;
} ;
2015-06-30 15:46:07 +06:00
class CTriggerMonsterJump : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
virtual void Think ( ) ;
2015-09-17 02:19:21 +06:00
virtual void Touch ( CBaseEntity * pOther ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
void Think_ ( ) ;
2015-06-30 15:46:07 +06:00
void Touch_ ( CBaseEntity * pOther ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
// trigger_cdaudio - starts/stops cd audio tracks
2015-06-30 15:46:07 +06:00
class CTriggerCDAudio : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-09-17 02:19:21 +06:00
virtual void Touch ( CBaseEntity * pOther ) ;
virtual void Use ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-06-30 15:46:07 +06:00
void Touch_ ( CBaseEntity * pOther ) ;
void Use_ ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
public :
2016-02-04 06:18:26 +06:00
void PlayTrack ( ) ;
} ;
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
// This plays a CD track when fired or when the player enters it's radius
2015-06-30 15:46:07 +06:00
class CTargetCDAudio : public CPointEntity
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
2016-02-04 06:18:26 +06:00
virtual void Think ( ) ;
2015-09-17 02:19:21 +06:00
virtual void Use ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-06-30 15:46:07 +06:00
void KeyValue_ ( KeyValueData * pkvd ) ;
2016-02-04 06:18:26 +06:00
void Think_ ( ) ;
2015-06-30 15:46:07 +06:00
void Use_ ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
public :
2016-02-04 06:18:26 +06:00
void Play ( ) ;
} ;
2015-06-30 15:46:07 +06:00
2015-12-09 04:39:54 +06:00
// QUAKED trigger_multiple (.5 .5 .5) ? notouch
// Variable sized repeatable trigger. Must be targeted at one or more entities.
// If "health" is set, the trigger must be killed to activate each time.
// If "delay" is set, the trigger waits some time after activating before firing.
// "wait" : Seconds between triggerings. (.2 default)
// If notouch is set, the trigger is only fired by other entities, not by touching.
// NOTOUCH has been obsoleted by trigger_relay!
// sounds
// 1) secret
// 2) beep beep
// 3) large switch
// 4)
// NEW
// if a trigger has a NETNAME, that NETNAME will become the TARGET of the triggered object.
2015-06-30 15:46:07 +06:00
class CTriggerMultiple : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
2015-12-09 04:39:54 +06:00
// QUAKED trigger_once (.5 .5 .5) ? notouch
// Variable sized trigger. Triggers once, then removes itself. You must set the key "target" to the name of another object in the level that has a matching
// "targetname". If "health" is set, the trigger must be killed to activate.
// If notouch is set, the trigger is only fired by other entities, not by touching.
// if "killtarget" is set, any objects that have a matching "target" will be removed when the trigger is fired.
// if "angle" is set, the trigger will only fire when someone is facing the direction of the angle. Use "360" for an angle of 0.
// sounds
// 1) secret
// 2) beep beep
// 3) large switch
2015-09-17 02:19:21 +06:00
// 4)
2015-06-30 15:46:07 +06:00
class CTriggerOnce : public CTriggerMultiple
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
2015-12-09 04:39:54 +06:00
// QUAKED trigger_counter (.5 .5 .5) ? nomessage
// Acts as an intermediary for an action that takes multiple inputs.
// If nomessage is not set, it will print "1 more.. " etc when triggered and
// "sequence complete" when finished. After the counter has been triggered "cTriggersLeft"
// times (default 2), it will fire all of it's targets and remove itself.
2015-06-30 15:46:07 +06:00
class CTriggerCounter : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
// Derive from point entity so this doesn't move across levels
2015-06-30 15:46:07 +06:00
class CTriggerVolume : public CPointEntity
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
// Fires a target after level transition and then dies
2015-06-30 15:46:07 +06:00
class CFireAndDie : public CBaseDelay
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
virtual void Precache ( ) ;
virtual int ObjectCaps ( ) { return ( CBaseDelay : : ObjectCaps ( ) | FCAP_FORCE_TRANSITION ) ; } // Always go across transitions
virtual void Think ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
void Precache_ ( ) ;
void Think_ ( ) ;
2015-06-30 15:46:07 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
2015-12-09 04:39:54 +06:00
// QUAKED trigger_changelevel (0.5 0.5 0.5) ? NO_INTERMISSION
2015-09-17 02:19:21 +06:00
// When the player touches this, he gets sent to the map listed in the "map" variable. Unless the NO_INTERMISSION flag is set, the view will go to the info_intermission spot and display stats.
2015-06-30 15:46:07 +06:00
class CChangeLevel : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
virtual int Save ( CSave & save ) ;
virtual int Restore ( CRestore & restore ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-06-30 15:46:07 +06:00
void KeyValue_ ( KeyValueData * pkvd ) ;
int Save_ ( CSave & save ) ;
int Restore_ ( CRestore & restore ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
public :
2015-09-17 02:19:21 +06:00
void EXPORT UseChangeLevel ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2016-02-23 05:13:52 +06:00
void EXPORT TriggerChangeLevel ( ) ;
2016-02-04 06:18:26 +06:00
void EXPORT ExecuteChangeLevel ( ) ;
2015-09-17 02:19:21 +06:00
void EXPORT TouchChangeLevel ( CBaseEntity * pOther ) ;
void ChangeLevelNow ( CBaseEntity * pActivator ) ;
2015-06-30 15:46:07 +06:00
2015-08-20 16:35:01 +06:00
static edict_t * FindLandmark ( const char * pLandmarkName ) ;
static int ChangeList ( LEVELLIST * pLevelList , int maxList ) ;
static int AddTransitionToList ( LEVELLIST * pLevelList , int listCount , const char * pMapName , const char * pLandmarkName , edict_t * pentLandmark ) ;
static int InTransitionVolume ( CBaseEntity * pEntity , char * pVolumeName ) ;
2015-06-30 15:46:07 +06:00
2015-07-05 17:05:26 +06:00
public :
2015-12-09 04:39:54 +06:00
static TYPEDESCRIPTION IMPL ( m_SaveData ) [ 4 ] ;
2015-06-30 15:46:07 +06:00
2016-02-23 05:13:52 +06:00
char m_szMapName [ cchMapNameMost ] ; // trigger_changelevel only: next map
char m_szLandmarkName [ cchMapNameMost ] ; // trigger_changelevel only: landmark on next map
2015-06-30 15:46:07 +06:00
int m_changeTarget ;
float m_changeTargetDelay ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CLadder : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
virtual void Precache ( ) ;
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
void Precache_ ( ) ;
2015-06-30 15:46:07 +06:00
void KeyValue_ ( KeyValueData * pkvd ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CTriggerPush : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
virtual void Touch ( CBaseEntity * pOther ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-06-30 15:46:07 +06:00
void KeyValue_ ( KeyValueData * pkvd ) ;
void Touch_ ( CBaseEntity * pOther ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CTriggerTeleport : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CBuyZone : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
void EXPORT BuyTouch ( CBaseEntity * pOther ) ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CBombTarget : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
public :
2015-09-17 02:19:21 +06:00
void EXPORT BombTargetTouch ( CBaseEntity * pOther ) ;
void EXPORT BombTargetUse ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CHostageRescue : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
public :
2015-09-17 02:19:21 +06:00
void EXPORT HostageRescueTouch ( CBaseEntity * pOther ) ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CEscapeZone : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
void EXPORT EscapeTouch ( CBaseEntity * pOther ) ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CVIP_SafetyZone : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
void EXPORT VIP_SafetyTouch ( CBaseEntity * pOther ) ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CTriggerSave : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
void EXPORT SaveTouch ( CBaseEntity * pOther ) ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CTriggerEndSection : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-06-30 15:46:07 +06:00
void KeyValue_ ( KeyValueData * pkvd ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
public :
2015-09-17 02:19:21 +06:00
void EXPORT EndSectionTouch ( CBaseEntity * pOther ) ;
void EXPORT EndSectionUse ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CTriggerGravity : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-07-05 17:05:26 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-07-05 17:05:26 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
void EXPORT GravityTouch ( CBaseEntity * pOther ) ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
2015-09-17 02:19:21 +06:00
// this is a really bad idea.
2015-06-30 15:46:07 +06:00
class CTriggerChangeTarget : public CBaseDelay
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
virtual int Save ( CSave & save ) ;
virtual int Restore ( CRestore & restore ) ;
2016-02-04 06:18:26 +06:00
virtual int ObjectCaps ( ) { return ( CBaseEntity : : ObjectCaps ( ) & ~ FCAP_ACROSS_TRANSITION ) ; }
2015-09-17 02:19:21 +06:00
virtual void Use ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-06-30 15:46:07 +06:00
void KeyValue_ ( KeyValueData * pkvd ) ;
int Save_ ( CSave & save ) ;
int Restore_ ( CRestore & restore ) ;
void Use_ ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
public :
2015-12-09 04:39:54 +06:00
static TYPEDESCRIPTION IMPL ( m_SaveData ) [ 1 ] ;
2015-07-05 17:05:26 +06:00
2015-06-30 15:46:07 +06:00
private :
int m_iszNewTarget ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CTriggerCamera : public CBaseDelay
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
virtual int Save ( CSave & save ) ;
virtual int Restore ( CRestore & restore ) ;
2016-02-04 06:18:26 +06:00
virtual int ObjectCaps ( ) { return ( CBaseEntity : : ObjectCaps ( ) & ~ FCAP_ACROSS_TRANSITION ) ; }
2015-09-17 02:19:21 +06:00
virtual void Use ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-06-30 15:46:07 +06:00
void KeyValue_ ( KeyValueData * pkvd ) ;
int Save_ ( CSave & save ) ;
int Restore_ ( CRestore & restore ) ;
void Use_ ( CBaseEntity * pActivator , CBaseEntity * pCaller , USE_TYPE useType , float value ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
public :
2016-02-04 06:18:26 +06:00
void EXPORT FollowTarget ( ) ;
void Move ( ) ;
2015-06-30 15:46:07 +06:00
2015-12-09 04:39:54 +06:00
static TYPEDESCRIPTION IMPL ( m_SaveData ) [ 13 ] ;
2015-06-30 15:46:07 +06:00
EHANDLE m_hPlayer ;
EHANDLE m_hTarget ;
CBaseEntity * m_pentPath ;
int m_sPath ;
float m_flWait ;
float m_flReturnTime ;
float m_flStopTime ;
float m_moveDistance ;
float m_targetSpeed ;
float m_initialSpeed ;
float m_acceleration ;
float m_deceleration ;
int m_state ;
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CWeather : public CBaseTrigger
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2015-09-17 02:19:21 +06:00
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-09-17 02:19:21 +06:00
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
2016-02-04 06:18:26 +06:00
} ;
2015-06-30 15:46:07 +06:00
class CClientFog : public CBaseEntity
{
public :
2016-02-04 06:18:26 +06:00
virtual void Spawn ( ) ;
2015-09-17 02:19:21 +06:00
virtual void KeyValue ( KeyValueData * pkvd ) ;
2015-06-30 15:46:07 +06:00
# ifdef HOOK_GAMEDLL
2016-02-04 06:18:26 +06:00
void Spawn_ ( ) ;
2015-06-30 15:46:07 +06:00
void KeyValue_ ( KeyValueData * pkvd ) ;
2016-02-23 05:13:52 +06:00
# endif
2015-06-30 15:46:07 +06:00
public :
int m_iStartDist ;
int m_iEndDist ;
float m_fDensity ;
2016-02-04 06:18:26 +06:00
} ;
2015-09-17 02:19:21 +06:00
void PlayCDTrack ( int iTrack ) ;
2016-03-17 23:44:52 +06:00
int BuildChangeList ( LEVELLIST * pLevelList , int maxList ) ;
2016-02-23 05:13:52 +06:00
void NextLevel ( ) ;
2015-06-30 15:46:07 +06:00
# endif // TRIGGERS_H