From d76416d9638cc8837fd6e1d3fa3f6416146bca73 Mon Sep 17 00:00:00 2001 From: divverent Date: Thu, 9 Sep 2010 07:37:50 +0000 Subject: [PATCH] do sound occlusion only once per sound, not once per listener channel git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@10451 d7cf8633-e32d-0410-b094-e92efae38249 ::stable-branch::merge=1c4c36dd5a6587988ac63db25c246c96fba749f4 --- snd_main.c | 42 +++++++++++++++++++----------------------- 1 file changed, 19 insertions(+), 23 deletions(-) diff --git a/snd_main.c b/snd_main.c index b9fe6602..ea8a1548 100644 --- a/snd_main.c +++ b/snd_main.c @@ -1376,6 +1376,25 @@ void SND_Spatialize(channel_t *ch, qboolean isstatic) intensity = mastervol * (1.0 - dist * ch->dist_mult); if (intensity > 0) { + qboolean occluded = false; + if (snd_spatialization_occlusion.integer) + { + if(snd_spatialization_occlusion.integer & 1) + if(listener_pvs) + { + int cluster = cl.worldmodel->brush.PointInLeaf(cl.worldmodel, ch->origin)->clusterindex; + if(cluster >= 0 && cluster < 8 * listener_pvsbytes && !CHECKPVSBIT(listener_pvs, cluster)) + occluded = true; + } + + if(snd_spatialization_occlusion.integer & 2) + if(!occluded) + if(cl.worldmodel && cl.worldmodel->brush.TraceLineOfSight && !cl.worldmodel->brush.TraceLineOfSight(cl.worldmodel, listener_origin, ch->origin)) + occluded = true; + } + if(occluded) + intensity *= 0.5; + for (i = 0;i < SND_LISTENERS;i++) { Matrix4x4_Transform(&listener_matrix[i], ch->origin, source_vec); @@ -1406,29 +1425,6 @@ void SND_Spatialize(channel_t *ch, qboolean isstatic) vol = intensity * max(0, source_vec[0] * snd_speakerlayout.listeners[i].dotscale + snd_speakerlayout.listeners[i].dotbias); - if (snd_spatialization_occlusion.integer) - { - qboolean occluded = false; - - if(snd_spatialization_occlusion.integer & 1) - if(listener_pvs) - { - int cluster = cl.worldmodel->brush.PointInLeaf(cl.worldmodel, ch->origin)->clusterindex; - if(cluster >= 0 && cluster < 8 * listener_pvsbytes && !CHECKPVSBIT(listener_pvs, cluster)) - occluded = true; - } - - if(snd_spatialization_occlusion.integer & 2) - if(!occluded) - if(cl.worldmodel && cl.worldmodel->brush.TraceLineOfSight && !cl.worldmodel->brush.TraceLineOfSight(cl.worldmodel, listener_origin, ch->origin)) - { - occluded = true; - } - - if(occluded) - vol *= 0.5f; - } - ch->listener_volume[i] = (int)bound(0, vol, 255); } } -- 2.39.2