summaryrefslogtreecommitdiff
path: root/src/cgame
diff options
context:
space:
mode:
Diffstat (limited to 'src/cgame')
-rw-r--r--src/cgame/cg_draw.c14
-rw-r--r--src/cgame/cg_local.h4
-rw-r--r--src/cgame/cg_main.c18
3 files changed, 34 insertions, 2 deletions
diff --git a/src/cgame/cg_draw.c b/src/cgame/cg_draw.c
index 09777b6..35c53cc 100644
--- a/src/cgame/cg_draw.c
+++ b/src/cgame/cg_draw.c
@@ -3879,6 +3879,20 @@ found_blob:
blob->flags = flags;
VectorCopy( origin, blob->origin );
VectorSet( blob->velocity, crandom( ) * 20, crandom( ) * 20, 100 );
+
+ if( cg_hitSounds.integer > 1 ||
+ ( cg_hitSounds.integer == 1 &&
+ ( flags & DAMAGE_BLOB_FRIENDLY ) ) )
+ {
+ int index;
+
+ if( flags & DAMAGE_BLOB_FRIENDLY )
+ index = 4;
+ else
+ index = ( flags & ( DAMAGE_BLOB_SPLASH | DAMAGE_BLOB_BUILDABLE ) );
+
+ trap_S_StartLocalSound( cgs.media.hitSounds[ index ], CHAN_LOCAL_SOUND );
+ }
}
static void CG_DrawNumber( float x, float y, float h, char *str )
diff --git a/src/cgame/cg_local.h b/src/cgame/cg_local.h
index 2d2598c..6c3325a 100644
--- a/src/cgame/cg_local.h
+++ b/src/cgame/cg_local.h
@@ -1349,6 +1349,8 @@ typedef struct
qhandle_t lightningBeam;
qhandle_t lightningImpactPS;
+
+ sfxHandle_t hitSounds[ 5 ];
} cgMedia_t;
typedef struct
@@ -1613,6 +1615,8 @@ extern vmCvar_t cg_damageBlobAlpha;
extern vmCvar_t cg_healthBarSize;
extern vmCvar_t cg_healthBarAlpha;
+extern vmCvar_t cg_hitSounds;
+
//
// cg_main.c
//
diff --git a/src/cgame/cg_main.c b/src/cgame/cg_main.c
index 9e51258..06fd2a3 100644
--- a/src/cgame/cg_main.c
+++ b/src/cgame/cg_main.c
@@ -238,6 +238,8 @@ vmCvar_t cg_damageBlobAlpha;
vmCvar_t cg_healthBarSize;
vmCvar_t cg_healthBarAlpha;
+vmCvar_t cg_hitSounds;
+
typedef struct
{
vmCvar_t *vmCvar;
@@ -391,7 +393,9 @@ static cvarTable_t cvarTable[ ] =
{ &cg_damageBlobAlpha, "cg_damageBlobAlpha", "0.8", CVAR_ARCHIVE },
{ &cg_healthBarSize, "cg_healthBarSize", "2000", CVAR_ARCHIVE },
- { &cg_healthBarAlpha, "cg_healthBarAlpha", "0.5", CVAR_ARCHIVE }
+ { &cg_healthBarAlpha, "cg_healthBarAlpha", "0.5", CVAR_ARCHIVE },
+
+ { &cg_hitSounds, "cg_hitSounds", "1", CVAR_ARCHIVE }
};
static int cvarTableSize = sizeof( cvarTable ) / sizeof( cvarTable[0] );
@@ -647,7 +651,14 @@ static void CG_RegisterSounds( void )
int i;
char name[ MAX_QPATH ];
const char *soundName;
-
+ const char *hit_sounds[ 5 ] =
+ {
+ "sound/feedback/hit_enemy.wav",
+ "sound/feedback/hit_splash.wav",
+ "sound/feedback/hit_building.wav",
+ "sound/feedback/hit_building_splash.wav",
+ "sound/feedback/hit_friendly.wav",
+ };
cgs.media.alienStageTransition = trap_S_RegisterSound( "sound/announcements/overmindevolved.wav", qtrue );
@@ -751,6 +762,9 @@ static void CG_RegisterSounds( void )
cgs.media.FlamerWarningSound = trap_S_RegisterSound( "models/weapons/flamer/warning.wav", qfalse );
cgs.media.FlamerWarningSound2 = trap_S_RegisterSound( "models/weapons/flamer/warning2.wav", qfalse );
+
+ for( i = 0; i < 5; i++ )
+ cgs.media.hitSounds[ i ] = trap_S_RegisterSound( hit_sounds[ i ], qfalse );
}