2008-12-25 22:00:00 +01:00
|
|
|
/***
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
****/
|
|
|
|
//
|
|
|
|
// Geiger.cpp
|
|
|
|
//
|
|
|
|
// implementation of CHudAmmo class
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "extdll.h"
|
2009-01-22 22:00:00 +01:00
|
|
|
#include "utils.h"
|
2008-12-25 22:00:00 +01:00
|
|
|
#include "hud.h"
|
|
|
|
|
|
|
|
DECLARE_MESSAGE( m_Geiger, Geiger )
|
|
|
|
|
|
|
|
int CHudGeiger::Init( void )
|
|
|
|
{
|
|
|
|
HOOK_MESSAGE( Geiger );
|
|
|
|
|
|
|
|
m_iGeigerRange = 0;
|
|
|
|
m_iFlags = 0;
|
|
|
|
|
|
|
|
gHUD.AddHudElem( this );
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int CHudGeiger::VidInit( void )
|
|
|
|
{
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int CHudGeiger::MsgFunc_Geiger( const char *pszName, int iSize, void *pbuf )
|
|
|
|
{
|
|
|
|
BEGIN_READ( pszName, iSize, pbuf );
|
|
|
|
|
|
|
|
// update geiger data
|
|
|
|
m_iGeigerRange = READ_BYTE();
|
|
|
|
m_iGeigerRange = m_iGeigerRange << 2;
|
|
|
|
|
|
|
|
m_iFlags |= HUD_ACTIVE;
|
|
|
|
|
|
|
|
END_READ();
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int CHudGeiger::Draw( float flTime )
|
|
|
|
{
|
|
|
|
int pct;
|
|
|
|
float flvol;
|
|
|
|
int rg[3];
|
|
|
|
int i;
|
|
|
|
|
|
|
|
if( m_iGeigerRange < 1000 && m_iGeigerRange > 0 )
|
|
|
|
{
|
|
|
|
// peicewise linear is better than continuous formula for this
|
|
|
|
if( m_iGeigerRange > 800 )
|
|
|
|
{
|
2010-08-15 22:00:00 +02:00
|
|
|
pct = 0; //Con_Printf( "range > 800\n" );
|
2008-12-25 22:00:00 +01:00
|
|
|
}
|
|
|
|
else if( m_iGeigerRange > 600 )
|
|
|
|
{
|
|
|
|
pct = 2;
|
2010-08-15 22:00:00 +02:00
|
|
|
flvol = 0.4; //Con_Printf( "range > 600\n" );
|
2008-12-25 22:00:00 +01:00
|
|
|
rg[0] = 1;
|
|
|
|
rg[1] = 1;
|
|
|
|
i = 2;
|
|
|
|
}
|
|
|
|
else if( m_iGeigerRange > 500 )
|
|
|
|
{
|
|
|
|
pct = 4;
|
2010-08-15 22:00:00 +02:00
|
|
|
flvol = 0.5; //Con_Printf( "range > 500\n" );
|
2008-12-25 22:00:00 +01:00
|
|
|
rg[0] = 1;
|
|
|
|
rg[1] = 2;
|
|
|
|
i = 2;
|
|
|
|
}
|
|
|
|
else if( m_iGeigerRange > 400 )
|
|
|
|
{
|
|
|
|
pct = 8;
|
2010-08-15 22:00:00 +02:00
|
|
|
flvol = 0.6; //Con_Printf( "range > 400\n" );
|
2008-12-25 22:00:00 +01:00
|
|
|
rg[0] = 1;
|
|
|
|
rg[1] = 2;
|
|
|
|
rg[2] = 3;
|
|
|
|
i = 3;
|
|
|
|
}
|
|
|
|
else if( m_iGeigerRange > 300 )
|
|
|
|
{
|
|
|
|
pct = 8;
|
2010-08-15 22:00:00 +02:00
|
|
|
flvol = 0.7; //Con_Printf( "range > 300\n" );
|
2008-12-25 22:00:00 +01:00
|
|
|
rg[0] = 2;
|
|
|
|
rg[1] = 3;
|
|
|
|
rg[2] = 4;
|
|
|
|
i = 3;
|
|
|
|
}
|
|
|
|
else if( m_iGeigerRange > 200 )
|
|
|
|
{
|
|
|
|
pct = 28;
|
2010-08-15 22:00:00 +02:00
|
|
|
flvol = 0.78; //Con_Printf( "range > 200\n" );
|
2008-12-25 22:00:00 +01:00
|
|
|
rg[0] = 2;
|
|
|
|
rg[1] = 3;
|
|
|
|
rg[2] = 4;
|
|
|
|
i = 3;
|
|
|
|
}
|
|
|
|
else if( m_iGeigerRange > 150 )
|
|
|
|
{
|
|
|
|
pct = 40;
|
2010-08-15 22:00:00 +02:00
|
|
|
flvol = 0.80; //Con_Printf( "range > 150\n" );
|
2008-12-25 22:00:00 +01:00
|
|
|
rg[0] = 3;
|
|
|
|
rg[1] = 4;
|
|
|
|
rg[2] = 5;
|
|
|
|
i = 3;
|
|
|
|
}
|
|
|
|
else if( m_iGeigerRange > 100 )
|
|
|
|
{
|
|
|
|
pct = 60;
|
2010-08-15 22:00:00 +02:00
|
|
|
flvol = 0.85; //Con_Printf( "range > 100\n" );
|
2008-12-25 22:00:00 +01:00
|
|
|
rg[0] = 3;
|
|
|
|
rg[1] = 4;
|
|
|
|
rg[2] = 5;
|
|
|
|
i = 3;
|
|
|
|
}
|
|
|
|
else if( m_iGeigerRange > 75 )
|
|
|
|
{
|
|
|
|
pct = 80;
|
|
|
|
flvol = 0.9;
|
|
|
|
rg[0] = 4;
|
|
|
|
rg[1] = 5;
|
|
|
|
rg[2] = 6;
|
|
|
|
i = 3;
|
|
|
|
}
|
|
|
|
else if( m_iGeigerRange > 50 )
|
|
|
|
{
|
|
|
|
pct = 90;
|
|
|
|
flvol = 0.95;
|
|
|
|
rg[0] = 5;
|
|
|
|
rg[1] = 6;
|
|
|
|
i = 2;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
pct = 95;
|
|
|
|
flvol = 1.0;
|
|
|
|
rg[0] = 5;
|
|
|
|
rg[1] = 6;
|
|
|
|
i = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
flvol = flvol * RANDOM_FLOAT( 0.25, 0.5 );
|
|
|
|
|
|
|
|
if( RANDOM_LONG( 0, 128 ) < pct )
|
|
|
|
{
|
|
|
|
char sz[256];
|
|
|
|
|
|
|
|
int j = RANDOM_LONG( 0, 2 );
|
|
|
|
if( i > 2 )
|
|
|
|
j += RANDOM_LONG( 0, 2 );
|
|
|
|
|
|
|
|
// player/geiger6.wav isn't used ?
|
|
|
|
sprintf( sz, "player/geiger%d.wav", j + 1 );
|
|
|
|
CL_PlaySound( sz, flvol );
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 1;
|
|
|
|
}
|