604 lines
16 KiB
C++
604 lines
16 KiB
C++
//========= 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_ */
|