From 1245323a3f3f9ea36767ae853bc06eaed0e6c881 Mon Sep 17 00:00:00 2001 From: havoc Date: Thu, 3 Mar 2011 00:48:23 +0000 Subject: [PATCH] skip backfaces in surface traceline git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@10884 d7cf8633-e32d-0410-b094-e92efae38249 --- model_brush.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/model_brush.c b/model_brush.c index 7a16f6d7..7786be2d 100644 --- a/model_brush.c +++ b/model_brush.c @@ -1314,6 +1314,7 @@ static const texture_t *Mod_Q1BSP_TraceLineAgainstSurfacesFindTextureOnNode(Recu surface = model->data_surfaces + node->firstsurface; for (i = 0;i < node->numsurfaces;i++, surface++) { + // skip surfaces whose bounding box does not include the point if (axis < 3) { if (mid[axis] < surface->mins[axis] || mid[axis] > surface->maxs[axis]) @@ -1324,10 +1325,15 @@ static const texture_t *Mod_Q1BSP_TraceLineAgainstSurfacesFindTextureOnNode(Recu if (!BoxesOverlap(mid, mid, surface->mins, surface->maxs)) continue; } + // skip faces with contents we don't care about if (!(t->trace->hitsupercontentsmask & surface->texture->supercontents)) continue; + // get the surface normal - since it is flat we know any vertex normal will suffice VectorCopy(model->surfmesh.data_normal3f + 3 * surface->num_firstvertex, normal); - //VectorCopy(node->plane->normal, normal); + // skip backfaces + if (DotProduct(t->dist, normal) > 0) + continue; + // iterate edges and see if the point is outside one of them for (j = 0, k = surface->num_vertices - 1;j < surface->num_vertices;k = j, j++) { VectorCopy(model->surfmesh.data_vertex3f + 3 * (surface->num_firstvertex + k), v0); @@ -1337,6 +1343,7 @@ static const texture_t *Mod_Q1BSP_TraceLineAgainstSurfacesFindTextureOnNode(Recu if (DotProduct(edgenormal, p) > DotProduct(edgenormal, v0)) break; } + // if the point is outside one of the edges, it is not within the surface if (j < surface->num_vertices) continue; -- 2.39.2