From 07cf7fb3bfa35c5a2792fe36be6f1c22dcd7371c Mon Sep 17 00:00:00 2001 From: Rudolf Polzer Date: Sun, 9 May 2010 16:08:24 +0200 Subject: [PATCH] honor bgmvolume --- qcsrc/client/target_music.qc | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/qcsrc/client/target_music.qc b/qcsrc/client/target_music.qc index 34d19dc027..a7a46d80ad 100644 --- a/qcsrc/client/target_music.qc +++ b/qcsrc/client/target_music.qc @@ -4,12 +4,13 @@ entity music_target; entity music_trigger; .float state; +.float lastvol; void TargetMusic_Advance() { // run AFTER all the thinks! entity best, e; - float s0; + float vol, vol0; best = music_default; if(music_target && time < music_target.lifetime) best = music_target; @@ -17,10 +18,10 @@ void TargetMusic_Advance() best = music_trigger; for(e = world; (e = findfloat(e, enttype, ENT_CLIENT_TRIGGER_MUSIC)); ) if(e.noise) { - s0 = e.state; + vol0 = e.lastvol; if(getsoundtime(e, CHAN_VOICE) < 0) { - s0 = -1; + vol0 = -1; } if(e == best) { @@ -38,12 +39,14 @@ void TargetMusic_Advance() else e.state = 0; } - if(e.state != s0) + vol = e.state * e.volume * cvar("bgmvolume"); + if(vol != vol0) { - if(s0 < 0) - sound(e, CHAN_VOICE, e.noise, e.volume * e.state * cvar("bgmvolume"), ATTN_NONE); // restart + if(vol0 < 0) + sound(e, CHAN_VOICE, e.noise, vol, ATTN_NONE); // restart else - sound(e, CHAN_VOICE, "", e.volume * e.state * cvar("bgmvolume"), ATTN_NONE); + sound(e, CHAN_VOICE, "", vol, ATTN_NONE); + e.lastvol = vol; } } music_trigger = world; -- 2.39.5