You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
262 lines
6.6 KiB
262 lines
6.6 KiB
/*** |
|
* |
|
* 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. |
|
* |
|
****/ |
|
// |
|
// statusbar.cpp |
|
// |
|
// generic text status bar, set by game dll |
|
// runs across bottom of screen |
|
// |
|
|
|
#include "hud.h" |
|
#include "cl_util.h" |
|
#include "parsemsg.h" |
|
|
|
#include <string.h> |
|
#include <stdio.h> |
|
|
|
DECLARE_MESSAGE( m_StatusBar, StatusText ) |
|
DECLARE_MESSAGE( m_StatusBar, StatusValue ) |
|
|
|
#define STATUSBAR_ID_LINE 1 |
|
|
|
extern int GetTeamIndex( int clientIndex ); |
|
int g_iNameColors; |
|
|
|
int CHudStatusBar::Init( void ) |
|
{ |
|
gHUD.AddHudElem( this ); |
|
|
|
HOOK_MESSAGE( StatusText ); |
|
HOOK_MESSAGE( StatusValue ); |
|
|
|
Reset(); |
|
|
|
//CVAR_CREATE( "hud_centerid", "0", FCVAR_ARCHIVE ); |
|
|
|
return 1; |
|
} |
|
|
|
int CHudStatusBar::VidInit( void ) |
|
{ |
|
m_iArmorSpriteIndex = gHUD.GetSpriteIndex( "armor_bar" ); |
|
m_hArmor = gHUD.GetSprite( m_iArmorSpriteIndex ); |
|
|
|
m_iHealthSpriteIndex = gHUD.GetSpriteIndex( "health_bar" ); |
|
m_hHealth = gHUD.GetSprite( m_iHealthSpriteIndex ); |
|
|
|
// Load sprites here |
|
return 1; |
|
} |
|
|
|
void CHudStatusBar::Reset( void ) |
|
{ |
|
int i = 0; |
|
|
|
m_iFlags &= ~HUD_ACTIVE; // start out inactive |
|
for( i = 0; i < MAX_STATUSBAR_LINES; i++ ) |
|
m_szStatusText[i][0] = 0; |
|
memset( m_iStatusValues, 0, sizeof m_iStatusValues ); |
|
|
|
m_iStatusValues[0] = 1; // 0 is the special index, which always returns true |
|
} |
|
|
|
void CHudStatusBar::ParseStatusString( int line_num ) |
|
{ |
|
int indexval = m_iStatusValues[1]; |
|
GetPlayerInfo( indexval, &g_PlayerInfoList[indexval] ); |
|
if( g_PlayerInfoList[indexval].name != NULL ) |
|
{ |
|
strncpy( m_szName[line_num], g_PlayerInfoList[indexval].name, MAX_PLAYER_NAME_LENGTH - 1 ); |
|
m_szName[line_num][MAX_PLAYER_NAME_LENGTH - 1] = '\0'; |
|
} |
|
else |
|
{ |
|
strcpy( m_szName[line_num], "******" ); |
|
} |
|
g_iNameColors = GetTeamIndex( indexval ); |
|
|
|
indexval = m_iStatusValues[2]; |
|
sprintf( m_szHealth[line_num], ":%d", indexval ); |
|
|
|
indexval = m_iStatusValues[3]; |
|
sprintf( m_szArmor[line_num], ":%d", indexval ); |
|
m_iTeamMate[line_num] = m_iStatusValues[5]; |
|
} |
|
|
|
int CHudStatusBar::Draw( float fTime ) |
|
{ |
|
int r, g, b, a, name_r, name_g, name_b; |
|
|
|
if( m_bReparseString ) |
|
{ |
|
for( int i = 0; i < MAX_STATUSBAR_LINES; i++ ) |
|
{ |
|
ParseStatusString( i ); |
|
} |
|
m_bReparseString = FALSE; |
|
} |
|
|
|
//Not Watching anyone |
|
if( m_iStatusValues[1] == 0 ) |
|
{ |
|
m_iFlags &= ~HUD_ACTIVE; |
|
return 1; |
|
} |
|
|
|
// Draw the status bar lines |
|
for( int i = 0; i < MAX_STATUSBAR_LINES; i++ ) |
|
{ |
|
int TextHeight = 0, TotalTextWidth = 0; |
|
|
|
//Ugly way to get |
|
if( m_iTeamMate[i] ) |
|
{ |
|
TotalTextWidth += gHUD.ReturnStringPixelLength( m_szName[i] ); |
|
TotalTextWidth += gHUD.ReturnStringPixelLength( m_szHealth[i] ); |
|
TotalTextWidth += gHUD.ReturnStringPixelLength( m_szArmor[i] ); |
|
TotalTextWidth += 48; |
|
TextHeight = gHUD.m_scrinfo.iCharHeight; |
|
} |
|
else |
|
TotalTextWidth += gHUD.ReturnStringPixelLength( m_szName[i] ); |
|
|
|
TextHeight = gHUD.m_scrinfo.iCharHeight; |
|
|
|
if( g_iNameColors == 1 ) |
|
{ |
|
name_r = 255; |
|
name_g = 50; |
|
name_b = 50; |
|
} |
|
else if( g_iNameColors == 2 ) |
|
{ |
|
name_r = 50; |
|
name_g = 50; |
|
name_b = 255; |
|
} |
|
else |
|
name_r = name_g = name_b = 255; |
|
|
|
int Y_START; |
|
if( ScreenHeight >= 480 ) |
|
Y_START = ScreenHeight - 55; |
|
else |
|
Y_START = ScreenHeight - 45; |
|
|
|
int x = gHUD.m_Ammo.m_iNumberXPosition; |
|
int y = Y_START; // = ( ScreenHeight / 2 ) + ( TextHeight * 3 ); |
|
|
|
int x_offset; |
|
a = 200; |
|
|
|
UnpackRGB( r, g, b, RGB_NORMAL); |
|
ScaleColors( r, g, b, a ); |
|
ScaleColors( name_r, name_g, name_b, 125 ); |
|
|
|
//Draw the name First |
|
gHUD.DrawHudString( x, y, 1024, m_szName[i], name_r, name_g, name_b ); |
|
|
|
if( !m_iTeamMate[i] ) |
|
continue; |
|
|
|
//Get the length in pixels for the name |
|
x_offset = gHUD.ReturnStringPixelLength( m_szName[i] ); |
|
|
|
//Add the offset |
|
x += ( x_offset + 8 ); |
|
|
|
//Now draw the Sprite for the health |
|
SPR_Set( m_hHealth, r, g, b ); |
|
SPR_DrawHoles( 0, x , y, &gHUD.GetSpriteRect( m_iHealthSpriteIndex ) ); |
|
|
|
//Add the sprite width size |
|
x += 16; |
|
|
|
//Draw the health value ( x + offset for the name lenght + width of the sprite ) |
|
gHUD.DrawHudString( x, y, 1024, m_szHealth[i], name_r, name_g, name_b ); |
|
|
|
//Get the length in pixels for the health |
|
x_offset = gHUD.ReturnStringPixelLength( m_szHealth[i] ); |
|
|
|
//Add the offset |
|
x += ( x_offset + 8 ); |
|
|
|
//Now draw the Sprite for the Armor |
|
SPR_Set( m_hArmor, r, g, b ); |
|
SPR_DrawHoles( 0, x, y, &gHUD.GetSpriteRect( m_iArmorSpriteIndex ) ); |
|
|
|
x += 16; |
|
|
|
//Draw the armor value ( x + offset for the name lenght + width of the sprite ) |
|
gHUD.DrawHudString( x, y, 1024, m_szArmor[i], name_r, name_g, name_b ); |
|
} |
|
|
|
return 1; |
|
} |
|
|
|
// Message handler for StatusText message |
|
// accepts two values: |
|
// byte: line number of status bar text |
|
// string: status bar text |
|
// this string describes how the status bar should be drawn |
|
// a semi-regular expression: |
|
// ( slotnum ([a..z] [%pX] [%iX])*)* |
|
// where slotnum is an index into the Value table (see below) |
|
// if slotnum is 0, the string is always drawn |
|
// if StatusValue[slotnum] != 0, the following string is drawn, upto the next newline - otherwise the text is skipped upto next newline |
|
// %pX, where X is an integer, will substitute a player name here, getting the player index from StatusValue[X] |
|
// %iX, where X is an integer, will substitute a number here, getting the number from StatusValue[X] |
|
int CHudStatusBar::MsgFunc_StatusText( const char *pszName, int iSize, void *pbuf ) |
|
{ |
|
BEGIN_READ( pbuf, iSize ); |
|
|
|
int line = READ_BYTE(); |
|
|
|
if( line < 0 || line >= MAX_STATUSBAR_LINES ) |
|
return 1; |
|
|
|
strncpy( m_szStatusText[line], READ_STRING(), MAX_STATUSTEXT_LENGTH - 1 ); |
|
m_szStatusText[line][MAX_STATUSTEXT_LENGTH - 1] = 0; // ensure it's null terminated ( strncpy() won't null terminate if read string too long) |
|
|
|
if( m_szStatusText[0] == 0 ) |
|
m_iFlags &= ~HUD_ACTIVE; |
|
else |
|
m_iFlags |= HUD_ACTIVE; // we have status text, so turn on the status bar |
|
|
|
m_bReparseString = TRUE; |
|
|
|
return 1; |
|
} |
|
|
|
// Message handler for StatusText message |
|
// accepts two values: |
|
// byte: index into the status value array |
|
// short: value to store |
|
int CHudStatusBar::MsgFunc_StatusValue( const char *pszName, int iSize, void *pbuf ) |
|
{ |
|
BEGIN_READ( pbuf, iSize ); |
|
|
|
int index = READ_BYTE(); |
|
if( index < 1 || index >= MAX_STATUSBAR_VALUES ) |
|
return 1; // index out of range |
|
|
|
m_iStatusValues[index] = READ_SHORT(); |
|
|
|
m_iFlags |= HUD_ACTIVE; |
|
|
|
m_bReparseString = TRUE; |
|
|
|
return 1; |
|
}
|
|
|