2021-07-24 21:11:47 -07:00

604 lines
16 KiB
C++
Raw Permalink Blame History

//========= Copyright <20> 1996-2005, Valve Corporation, All rights reserved. ============//
//
// Purpose:
//
//=============================================================================//
#ifndef SFHUDRADAR_H_
#define SFHUDRADAR_H_
#include "hud.h"
#include "hud_element_helper.h"
#include "scaleformui/scaleformui.h"
#include "sfhudflashinterface.h"
#include "c_cs_hostage.h"
#define MAX_LOCATION_TEXT_LENGTH 100
#define MAX_DECOYS 30
class SFHudRadar : public SFHudFlashInterface
{
// this manages the display of the players and hostages
// in the radar
protected:
enum ICON_PACK_TYPE
{
ICON_PACK_PLAYER,
ICON_PACK_HOSTAGE,
ICON_PACK_DECOY,
ICON_PACK_DEFUSER,
};
enum
{
R_BELOW = 0,
R_SAMELEVEL = 1,
R_ABOVE = 2,
};
// each enum represents an icon that this class is managing
enum PLAYER_ICON_INDICES
{
PI_PLAYER_NUMBER,
PI_PLAYER_LETTER,
PI_FIRST_ROTATED,
PI_PLAYER_INDICATOR = PI_FIRST_ROTATED,
PI_SPEAKING,
PI_SPEAKING_OFFMAP,
PI_ABOVE,
PI_BELOW,
PI_HOSTAGE_MOVING,
PI_HOSTAGE_MOVING_OFFMAP,
PI_CT,
PI_CT_OFFMAP,
PI_CT_DEAD,
PI_CT_GHOST,
PI_T,
PI_T_OFFMAP,
PI_T_DEAD,
PI_T_GHOST,
PI_ENEMY,
PI_ENEMY_OFFMAP,
PI_ENEMY_DEAD,
PI_ENEMY_GHOST,
PI_HOSTAGE,
PI_HOSTAGE_OFFMAP,
PI_HOSTAGE_DEAD,
PI_HOSTAGE_GHOST,
PI_DIRECTION_INDICATOR,
PI_DEFUSER,
PI_SELECTED,
PI_VIEWFRUSTRUM,
PI_ENEMY_SEELOCAL,
PI_NUM_ICONS
};
class SFHudRadarIconPackage
{
public:
SFHudRadarIconPackage();
~SFHudRadarIconPackage();
// zero all the internal variables
void ClearAll( void );
// get handles to the icons which will all be children
// of the iconPackage handle
void Init( IScaleformUI* pui, SFVALUE iconPackage );
// release all the handles, and clear all the variables
// used when removing players or changing maps
void NukeFromOrbit( SFHudRadar* pSFUI );
// reset all variables to their start of round values
void StartRound( void );
// set the states for this player
void SetIsPlayer( bool value );
void SetIsSelected( bool value );
void SetIsSpeaking ( bool value );
void SetIsOffMap( bool value );
void SetIsAboveOrBelow( int value );
void SetIsMovingHostage( bool value );
void SetIsDead( bool value );
void SetIsRescued( bool value );
void SetPlayerTeam( int team );
void SetGrenadeExpireTime( float value );
void SetIsSpotted( bool value );
void SetIsSpottedByFriendsOnly( bool value );
void SetAlpha( float newAlpha );
void SetIsOnLocalTeam( bool value );
void SetIsBot( bool value );
void SetIsControlledBot( void );
void SetIsDefuse( bool bValue );
// given the current set of states, decide which
// icons should be shown and which should be hidden
void SetupIconsFromStates( void );
// each bit in newFlags represents the visibility of one of the
// icons in the PLAYER_ICON_INDICES. If the bit is on, the icon
// is shown.
void SetVisibilityFlags( int newFlags );
void UpdateIconsPostion( void );
bool IsHostageType( void ) { return m_IconPackType == ICON_PACK_HOSTAGE;}
bool IsDecoyType( void ) { return m_IconPackType == ICON_PACK_DECOY;}
bool IsPlayerType( void ) { return m_IconPackType == ICON_PACK_PLAYER;}
bool IsDefuserType( void ) { return m_IconPackType == ICON_PACK_DEFUSER;}
bool IsVisible( void );
public:
// pointer to scaleform
IScaleformUI* m_pScaleformUI;
// the parent for all the icons
SFVALUE m_IconPackage;
SFVALUE m_IconPackageRotate;
// the handles for all the icons listed in PLAYER_ICON_INDICES
SFVALUE m_Icons[PI_NUM_ICONS];
// the location and position of this player/hostage
// only updated when the player is spotted
Vector m_Position; // current x,y pos
QAngle m_Angle; // view origin 0..360
// HUD Position, rotation and scale - used to update the position of the visible icons
Vector m_HudPosition;
float m_HudRotation;
float m_HudScale;
// ignore visibility updates until a little time has passed
// this keeps track of when the round started
float m_fRoundStartTime;
// the time at which this player/hostage died ( or was rescued )
// used to calculate the alpha of the X icon.
float m_fDeadTime;
// the time at which the player / hostage was last spotted
// used to fade out the ? icon
float m_fGhostTime;
// the alpha currently used to display all icons
// used to lazy update the actual scaleform value
float m_fCurrentAlpha;
// last time we applied this color to the movie
float m_fLastColorUpdate;
// each bit represents one of the PLAYER_ICON_INDICES
// used to lazy update the visibility of the icons in scaleform
int m_iCurrentVisibilityFlags;
// the index of this player/hostage in the radar.
// used to create the instance name of the icon package in flash
int m_iIndex;
// set from the player objects UserID or EntityID ( for the hostages ). Lets us find the radar
// object that represents a player / hostage
int m_iEntityID;
// state variables used to keep track of the player / hostage state
// so we know which icon( s ) to show
int m_Health; // 0..100, 7 bit
wchar_t m_wcName[MAX_PLAYER_NAME_LENGTH+1];
// the base icon for the player
int m_iPlayerType; // will be PI_CT, PI_T, or PI_HOSTAGE
int m_nAboveOrBelow;// R_BELOW = 0,R_SAMELEVEL = 1,R_ABOVE = 2,
float m_fGrenExpireTime;
ICON_PACK_TYPE m_IconPackType;
bool m_bIsActive : 1;
bool m_bOffMap : 1;
bool m_bIsPlayer : 1;
bool m_bIsSelected : 1;
bool m_bIsSpeaking : 1;
bool m_bIsDead : 1;
bool m_bIsBot : 1;
bool m_bIsMovingHostage : 1;
bool m_bIsSpotted : 1;
bool m_bIsSpottedByFriendsOnly : 1;
bool m_bIsRescued : 1;
bool m_bIsOnLocalTeam : 1;
bool m_bIsDefuser : 1;
bool m_bHostageIsUsed : 1;
// don't put anything new after the bitfields or suffer the Wrath of the Compiler!
};
// this little class manages the display of the hostage
// indicators in the panel
class SFHudRadarHostageIcons
{
public:
enum HOSTAGE_ICON_INDICES
{
HI_DEAD,
HI_RESCUED,
HI_ALIVE,
HI_TRANSIT,
HI_NUM_ICONS,
HI_UNUSED = HI_NUM_ICONS,
};
public:
SFHudRadarHostageIcons();
~SFHudRadarHostageIcons();
void Init( IScaleformUI* scaleformui, SFVALUE iconPackage );
void ReleaseHandles( SFHudRadar* pradar );
void SetStatus( int status );
public:
IScaleformUI* m_pScaleformUI;
// the parent object of all the icons
SFVALUE m_IconPackage;
// the icons which represent each of the HOSTAGE_ICON_INDICES
SFVALUE m_Icons[HI_NUM_ICONS];
// the index of the icon that is currently shown
int m_iCurrentIcon;
};
// this just keeps track of the bombzone and hostagezone
// icons that are shown on the radar
struct SFHudRadarGoalIcon
{
Vector m_Position;
SFVALUE m_Icon;
};
public:
explicit SFHudRadar( const char *value );
virtual ~SFHudRadar();
// These overload the CHudElement class
virtual void ProcessInput( void );
virtual void LevelInit( void );
virtual void LevelShutdown( void );
virtual void SetActive( bool bActive );
virtual void Init( void );
virtual bool ShouldDraw( void );
virtual void Reset( void )
{
SetActive( true );
}
// these overload the ScaleformFlashInterfaceMixin class
virtual void FlashLoaded( void );
virtual void FlashReady( void );
virtual bool PreUnloadFlash( void );
void MapLoaded( SCALEFORM_CALLBACK_ARGS_DECL );
// overloads for the CGameEventListener class
virtual void FireGameEvent( IGameEvent *event );
bool MsgFunc_ProcessSpottedEntityUpdate( const CCSUsrMsg_ProcessSpottedEntityUpdate &msg );
void ShowRadar( bool value ) {m_bShowRadar = value;}
bool IsRadarShown( void ) {return m_bShowRadar;}
void ResizeHud( void );
void SwitchRadarToRound( bool toRound );
CUserMessageBinder m_UMCMsgProcessSpottedEntityUpdate;
bool m_bRound; // Is the radar round ( otherwise square )
protected:
void ResetRadar( bool bResetGlobalStates = true );
void ResetForNewMap( void );
void ResetRound( void );
void SetMap( const char* pMapName );
void WorldToRadar( const Vector& ptin, Vector& ptout );
void RadarToHud( const Vector& ptin, Vector& ptout );
void LazyCreateGoalIcons( void );
void FlashLoadMap( const char* pMapName );
void FlashUpdateMapLayer( int layerIdx );
void InitIconPackage( SFHudRadarIconPackage* pPlayer, int iAbsoluteIndex, ICON_PACK_TYPE packType );
void RemoveIconPackage( SFHudRadarIconPackage* pPlayer );
SFHudRadarIconPackage* CreatePlayer( int index );
void ResetPlayer( int index );
void RemovePlayer( int index );
SFHudRadarIconPackage* CreateHostage( int index );
void ResetHostage( int index );
void RemoveHostage( int index );
void RemoveStaleHostages( void );
void RemoveAllHostages( void );
SFHudRadarIconPackage* CreateDecoy( int index );
void RemoveAllDecoys( void );
void RemoveDecoy( int index );
SFHudRadarIconPackage * CreateDefuser( int nEntityID );
SFHudRadarIconPackage * GetDefuser( int nEntityID, bool bCreateIfNotFound = false );
void SetDefuserPos( int nEntityID, int x, int y, int z, int a );
void UpdateAllDefusers( void );
void RemoveAllDefusers( void );
void RemoveDefuser( int index );
bool LazyUpdateIconArray( SFHudRadarIconPackage* pArray, int lastIndex );
virtual bool LazyCreateIconPackage( SFHudRadarIconPackage* pPackage );
void LazyCreatePlayerIcons( void );
void SetPlayerTeam( int index, int team );
int GetPlayerIndexFromUserID( int userID );
int GetHostageIndexFromHostageEntityID( int entityID );
int GetDecoyIndexFromEntityID( int entityID );
int GetDefuseIndexFromEntityID( int nEntityID );
void ApplySpectatorModes( void );
void PositionRadarViewpoint( void );
void PlaceGoalIcons( void );
void Show( bool show );
void PlacePlayers();
void PlaceHostages();
void SetIconPackagePosition( SFHudRadarIconPackage* pPackage );
void UpdateMiscIcons( void );
void SetVisibilityFlags( int newFlags );
void SetupIconsFromStates( void );
void SetLocationText( wchar_t *newText );
void ResetRoundVariables( bool bResetGlobalStates = true );
void UpdateDecoys( void );
void UpdateAllPlayerNumbers( void );
void UpdatePlayerNumber( SFHudRadarIconPackage* pPackage );
SFHudRadarIconPackage* GetRadarPlayer( int index );
SFHudRadarIconPackage* GetRadarHostage( int index );
SFHudRadarIconPackage* GetRadarDecoy( int index );
SFHudRadarIconPackage* GetRadarDefuser( int index );
SFHudRadarIconPackage* GetRadarHeight( int index );
protected:
// these are the icons used individually by the radar and panel
enum RADAR_ICON_INDICES
{
RI_BOMB_IS_PLANTED,
RI_BOMB_IS_PLANTED_MEDIUM,
RI_BOMB_IS_PLANTED_FAST,
RI_IN_HOSTAGE_ZONE,
RI_DASHBOARD,
RI_BOMB_ICON_PLANTED,
RI_BOMB_ICON_DROPPED,
RI_BOMB_ICON_BOMB_CT,
RI_BOMB_ICON_BOMB_T,
RI_BOMB_ICON_BOMB_ABOVE,
RI_BOMB_ICON_BOMB_BELOW,
RI_BOMB_ICON_PACKAGE,
RI_DEFUSER_ICON_DROPPED,
RI_DEFUSER_ICON_PACKAGE,
RI_NUM_ICONS,
};
enum
{
MAX_BOMB_ZONES = 2,
};
int m_nCurrentRadarVerticalSection;
struct HudRadarLevelVerticalSection_t
{
int m_nSectionIndex;
char m_szSectionName[MAX_MAP_NAME];
float m_flSectionAltitudeFloor;
float m_flSectionAltitudeCeiling;
HudRadarLevelVerticalSection_t()
{
m_nSectionIndex = 0;
m_szSectionName[0] = 0;
m_flSectionAltitudeFloor = 0;
m_flSectionAltitudeCeiling = 0;
}
};
CUtlVector< HudRadarLevelVerticalSection_t > m_vecRadarVerticalSections;
// this holds the names and indexes of the messages we receive so that
// we don't have to do a whole bunch of string compares to find them
static CUtlMap<const char*, int> m_messageMap;
// these are used to scale world coordinates to radar coordinates
Vector m_MapOrigin;
float m_fMapSize;
float m_fRadarSize;
float m_fPixelToRadarScale;
float m_fWorldToPixelScale;
float m_fWorldToRadarScale;
// this is center of the radar in world and map coordinates
Vector m_RadarViewpointWorld;
Vector m_RadarViewpointMap;
float m_RadarRotation;
// the current position of the bomb
Vector m_BombPosition;
// the last time the bomb was seen. Used to fade
// out the bomb icon after it has dropped out of sight
float m_fBombSeenTime;
float m_fBombAlpha;
// the current position of the defuser
Vector m_DefuserPosition;
// the last time the defuser was seen. Used to fade
// out the defuser icon after it has dropped out of sight
float m_fDefuserSeenTime;
float m_fDefuserAlpha;
// a bitmap of the icons that are currently beeing shown.
// each bit corresponds to one the RADAR_ICON_INDICES
int m_iCurrentVisibilityFlags;
// the handles to the RADAR_ICON_INDICES icons
SFVALUE m_Icons[RI_NUM_ICONS];
// Background panel
SFVALUE m_BackgroundPanel;
// handles to the radar movie clips in flash.
// there is a rotation and a translation layer each for the icons and for the background map.
// The map and the icons have separate layers because the map is behind a mask layer, and the
// icons are not.
// the root of the entire radar and dashboard
SFVALUE m_RadarModule;
// the root of the radar part of the module
SFVALUE m_Radar;
// the layers that handle the icons
SFVALUE m_IconTranslation;
SFVALUE m_IconRotation;
// the layers that handle the map
SFVALUE m_MapRotation;
SFVALUE m_MapTranslation;
// handles to the actual bomb zone and hostage icons that are defined
// in the flash file
SFVALUE m_HostageZoneIcons[MAX_HOSTAGE_RESCUES];
SFVALUE m_BombZoneIcons[MAX_BOMB_ZONES];
// "handle" to the text that holds the current location
ISFTextObject* m_LocationText;
// the last index of an active player in the m_Players array
int m_iLastPlayerIndex;
// the last index of an active hostage in the m_Hostages array
int m_iLastHostageIndex;
// the last index of an active decoy in the m_Decoys array
int m_iLastDecoyIndex;
// the last index of an active defuser in the m_Defuser array
int m_iLastDefuserIndex;
// keeps the state information and icon handles for the players
SFHudRadarIconPackage m_Players[MAX_PLAYERS];
// keeps the state information and icon handles for the hostages
SFHudRadarIconPackage m_Hostages[MAX_HOSTAGES];
// keeps the state information and icon handles for the decoys
SFHudRadarIconPackage m_Decoys[MAX_DECOYS];
// keeps the state information and icon handles for the decoys
SFHudRadarIconPackage m_Defusers[MAX_PLAYERS];
// the handles to the hostage status icons that appear beneath the dashboard
SFHudRadarHostageIcons m_HostageStatusIcons[MAX_HOSTAGES];
// a goal icon is either a bomb-area or a hostage-area icon
// This array holds the positions / handles of the ones that are active for the current map
int m_iNumGoalIcons;
SFHudRadarGoalIcon m_GoalIcons[MAX_HOSTAGE_RESCUES + MAX_BOMB_ZONES];
// the current observer mode. Figures into the placement of the center of the radar
// and a few other things
int m_iObserverMode;
// there is a loaded and a desired so that we don't load the same map twice, and so that we
// can request that a map be loaded before the flash stuff is able to actually load it.
char m_cLoadedMapName[MAX_MAP_NAME+1];
char m_cDesiredMapName[MAX_MAP_NAME+1];
// the name of our current location
wchar_t m_wcLocationString[MAX_LOCATION_TEXT_LENGTH+1];
// keeps track of weather flash is ready or not and if it's currently being loaded
bool m_bFlashLoading : 1;
bool m_bFlashReady : 1;
// this is set by a con command to hide the whole radar
bool m_bShowRadar : 1;
bool m_bVisible;
bool m_bShowViewFrustrum;
// set to true in spectator mode if we're not in pro mode
bool m_bShowAll : 1;
// keep track of whether we've already gotten all the goal icons and player icons from the
// flash file. This is necessary because some of the level information is loaded before
// flash is ready
bool m_bGotGoalIcons : 1;
bool m_bGotPlayerIcons : 1;
// state information about which icons should be displayed
bool m_bShowingHostageZone : 1;
bool m_bBombPlanted : 1;
bool m_bBombDropped : 1;
bool m_bBombDefused : 1;
bool m_bBombExploded : 1;
bool m_bShowBombHighlight : 1;
bool m_bShowingDashboard : 1;
bool m_bBombIsSpotted : 1;
int m_nBombEntIndex;
int m_nBombHolderUserId;
bool m_bTrackDefusers;
// entities spotted last ProcessSpottedEntityUpdate
CBitVec<MAX_EDICTS> m_EntitySpotted;
};
#endif /* SFHUDRADAR_H_ */