mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-16 06:30:52 +00:00
Merge branch 'plane-fixes' into 'next'
Software plane rendering fixes/cleanup This is mostly cleanup, with the exception that polyobject planes should now behave somewhat better than they do in 2.1 currently (translucent polyobj planes should now always be actually translucent regardless of where you view them from, for instance). I can't claim I've fixed their rendering once and for all though, there may still be bugs for all I know... See merge request !136
This commit is contained in:
commit
cd0ec0881d
4 changed files with 100 additions and 49 deletions
67
src/r_bsp.c
67
src/r_bsp.c
|
@ -859,6 +859,7 @@ static void R_Subsector(size_t num)
|
||||||
static sector_t tempsec; // Deep water hack
|
static sector_t tempsec; // Deep water hack
|
||||||
extracolormap_t *floorcolormap;
|
extracolormap_t *floorcolormap;
|
||||||
extracolormap_t *ceilingcolormap;
|
extracolormap_t *ceilingcolormap;
|
||||||
|
fixed_t floorcenterz, ceilingcenterz;
|
||||||
|
|
||||||
#ifdef RANGECHECK
|
#ifdef RANGECHECK
|
||||||
if (num >= numsubsectors)
|
if (num >= numsubsectors)
|
||||||
|
@ -879,6 +880,18 @@ static void R_Subsector(size_t num)
|
||||||
|
|
||||||
floorcolormap = ceilingcolormap = frontsector->extra_colormap;
|
floorcolormap = ceilingcolormap = frontsector->extra_colormap;
|
||||||
|
|
||||||
|
floorcenterz =
|
||||||
|
#ifdef ESLOPE
|
||||||
|
frontsector->f_slope ? P_GetZAt(frontsector->f_slope, frontsector->soundorg.x, frontsector->soundorg.y) :
|
||||||
|
#endif
|
||||||
|
frontsector->floorheight;
|
||||||
|
|
||||||
|
ceilingcenterz =
|
||||||
|
#ifdef ESLOPE
|
||||||
|
frontsector->c_slope ? P_GetZAt(frontsector->c_slope, frontsector->soundorg.x, frontsector->soundorg.y) :
|
||||||
|
#endif
|
||||||
|
frontsector->ceilingheight;
|
||||||
|
|
||||||
// Check and prep all 3D floors. Set the sector floor/ceiling light levels and colormaps.
|
// Check and prep all 3D floors. Set the sector floor/ceiling light levels and colormaps.
|
||||||
if (frontsector->ffloors)
|
if (frontsector->ffloors)
|
||||||
{
|
{
|
||||||
|
@ -891,19 +904,11 @@ static void R_Subsector(size_t num)
|
||||||
sub->sector->moved = frontsector->moved = false;
|
sub->sector->moved = frontsector->moved = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
light = R_GetPlaneLight(frontsector,
|
light = R_GetPlaneLight(frontsector, floorcenterz, false);
|
||||||
#ifdef ESLOPE
|
|
||||||
frontsector->f_slope ? P_GetZAt(frontsector->f_slope, frontsector->soundorg.x, frontsector->soundorg.y) :
|
|
||||||
#endif
|
|
||||||
frontsector->floorheight, false);
|
|
||||||
if (frontsector->floorlightsec == -1)
|
if (frontsector->floorlightsec == -1)
|
||||||
floorlightlevel = *frontsector->lightlist[light].lightlevel;
|
floorlightlevel = *frontsector->lightlist[light].lightlevel;
|
||||||
floorcolormap = frontsector->lightlist[light].extra_colormap;
|
floorcolormap = frontsector->lightlist[light].extra_colormap;
|
||||||
light = R_GetPlaneLight(frontsector,
|
light = R_GetPlaneLight(frontsector, ceilingcenterz, false);
|
||||||
#ifdef ESLOPE
|
|
||||||
frontsector->c_slope ? P_GetZAt(frontsector->c_slope, frontsector->soundorg.x, frontsector->soundorg.y) :
|
|
||||||
#endif
|
|
||||||
frontsector->ceilingheight, false);
|
|
||||||
if (frontsector->ceilinglightsec == -1)
|
if (frontsector->ceilinglightsec == -1)
|
||||||
ceilinglightlevel = *frontsector->lightlist[light].lightlevel;
|
ceilinglightlevel = *frontsector->lightlist[light].lightlevel;
|
||||||
ceilingcolormap = frontsector->lightlist[light].extra_colormap;
|
ceilingcolormap = frontsector->lightlist[light].extra_colormap;
|
||||||
|
@ -920,6 +925,9 @@ static void R_Subsector(size_t num)
|
||||||
{
|
{
|
||||||
floorplane = R_FindPlane(frontsector->floorheight, frontsector->floorpic, floorlightlevel,
|
floorplane = R_FindPlane(frontsector->floorheight, frontsector->floorpic, floorlightlevel,
|
||||||
frontsector->floor_xoffs, frontsector->floor_yoffs, frontsector->floorpic_angle, floorcolormap, NULL
|
frontsector->floor_xoffs, frontsector->floor_yoffs, frontsector->floorpic_angle, floorcolormap, NULL
|
||||||
|
#ifdef POLYOBJECTS_PLANES
|
||||||
|
, NULL
|
||||||
|
#endif
|
||||||
#ifdef ESLOPE
|
#ifdef ESLOPE
|
||||||
, frontsector->f_slope
|
, frontsector->f_slope
|
||||||
#endif
|
#endif
|
||||||
|
@ -939,6 +947,9 @@ static void R_Subsector(size_t num)
|
||||||
ceilingplane = R_FindPlane(frontsector->ceilingheight, frontsector->ceilingpic,
|
ceilingplane = R_FindPlane(frontsector->ceilingheight, frontsector->ceilingpic,
|
||||||
ceilinglightlevel, frontsector->ceiling_xoffs, frontsector->ceiling_yoffs, frontsector->ceilingpic_angle,
|
ceilinglightlevel, frontsector->ceiling_xoffs, frontsector->ceiling_yoffs, frontsector->ceilingpic_angle,
|
||||||
ceilingcolormap, NULL
|
ceilingcolormap, NULL
|
||||||
|
#ifdef POLYOBJECTS_PLANES
|
||||||
|
, NULL
|
||||||
|
#endif
|
||||||
#ifdef ESLOPE
|
#ifdef ESLOPE
|
||||||
, frontsector->c_slope
|
, frontsector->c_slope
|
||||||
#endif
|
#endif
|
||||||
|
@ -956,7 +967,7 @@ static void R_Subsector(size_t num)
|
||||||
if (frontsector->ffloors)
|
if (frontsector->ffloors)
|
||||||
{
|
{
|
||||||
ffloor_t *rover;
|
ffloor_t *rover;
|
||||||
fixed_t heightcheck, planecenterz, floorcenterz, ceilingcenterz;
|
fixed_t heightcheck, planecenterz;
|
||||||
|
|
||||||
for (rover = frontsector->ffloors; rover && numffloors < MAXFFLOORS; rover = rover->next)
|
for (rover = frontsector->ffloors; rover && numffloors < MAXFFLOORS; rover = rover->next)
|
||||||
{
|
{
|
||||||
|
@ -975,18 +986,6 @@ static void R_Subsector(size_t num)
|
||||||
ffloor[numffloors].plane = NULL;
|
ffloor[numffloors].plane = NULL;
|
||||||
ffloor[numffloors].polyobj = NULL;
|
ffloor[numffloors].polyobj = NULL;
|
||||||
|
|
||||||
floorcenterz =
|
|
||||||
#ifdef ESLOPE
|
|
||||||
frontsector->f_slope ? P_GetZAt(frontsector->f_slope, frontsector->soundorg.x, frontsector->soundorg.y) :
|
|
||||||
#endif
|
|
||||||
frontsector->floorheight;
|
|
||||||
|
|
||||||
ceilingcenterz =
|
|
||||||
#ifdef ESLOPE
|
|
||||||
frontsector->c_slope ? P_GetZAt(frontsector->c_slope, frontsector->soundorg.x, frontsector->soundorg.y) :
|
|
||||||
#endif
|
|
||||||
frontsector->ceilingheight;
|
|
||||||
|
|
||||||
heightcheck =
|
heightcheck =
|
||||||
#ifdef ESLOPE
|
#ifdef ESLOPE
|
||||||
*rover->b_slope ? P_GetZAt(*rover->b_slope, viewx, viewy) :
|
*rover->b_slope ? P_GetZAt(*rover->b_slope, viewx, viewy) :
|
||||||
|
@ -1009,6 +1008,9 @@ static void R_Subsector(size_t num)
|
||||||
ffloor[numffloors].plane = R_FindPlane(*rover->bottomheight, *rover->bottompic,
|
ffloor[numffloors].plane = R_FindPlane(*rover->bottomheight, *rover->bottompic,
|
||||||
*frontsector->lightlist[light].lightlevel, *rover->bottomxoffs,
|
*frontsector->lightlist[light].lightlevel, *rover->bottomxoffs,
|
||||||
*rover->bottomyoffs, *rover->bottomangle, frontsector->lightlist[light].extra_colormap, rover
|
*rover->bottomyoffs, *rover->bottomangle, frontsector->lightlist[light].extra_colormap, rover
|
||||||
|
#ifdef POLYOBJECTS_PLANES
|
||||||
|
, NULL
|
||||||
|
#endif
|
||||||
#ifdef ESLOPE
|
#ifdef ESLOPE
|
||||||
, *rover->b_slope
|
, *rover->b_slope
|
||||||
#endif
|
#endif
|
||||||
|
@ -1052,6 +1054,9 @@ static void R_Subsector(size_t num)
|
||||||
ffloor[numffloors].plane = R_FindPlane(*rover->topheight, *rover->toppic,
|
ffloor[numffloors].plane = R_FindPlane(*rover->topheight, *rover->toppic,
|
||||||
*frontsector->lightlist[light].lightlevel, *rover->topxoffs, *rover->topyoffs, *rover->topangle,
|
*frontsector->lightlist[light].lightlevel, *rover->topxoffs, *rover->topyoffs, *rover->topangle,
|
||||||
frontsector->lightlist[light].extra_colormap, rover
|
frontsector->lightlist[light].extra_colormap, rover
|
||||||
|
#ifdef POLYOBJECTS_PLANES
|
||||||
|
, NULL
|
||||||
|
#endif
|
||||||
#ifdef ESLOPE
|
#ifdef ESLOPE
|
||||||
, *rover->t_slope
|
, *rover->t_slope
|
||||||
#endif
|
#endif
|
||||||
|
@ -1093,8 +1098,8 @@ static void R_Subsector(size_t num)
|
||||||
polysec = po->lines[0]->backsector;
|
polysec = po->lines[0]->backsector;
|
||||||
ffloor[numffloors].plane = NULL;
|
ffloor[numffloors].plane = NULL;
|
||||||
|
|
||||||
if (polysec->floorheight <= frontsector->ceilingheight
|
if (polysec->floorheight <= ceilingcenterz
|
||||||
&& polysec->floorheight >= frontsector->floorheight
|
&& polysec->floorheight >= floorcenterz
|
||||||
&& (viewz < polysec->floorheight))
|
&& (viewz < polysec->floorheight))
|
||||||
{
|
{
|
||||||
fixed_t xoff, yoff;
|
fixed_t xoff, yoff;
|
||||||
|
@ -1118,11 +1123,13 @@ static void R_Subsector(size_t num)
|
||||||
polysec->floorpic_angle-po->angle,
|
polysec->floorpic_angle-po->angle,
|
||||||
NULL,
|
NULL,
|
||||||
NULL
|
NULL
|
||||||
|
#ifdef POLYOBJECTS_PLANES
|
||||||
|
, po
|
||||||
|
#endif
|
||||||
#ifdef ESLOPE
|
#ifdef ESLOPE
|
||||||
, NULL // will ffloors be slopable eventually?
|
, NULL // will ffloors be slopable eventually?
|
||||||
#endif
|
#endif
|
||||||
);
|
);
|
||||||
//ffloor[numffloors].plane->polyobj = po;
|
|
||||||
|
|
||||||
ffloor[numffloors].height = polysec->floorheight;
|
ffloor[numffloors].height = polysec->floorheight;
|
||||||
ffloor[numffloors].polyobj = po;
|
ffloor[numffloors].polyobj = po;
|
||||||
|
@ -1139,8 +1146,8 @@ static void R_Subsector(size_t num)
|
||||||
|
|
||||||
ffloor[numffloors].plane = NULL;
|
ffloor[numffloors].plane = NULL;
|
||||||
|
|
||||||
if (polysec->ceilingheight >= frontsector->floorheight
|
if (polysec->ceilingheight >= floorcenterz
|
||||||
&& polysec->ceilingheight <= frontsector->ceilingheight
|
&& polysec->ceilingheight <= ceilingcenterz
|
||||||
&& (viewz > polysec->ceilingheight))
|
&& (viewz > polysec->ceilingheight))
|
||||||
{
|
{
|
||||||
fixed_t xoff, yoff;
|
fixed_t xoff, yoff;
|
||||||
|
@ -1162,11 +1169,13 @@ static void R_Subsector(size_t num)
|
||||||
ffloor[numffloors].plane = R_FindPlane(polysec->ceilingheight, polysec->ceilingpic,
|
ffloor[numffloors].plane = R_FindPlane(polysec->ceilingheight, polysec->ceilingpic,
|
||||||
polysec->lightlevel, xoff, yoff, polysec->ceilingpic_angle-po->angle,
|
polysec->lightlevel, xoff, yoff, polysec->ceilingpic_angle-po->angle,
|
||||||
NULL, NULL
|
NULL, NULL
|
||||||
|
#ifdef POLYOBJECTS_PLANES
|
||||||
|
, po
|
||||||
|
#endif
|
||||||
#ifdef ESLOPE
|
#ifdef ESLOPE
|
||||||
, NULL // will ffloors be slopable eventually?
|
, NULL // will ffloors be slopable eventually?
|
||||||
#endif
|
#endif
|
||||||
);
|
);
|
||||||
//ffloor[numffloors].plane->polyobj = po;
|
|
||||||
|
|
||||||
ffloor[numffloors].polyobj = po;
|
ffloor[numffloors].polyobj = po;
|
||||||
ffloor[numffloors].height = polysec->ceilingheight;
|
ffloor[numffloors].height = polysec->ceilingheight;
|
||||||
|
|
|
@ -431,6 +431,9 @@ static visplane_t *new_visplane(unsigned hash)
|
||||||
visplane_t *R_FindPlane(fixed_t height, INT32 picnum, INT32 lightlevel,
|
visplane_t *R_FindPlane(fixed_t height, INT32 picnum, INT32 lightlevel,
|
||||||
fixed_t xoff, fixed_t yoff, angle_t plangle, extracolormap_t *planecolormap,
|
fixed_t xoff, fixed_t yoff, angle_t plangle, extracolormap_t *planecolormap,
|
||||||
ffloor_t *pfloor
|
ffloor_t *pfloor
|
||||||
|
#ifdef POLYOBJECTS_PLANES
|
||||||
|
, polyobj_t *polyobj
|
||||||
|
#endif
|
||||||
#ifdef ESLOPE
|
#ifdef ESLOPE
|
||||||
, pslope_t *slope
|
, pslope_t *slope
|
||||||
#endif
|
#endif
|
||||||
|
@ -470,6 +473,8 @@ visplane_t *R_FindPlane(fixed_t height, INT32 picnum, INT32 lightlevel,
|
||||||
#ifdef POLYOBJECTS_PLANES
|
#ifdef POLYOBJECTS_PLANES
|
||||||
if (check->polyobj && pfloor)
|
if (check->polyobj && pfloor)
|
||||||
continue;
|
continue;
|
||||||
|
if (polyobj != check->polyobj)
|
||||||
|
continue;
|
||||||
#endif
|
#endif
|
||||||
if (height == check->height && picnum == check->picnum
|
if (height == check->height && picnum == check->picnum
|
||||||
&& lightlevel == check->lightlevel
|
&& lightlevel == check->lightlevel
|
||||||
|
@ -504,7 +509,7 @@ visplane_t *R_FindPlane(fixed_t height, INT32 picnum, INT32 lightlevel,
|
||||||
check->viewangle = viewangle;
|
check->viewangle = viewangle;
|
||||||
check->plangle = plangle;
|
check->plangle = plangle;
|
||||||
#ifdef POLYOBJECTS_PLANES
|
#ifdef POLYOBJECTS_PLANES
|
||||||
check->polyobj = NULL;
|
check->polyobj = polyobj;
|
||||||
#endif
|
#endif
|
||||||
#ifdef ESLOPE
|
#ifdef ESLOPE
|
||||||
check->slope = slope;
|
check->slope = slope;
|
||||||
|
@ -719,7 +724,11 @@ void R_DrawPlanes(void)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pl->ffloor != NULL)
|
if (pl->ffloor != NULL
|
||||||
|
#ifdef POLYOBJECTS_PLANES
|
||||||
|
|| pl->polyobj != NULL
|
||||||
|
#endif
|
||||||
|
)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
R_DrawSinglePlane(pl);
|
R_DrawSinglePlane(pl);
|
||||||
|
|
|
@ -97,6 +97,9 @@ void R_MakeSpans(INT32 x, INT32 t1, INT32 b1, INT32 t2, INT32 b2);
|
||||||
void R_DrawPlanes(void);
|
void R_DrawPlanes(void);
|
||||||
visplane_t *R_FindPlane(fixed_t height, INT32 picnum, INT32 lightlevel, fixed_t xoff, fixed_t yoff, angle_t plangle,
|
visplane_t *R_FindPlane(fixed_t height, INT32 picnum, INT32 lightlevel, fixed_t xoff, fixed_t yoff, angle_t plangle,
|
||||||
extracolormap_t *planecolormap, ffloor_t *ffloor
|
extracolormap_t *planecolormap, ffloor_t *ffloor
|
||||||
|
#ifdef POLYOBJECTS_PLANES
|
||||||
|
, polyobj_t *polyobj
|
||||||
|
#endif
|
||||||
#ifdef ESLOPE
|
#ifdef ESLOPE
|
||||||
, pslope_t *slope
|
, pslope_t *slope
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1699,21 +1699,25 @@ static void R_CreateDrawNodes(void)
|
||||||
entry->ffloor = ds->thicksides[i];
|
entry->ffloor = ds->thicksides[i];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#ifdef POLYOBJECTS_PLANES
|
||||||
|
// Check for a polyobject plane, but only if this is a front line
|
||||||
|
if (ds->curline->polyseg && ds->curline->polyseg->visplane && !ds->curline->side) {
|
||||||
|
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->plane = plane;
|
||||||
|
entry->seg = ds;
|
||||||
|
}
|
||||||
|
ds->curline->polyseg->visplane = NULL;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
if (ds->maskedtexturecol)
|
if (ds->maskedtexturecol)
|
||||||
{
|
{
|
||||||
#ifdef POLYOBJECTS_PLANES
|
|
||||||
// Check for a polyobject plane, but only if this is a front line
|
|
||||||
if (ds->curline->polyseg && ds->curline->polyseg->visplane && !ds->curline->side) {
|
|
||||||
// Put it in!
|
|
||||||
|
|
||||||
entry = R_CreateDrawNode(&nodehead);
|
|
||||||
entry->plane = ds->curline->polyseg->visplane;
|
|
||||||
entry->seg = ds;
|
|
||||||
ds->curline->polyseg->visplane->polyobj = ds->curline->polyseg;
|
|
||||||
ds->curline->polyseg->visplane = NULL;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
entry = R_CreateDrawNode(&nodehead);
|
entry = R_CreateDrawNode(&nodehead);
|
||||||
entry->seg = ds;
|
entry->seg = ds;
|
||||||
}
|
}
|
||||||
|
@ -1756,6 +1760,29 @@ static void R_CreateDrawNodes(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef POLYOBJECTS_PLANES
|
||||||
|
// find all the remaining polyobject planes and add them on the end of the list
|
||||||
|
// probably this is a terrible idea if we wanted them to be sorted properly
|
||||||
|
// but it works getting them in for now
|
||||||
|
for (i = 0; i < numPolyObjects; i++)
|
||||||
|
{
|
||||||
|
if (!PolyObjects[i].visplane)
|
||||||
|
continue;
|
||||||
|
plane = PolyObjects[i].visplane;
|
||||||
|
R_PlaneBounds(plane);
|
||||||
|
|
||||||
|
if (plane->low < con_clipviewtop || plane->high > vid.height || plane->high > plane->low)
|
||||||
|
{
|
||||||
|
PolyObjects[i].visplane = NULL;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
entry = R_CreateDrawNode(&nodehead);
|
||||||
|
entry->plane = plane;
|
||||||
|
// note: no seg is set, for what should be obvious reasons
|
||||||
|
PolyObjects[i].visplane = NULL;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if (visspritecount == 0)
|
if (visspritecount == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -1812,13 +1839,16 @@ static void R_CreateDrawNodes(void)
|
||||||
if (x1 < r2->plane->minx) x1 = r2->plane->minx;
|
if (x1 < r2->plane->minx) x1 = r2->plane->minx;
|
||||||
if (x2 > r2->plane->maxx) x2 = r2->plane->maxx;
|
if (x2 > r2->plane->maxx) x2 = r2->plane->maxx;
|
||||||
|
|
||||||
for (i = x1; i <= x2; i++)
|
if (r2->seg) // if no seg set, assume the whole thing is in front or something stupid
|
||||||
{
|
{
|
||||||
if (r2->seg->frontscale[i] > rover->scale)
|
for (i = x1; i <= x2; i++)
|
||||||
break;
|
{
|
||||||
|
if (r2->seg->frontscale[i] > rover->scale)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (i > x2)
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
if (i > x2)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
entry = R_CreateDrawNode(NULL);
|
entry = R_CreateDrawNode(NULL);
|
||||||
(entry->prev = r2->prev)->next = entry;
|
(entry->prev = r2->prev)->next = entry;
|
||||||
|
|
Loading…
Reference in a new issue