Split polyobj plane drawnode-creating code from ds->maskedtexturecol code, and add plane bounds checking

This commit is contained in:
Monster Iestyn 2016-10-11 22:35:46 +01:00
parent b66925e467
commit ff0b1d1dfa

View file

@ -1699,21 +1699,25 @@ static void R_CreateDrawNodes(void)
entry->ffloor = ds->thicksides[i]; entry->ffloor = ds->thicksides[i];
} }
} }
if (ds->maskedtexturecol)
{
#ifdef POLYOBJECTS_PLANES #ifdef POLYOBJECTS_PLANES
// Check for a polyobject plane, but only if this is a front line // Check for a polyobject plane, but only if this is a front line
if (ds->curline->polyseg && ds->curline->polyseg->visplane && !ds->curline->side) { if (ds->curline->polyseg && ds->curline->polyseg->visplane && !ds->curline->side) {
// Put it in! plane = ds->curline->polyseg->visplane;
R_PlaneBounds(plane);
if (plane->low < con_clipviewtop || plane->high > vid.height || plane->high > plane->low)
;
else {
// Put it in!
entry = R_CreateDrawNode(&nodehead); entry = R_CreateDrawNode(&nodehead);
entry->plane = ds->curline->polyseg->visplane; entry->plane = plane;
entry->seg = ds; entry->seg = ds;
ds->curline->polyseg->visplane->polyobj = ds->curline->polyseg; }
ds->curline->polyseg->visplane = NULL; ds->curline->polyseg->visplane = NULL;
} }
#endif #endif
if (ds->maskedtexturecol)
{
entry = R_CreateDrawNode(&nodehead); entry = R_CreateDrawNode(&nodehead);
entry->seg = ds; entry->seg = ds;
} }