mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 11:10:39 +00:00
Improve player z clipping height detection
git-svn-id: https://svn.eduke32.com/eduke32@7460 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
ceaaaf9c0d
commit
af3fb71b19
1 changed files with 12 additions and 19 deletions
|
@ -4670,11 +4670,16 @@ void P_ProcessInput(int playerNum)
|
||||||
// sectorLotag can be set to 0 later on, but the same block sets spritebridge to 1
|
// sectorLotag can be set to 0 later on, but the same block sets spritebridge to 1
|
||||||
int stepHeight = (sectorLotag == ST_1_ABOVE_WATER || pPlayer->spritebridge == 1) ? pPlayer->autostep_sbw : pPlayer->autostep;
|
int stepHeight = (sectorLotag == ST_1_ABOVE_WATER || pPlayer->spritebridge == 1) ? pPlayer->autostep_sbw : pPlayer->autostep;
|
||||||
|
|
||||||
if (pPlayer->on_ground && pPlayer->pos.z + stepHeight > actor[pPlayer->i].floorz - 128)
|
|
||||||
stepHeight -= pPlayer->pos.z + stepHeight - actor[pPlayer->i].floorz + 128;
|
|
||||||
|
|
||||||
int32_t floorZ, ceilZ, highZhit, lowZhit, dummy;
|
int32_t floorZ, ceilZ, highZhit, lowZhit, dummy;
|
||||||
|
|
||||||
|
if (pPlayer->opos.z <= actor[pPlayer->i].ceilingz + PMINHEIGHT || pPlayer->opos.z >= actor[pPlayer->i].floorz - PMINHEIGHT)
|
||||||
|
stepHeight = 0;
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
if (pPlayer->on_ground && (pPlayer->pos.z + stepHeight > actor[pPlayer->i].floorz - 128))
|
||||||
|
stepHeight -= pPlayer->pos.z + stepHeight - actor[pPlayer->i].floorz + 128;
|
||||||
|
#endif
|
||||||
|
|
||||||
pPlayer->pos.z += stepHeight;
|
pPlayer->pos.z += stepHeight;
|
||||||
getzrange((vec3_t *)pPlayer, pPlayer->cursectnum, &ceilZ, &highZhit, &floorZ, &lowZhit, pPlayer->clipdist - 16, CLIPMASK0);
|
getzrange((vec3_t *)pPlayer, pPlayer->cursectnum, &ceilZ, &highZhit, &floorZ, &lowZhit, pPlayer->clipdist - 16, CLIPMASK0);
|
||||||
pPlayer->pos.z -= stepHeight;
|
pPlayer->pos.z -= stepHeight;
|
||||||
|
@ -5168,7 +5173,7 @@ void P_ProcessInput(int playerNum)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((sectorLotag != ST_2_UNDERWATER || ceilZ != pPlayer->truecz) && pPlayer->opos.z < (ceilZ + PMINHEIGHT))
|
if ((sectorLotag != ST_2_UNDERWATER || ceilZ != pPlayer->truecz) && pPlayer->jumping_counter && pPlayer->opos.z < (ceilZ + PMINHEIGHT))
|
||||||
{
|
{
|
||||||
pPlayer->jumping_counter = 0;
|
pPlayer->jumping_counter = 0;
|
||||||
if (pPlayer->vel.z < 0)
|
if (pPlayer->vel.z < 0)
|
||||||
|
@ -5380,23 +5385,11 @@ HORIZONLY:;
|
||||||
|
|
||||||
if (sectorLotag != ST_2_UNDERWATER)
|
if (sectorLotag != ST_2_UNDERWATER)
|
||||||
pPlayer->pos.z += pPlayer->vel.z;
|
pPlayer->pos.z += pPlayer->vel.z;
|
||||||
|
|
||||||
if ((sectorLotag != ST_2_UNDERWATER || ceilZ != pPlayer->truecz)
|
|
||||||
&& (pPlayer->opos.z < ceilZ + PMINHEIGHT || trueFloorDist < PHEIGHT))
|
|
||||||
{
|
|
||||||
int32_t ceilZ2 = ceilZ;
|
|
||||||
|
|
||||||
getzrange((vec3_t *)&pPlayer->opos, pPlayer->cursectnum, &ceilZ, &highZhit, &dummy, &dummy, pPlayer->clipdist - 24,
|
|
||||||
CSTAT_SPRITE_ALIGNMENT_FLOOR << 16);
|
|
||||||
|
|
||||||
if ((highZhit & 49152) == 49152 && (sprite[highZhit & (MAXSPRITES - 1)].cstat & CSTAT_SPRITE_BLOCK) != CSTAT_SPRITE_BLOCK)
|
|
||||||
ceilZ = ceilZ2;
|
|
||||||
|
|
||||||
if (pPlayer->pos.z < ceilZ + PMINHEIGHT)
|
|
||||||
pPlayer->pos.z = ceilZ + PMINHEIGHT;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((sectorLotag != ST_2_UNDERWATER || ceilZ != pPlayer->truecz) && pPlayer->pos.z < ceilZ + PMINHEIGHT)
|
||||||
|
pPlayer->pos.z = ceilZ + PMINHEIGHT;
|
||||||
|
|
||||||
if (sectorLotag != ST_1_ABOVE_WATER && pPlayer->pos.z > floorZ - PMINHEIGHT)
|
if (sectorLotag != ST_1_ABOVE_WATER && pPlayer->pos.z > floorZ - PMINHEIGHT)
|
||||||
pPlayer->pos.z = floorZ - PMINHEIGHT;
|
pPlayer->pos.z = floorZ - PMINHEIGHT;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue