mirror of
https://git.do.srb2.org/STJr/SRB2.git
synced 2025-01-20 16:31:03 +00:00
Optimize Z position functions on sloped sectors
This commit is contained in:
parent
7962b243de
commit
6a6b65ddc4
3 changed files with 33 additions and 4 deletions
|
@ -1109,7 +1109,7 @@ fixed_t P_MobjFloorZ(mobj_t *mobj, sector_t *sector, sector_t *boundsec, fixed_t
|
||||||
testy += y;
|
testy += y;
|
||||||
|
|
||||||
// If the highest point is in the sector, then we have it easy! Just get the Z at that point
|
// If the highest point is in the sector, then we have it easy! Just get the Z at that point
|
||||||
if (R_PointInSubsector(testx, testy)->sector == (boundsec ? boundsec : sector))
|
if (R_IsPointInSector(boundsec ? boundsec : sector, testx, testy))
|
||||||
return P_GetSlopeZAt(slope, testx, testy);
|
return P_GetSlopeZAt(slope, testx, testy);
|
||||||
|
|
||||||
// If boundsec is set, we're looking for specials. In that case, iterate over every line in this sector to find the TRUE highest/lowest point
|
// If boundsec is set, we're looking for specials. In that case, iterate over every line in this sector to find the TRUE highest/lowest point
|
||||||
|
@ -1186,7 +1186,7 @@ fixed_t P_MobjCeilingZ(mobj_t *mobj, sector_t *sector, sector_t *boundsec, fixed
|
||||||
testy += y;
|
testy += y;
|
||||||
|
|
||||||
// If the highest point is in the sector, then we have it easy! Just get the Z at that point
|
// If the highest point is in the sector, then we have it easy! Just get the Z at that point
|
||||||
if (R_PointInSubsector(testx, testy)->sector == (boundsec ? boundsec : sector))
|
if (R_IsPointInSector(boundsec ? boundsec : sector, testx, testy))
|
||||||
return P_GetSlopeZAt(slope, testx, testy);
|
return P_GetSlopeZAt(slope, testx, testy);
|
||||||
|
|
||||||
// If boundsec is set, we're looking for specials. In that case, iterate over every line in this sector to find the TRUE highest/lowest point
|
// If boundsec is set, we're looking for specials. In that case, iterate over every line in this sector to find the TRUE highest/lowest point
|
||||||
|
@ -1264,7 +1264,7 @@ fixed_t P_CameraFloorZ(camera_t *mobj, sector_t *sector, sector_t *boundsec, fix
|
||||||
testy += y;
|
testy += y;
|
||||||
|
|
||||||
// If the highest point is in the sector, then we have it easy! Just get the Z at that point
|
// If the highest point is in the sector, then we have it easy! Just get the Z at that point
|
||||||
if (R_PointInSubsector(testx, testy)->sector == (boundsec ? boundsec : sector))
|
if (R_IsPointInSector(boundsec ? boundsec : sector, testx, testy))
|
||||||
return P_GetSlopeZAt(slope, testx, testy);
|
return P_GetSlopeZAt(slope, testx, testy);
|
||||||
|
|
||||||
// If boundsec is set, we're looking for specials. In that case, iterate over every line in this sector to find the TRUE highest/lowest point
|
// If boundsec is set, we're looking for specials. In that case, iterate over every line in this sector to find the TRUE highest/lowest point
|
||||||
|
@ -1341,7 +1341,7 @@ fixed_t P_CameraCeilingZ(camera_t *mobj, sector_t *sector, sector_t *boundsec, f
|
||||||
testy += y;
|
testy += y;
|
||||||
|
|
||||||
// If the highest point is in the sector, then we have it easy! Just get the Z at that point
|
// If the highest point is in the sector, then we have it easy! Just get the Z at that point
|
||||||
if (R_PointInSubsector(testx, testy)->sector == (boundsec ? boundsec : sector))
|
if (R_IsPointInSector(boundsec ? boundsec : sector, testx, testy))
|
||||||
return P_GetSlopeZAt(slope, testx, testy);
|
return P_GetSlopeZAt(slope, testx, testy);
|
||||||
|
|
||||||
// If boundsec is set, we're looking for specials. In that case, iterate over every line in this sector to find the TRUE highest/lowest point
|
// If boundsec is set, we're looking for specials. In that case, iterate over every line in this sector to find the TRUE highest/lowest point
|
||||||
|
|
28
src/r_main.c
28
src/r_main.c
|
@ -1027,6 +1027,34 @@ void R_Init(void)
|
||||||
framecount = 0;
|
framecount = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// R_IsPointInSector
|
||||||
|
//
|
||||||
|
boolean R_IsPointInSector(sector_t *sector, fixed_t x, fixed_t y)
|
||||||
|
{
|
||||||
|
size_t i;
|
||||||
|
line_t *closest = NULL;
|
||||||
|
fixed_t closestdist = 0x7fffffff;
|
||||||
|
|
||||||
|
for (i = 0; i < sector->linecount; i++)
|
||||||
|
{
|
||||||
|
vertex_t v;
|
||||||
|
fixed_t dist;
|
||||||
|
|
||||||
|
// find the line closest to the point we're looking for.
|
||||||
|
P_ClosestPointOnLine(x, y, sector->lines[i], &v);
|
||||||
|
dist = R_PointToDist2(0, 0, v.x - x, v.y - y);
|
||||||
|
if (dist < closestdist)
|
||||||
|
{
|
||||||
|
closest = sector->lines[i];
|
||||||
|
closestdist = dist;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// if the side of the closest line is in this sector, we're inside of it.
|
||||||
|
return P_PointOnLineSide(x, y, closest) == 0 ? closest->frontsector == sector : closest->backsector == sector;
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// R_PointInSubsector
|
// R_PointInSubsector
|
||||||
//
|
//
|
||||||
|
|
|
@ -79,6 +79,7 @@ fixed_t R_PointToDist(fixed_t x, fixed_t y);
|
||||||
fixed_t R_PointToDist2(fixed_t px2, fixed_t py2, fixed_t px1, fixed_t py1);
|
fixed_t R_PointToDist2(fixed_t px2, fixed_t py2, fixed_t px1, fixed_t py1);
|
||||||
|
|
||||||
fixed_t R_ScaleFromGlobalAngle(angle_t visangle);
|
fixed_t R_ScaleFromGlobalAngle(angle_t visangle);
|
||||||
|
boolean R_IsPointInSector(sector_t *sector, fixed_t x, fixed_t y);
|
||||||
subsector_t *R_PointInSubsector(fixed_t x, fixed_t y);
|
subsector_t *R_PointInSubsector(fixed_t x, fixed_t y);
|
||||||
subsector_t *R_PointInSubsectorOrNull(fixed_t x, fixed_t y);
|
subsector_t *R_PointInSubsectorOrNull(fixed_t x, fixed_t y);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue