mirror of
https://github.com/shawns-valve/halflife.git
synced 2024-11-24 05:01:03 +00:00
148 lines
2.9 KiB
C++
148 lines
2.9 KiB
C++
/***
|
|
*
|
|
* Copyright (c) 1999, 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.
|
|
*
|
|
****/
|
|
//
|
|
// hud_msg.cpp
|
|
//
|
|
|
|
#include "hud.h"
|
|
#include "cl_util.h"
|
|
#include "parsemsg.h"
|
|
#include "r_efx.h"
|
|
|
|
#include "particleman.h"
|
|
extern IParticleMan *g_pParticleMan;
|
|
|
|
#define MAX_CLIENTS 32
|
|
|
|
#if !defined( _TFC )
|
|
extern BEAM *pBeam;
|
|
extern BEAM *pBeam2;
|
|
#endif
|
|
|
|
#if defined( _TFC )
|
|
void ClearEventList( void );
|
|
#endif
|
|
|
|
/// USER-DEFINED SERVER MESSAGE HANDLERS
|
|
|
|
int CHud :: MsgFunc_ResetHUD(const char *pszName, int iSize, void *pbuf )
|
|
{
|
|
ASSERT( iSize == 0 );
|
|
|
|
// clear all hud data
|
|
HUDLIST *pList = m_pHudList;
|
|
|
|
while ( pList )
|
|
{
|
|
if ( pList->p )
|
|
pList->p->Reset();
|
|
pList = pList->pNext;
|
|
}
|
|
|
|
// reset sensitivity
|
|
m_flMouseSensitivity = 0;
|
|
|
|
// reset concussion effect
|
|
m_iConcussionEffect = 0;
|
|
|
|
return 1;
|
|
}
|
|
|
|
void CAM_ToFirstPerson(void);
|
|
|
|
void CHud :: MsgFunc_ViewMode( const char *pszName, int iSize, void *pbuf )
|
|
{
|
|
CAM_ToFirstPerson();
|
|
}
|
|
|
|
void CHud :: MsgFunc_InitHUD( const char *pszName, int iSize, void *pbuf )
|
|
{
|
|
// prepare all hud data
|
|
HUDLIST *pList = m_pHudList;
|
|
|
|
while (pList)
|
|
{
|
|
if ( pList->p )
|
|
pList->p->InitHUDData();
|
|
pList = pList->pNext;
|
|
}
|
|
|
|
#if defined( _TFC )
|
|
ClearEventList();
|
|
|
|
// catch up on any building events that are going on
|
|
gEngfuncs.pfnServerCmd("sendevents");
|
|
#endif
|
|
|
|
if ( g_pParticleMan )
|
|
g_pParticleMan->ResetParticles();
|
|
|
|
#if !defined( _TFC )
|
|
//Probably not a good place to put this.
|
|
pBeam = pBeam2 = NULL;
|
|
#endif
|
|
}
|
|
|
|
|
|
int CHud :: MsgFunc_GameMode(const char *pszName, int iSize, void *pbuf )
|
|
{
|
|
BEGIN_READ( pbuf, iSize );
|
|
m_Teamplay = READ_BYTE();
|
|
|
|
if ( m_Teamplay )
|
|
gEngfuncs.pfnClientCmd("richpresence_gamemode Teamplay\n");
|
|
else
|
|
gEngfuncs.pfnClientCmd("richpresence_gamemode\n"); // reset
|
|
|
|
gEngfuncs.pfnClientCmd("richpresence_update\n");
|
|
|
|
return 1;
|
|
}
|
|
|
|
|
|
int CHud :: MsgFunc_Damage(const char *pszName, int iSize, void *pbuf )
|
|
{
|
|
int armor, blood;
|
|
Vector from;
|
|
int i;
|
|
float count;
|
|
|
|
BEGIN_READ( pbuf, iSize );
|
|
armor = READ_BYTE();
|
|
blood = READ_BYTE();
|
|
|
|
for (i=0 ; i<3 ; i++)
|
|
from[i] = READ_COORD();
|
|
|
|
count = (blood * 0.5) + (armor * 0.5);
|
|
|
|
if (count < 10)
|
|
count = 10;
|
|
|
|
// TODO: kick viewangles, show damage visually
|
|
|
|
return 1;
|
|
}
|
|
|
|
int CHud :: MsgFunc_Concuss( const char *pszName, int iSize, void *pbuf )
|
|
{
|
|
BEGIN_READ( pbuf, iSize );
|
|
m_iConcussionEffect = READ_BYTE();
|
|
if (m_iConcussionEffect)
|
|
this->m_StatusIcons.EnableIcon("dmg_concuss",255,160,0);
|
|
else
|
|
this->m_StatusIcons.DisableIcon("dmg_concuss");
|
|
return 1;
|
|
}
|