//========= Copyright � 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 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 m_EntitySpotted; }; #endif /* SFHUDRADAR_H_ */