From: havoc Date: Sat, 5 Jan 2008 05:37:43 +0000 (+0000) Subject: keep track of number of active explosions rather than scanning up to X-Git-Tag: xonotic-v0.1.0preview~2592 X-Git-Url: http://de.git.xonotic.org/?p=xonotic%2Fdarkplaces.git;a=commitdiff_plain;h=5e1006c50e10b3166b24e2c8b924c508e12315d7 keep track of number of active explosions rather than scanning up to MAX_EXPLOSIONS every frame git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@7912 d7cf8633-e32d-0410-b094-e92efae38249 --- diff --git a/r_explosion.c b/r_explosion.c index 268e9806..1d822eca 100644 --- a/r_explosion.c +++ b/r_explosion.c @@ -26,6 +26,8 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. #define EXPLOSIONVERTS ((EXPLOSIONGRID+1)*(EXPLOSIONGRID+1)) #define EXPLOSIONTRIS (EXPLOSIONGRID*EXPLOSIONGRID*2) +static int numexplosions = 0; + static float explosiontexcoord2f[EXPLOSIONVERTS][2]; static int explosiontris[EXPLOSIONTRIS][3]; static int explosionnoiseindex[EXPLOSIONVERTS]; @@ -94,6 +96,7 @@ static void r_explosion_shutdown(void) static void r_explosion_newmap(void) { + numexplosions = 0; memset(explosion, 0, sizeof(explosion)); } @@ -153,6 +156,7 @@ void R_NewExplosion(const vec3_t org) { if (!e->alpha) { + numexplosions = max(numexplosions, i + 1); e->starttime = cl.time; e->endtime = cl.time + cl_explosions_lifetime.value; e->time = e->starttime; @@ -250,9 +254,11 @@ static void R_MoveExplosion(explosion_t *e) void R_MoveExplosions(void) { int i; - for (i = 0;i < MAX_EXPLOSIONS;i++) + for (i = 0;i < numexplosions;i++) if (explosion[i].alpha) R_MoveExplosion(&explosion[i]); + while (numexplosions > 0 && explosion[i-1].alpha <= 0) + numexplosions--; } void R_DrawExplosions(void) @@ -261,7 +267,7 @@ void R_DrawExplosions(void) if (!r_drawexplosions.integer) return; - for (i = 0;i < MAX_EXPLOSIONS;i++) + for (i = 0;i < numexplosions;i++) if (explosion[i].alpha) R_MeshQueue_AddTransparent(explosion[i].origin, R_DrawExplosion_TransparentCallback, NULL, i, NULL); }