From 6ac35da545261db5b248a14ac19b56d1425b64e2 Mon Sep 17 00:00:00 2001 From: havoc Date: Wed, 1 Dec 2004 07:20:42 +0000 Subject: [PATCH] decals now render immediately rather than being transparency sorted, this generally resolves the issues with decals hiding sprites and lightning beams, though it's debatable whether the new interaction with water and transparent bmodels is really an improvement git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@4805 d7cf8633-e32d-0410-b094-e92efae38249 --- cl_particles.c | 30 ++++++++++-------------------- 1 file changed, 10 insertions(+), 20 deletions(-) diff --git a/cl_particles.c b/cl_particles.c index 0cf22897..bdf1d44c 100644 --- a/cl_particles.c +++ b/cl_particles.c @@ -180,7 +180,7 @@ float CL_TraceLine (vec3_t start, vec3_t end, vec3_t impact, vec3_t normal, int typedef enum { - pt_dead, pt_static, pt_rain, pt_bubble, pt_blood, pt_grow, pt_decal, pt_decalfade, pt_ember + pt_dead, pt_static, pt_rain, pt_bubble, pt_blood, pt_grow, pt_decal, pt_ember } ptype_t; @@ -1349,8 +1349,8 @@ void CL_MoveParticles (void) Matrix4x4_Transform3x3(&hitent->inversematrix, normal, p->relativedirection); VectorAdd(p->relativeorigin, p->relativedirection, p->relativeorigin); #endif - p->time2 = cl.time + cl_decals_time.value; - p->die = p->time2 + cl_decals_fadetime.value; + p->time2 = cl.time; + p->die = p->time2 + cl_decals_time.value + cl_decals_fadetime.value; p->alphafade = 0; VectorCopy(normal, p->vel2); VectorClear(p->vel); @@ -1443,22 +1443,7 @@ void CL_MoveParticles (void) p->scaley += frametime * p->time2; break; case pt_decal: -#ifndef WORKINGLQUAKE - if (p->owner->model == p->ownermodel) - { - Matrix4x4_Transform(&p->owner->matrix, p->relativeorigin, p->org); - Matrix4x4_Transform3x3(&p->owner->matrix, p->relativedirection, p->vel2); - if (cl.time > p->time2) - { - p->alphafade = p->alpha / (p->die - cl.time); - p->type = pt_decalfade; - } - } - else - p->type = pt_dead; -#endif - break; - case pt_decalfade: + p->alphafade = cl.time > (p->time2 + cl_decals_time.value) ? (p->alpha / cl_decals_fadetime.value) : 0; #ifndef WORKINGLQUAKE if (p->owner->model == p->ownermodel) { @@ -2025,7 +2010,12 @@ void R_DrawParticles (void) { c_particles++; if (DotProduct(p->org, r_viewforward) >= minparticledist || p->orientation == PARTICLE_BEAM) - R_MeshQueue_AddTransparent(p->org, R_DrawParticleCallback, p, 0); + { + if (p->type == pt_decal) + R_DrawParticleCallback(p, 0); + else + R_MeshQueue_AddTransparent(p->org, R_DrawParticleCallback, p, 0); + } } } #endif -- 2.39.5