mirror of
https://github.com/DrBeef/Raze.git
synced 2025-01-19 15:40:58 +00:00
- Duke: Ensure spawned player actor has view height baked in up until the first getzrange()
call.
* The original game spawning the player's sprite/actor would set the sprite's pos with the Z matching the player's, which had a height offset already applied. * This baked in height offset was carried through up until the `SetActor()` call in `processinput()`, where the original game would then strip off `gs.playerheight`. * This baked in height offset within the actor is critical on the first tic for pre-activated elevators on level spawn to function right, such as E1L2 and E2L3. * Properly setting the player actor's Z immediately after the initial `getzrange()` call, but before other functions like `movement()`, etc further down in `processinput()` is the best spot. * Fixes #870.
This commit is contained in:
parent
8bcbc1b892
commit
9a17d33579
3 changed files with 19 additions and 9 deletions
|
@ -2620,6 +2620,13 @@ void processinput_d(int snum)
|
||||||
shrunk = (pact->spr.scale.Y < 0.5);
|
shrunk = (pact->spr.scale.Y < 0.5);
|
||||||
getzrange(p->GetActor()->getPosWithOffsetZ(), psectp, &ceilingz, chz, &floorz, clz, 10.1875, CLIPMASK0);
|
getzrange(p->GetActor()->getPosWithOffsetZ(), psectp, &ceilingz, chz, &floorz, clz, 10.1875, CLIPMASK0);
|
||||||
|
|
||||||
|
if (!PlayClock)
|
||||||
|
{
|
||||||
|
pact->spr.pos.Z += gs.playerheight;
|
||||||
|
pact->opos.Z += gs.playerheight;
|
||||||
|
pact->oviewzoffset = pact->viewzoffset = -gs.playerheight;
|
||||||
|
}
|
||||||
|
|
||||||
p->truefz = getflorzofslopeptr(psectp, p->GetActor()->getPosWithOffsetZ());
|
p->truefz = getflorzofslopeptr(psectp, p->GetActor()->getPosWithOffsetZ());
|
||||||
p->truecz = getceilzofslopeptr(psectp, p->GetActor()->getPosWithOffsetZ());
|
p->truecz = getceilzofslopeptr(psectp, p->GetActor()->getPosWithOffsetZ());
|
||||||
|
|
||||||
|
@ -2910,7 +2917,7 @@ HORIZONLY:
|
||||||
}
|
}
|
||||||
|
|
||||||
// RBG***
|
// RBG***
|
||||||
SetActor(pact, p->GetActor()->spr.pos);
|
SetActor(pact, pact->spr.pos);
|
||||||
|
|
||||||
if (psectlotag < 3)
|
if (psectlotag < 3)
|
||||||
{
|
{
|
||||||
|
|
|
@ -3235,22 +3235,26 @@ void processinput_r(int snum)
|
||||||
p->spritebridge = 0;
|
p->spritebridge = 0;
|
||||||
|
|
||||||
shrunk = (pact->spr.scale.Y < 0.125);
|
shrunk = (pact->spr.scale.Y < 0.125);
|
||||||
double tempfz;
|
|
||||||
if (pact->clipdist == 16)
|
if (pact->clipdist == 16)
|
||||||
{
|
{
|
||||||
getzrange(p->GetActor()->getPosWithOffsetZ(), psectp, &ceilingz, chz, &floorz, clz, 10.1875, CLIPMASK0);
|
getzrange(p->GetActor()->getPosWithOffsetZ(), psectp, &ceilingz, chz, &floorz, clz, 10.1875, CLIPMASK0);
|
||||||
tempfz = getflorzofslopeptr(psectp, p->GetActor()->getPosWithOffsetZ());
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
getzrange(p->GetActor()->getPosWithOffsetZ(), psectp, &ceilingz, chz, &floorz, clz, 0.25, CLIPMASK0);
|
getzrange(p->GetActor()->getPosWithOffsetZ(), psectp, &ceilingz, chz, &floorz, clz, 0.25, CLIPMASK0);
|
||||||
tempfz = getflorzofslopeptr(psectp, p->GetActor()->getPosWithOffsetZ());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
p->truefz = tempfz;
|
if (!PlayClock)
|
||||||
|
{
|
||||||
|
pact->spr.pos.Z += gs.playerheight;
|
||||||
|
pact->opos.Z += gs.playerheight;
|
||||||
|
pact->oviewzoffset = pact->viewzoffset = -gs.playerheight;
|
||||||
|
}
|
||||||
|
|
||||||
|
p->truefz = getflorzofslopeptr(psectp, p->GetActor()->getPosWithOffsetZ());
|
||||||
p->truecz = getceilzofslopeptr(psectp, p->GetActor()->getPosWithOffsetZ());
|
p->truecz = getceilzofslopeptr(psectp, p->GetActor()->getPosWithOffsetZ());
|
||||||
|
|
||||||
double truefdist = abs(p->GetActor()->getOffsetZ() - tempfz);
|
double truefdist = abs(p->GetActor()->getOffsetZ() - p->truefz);
|
||||||
if (clz.type == kHitSector && psectlotag == 1 && truefdist > gs.playerheight + 16)
|
if (clz.type == kHitSector && psectlotag == 1 && truefdist > gs.playerheight + 16)
|
||||||
psectlotag = 0;
|
psectlotag = 0;
|
||||||
|
|
||||||
|
@ -3700,7 +3704,7 @@ HORIZONLY:
|
||||||
}
|
}
|
||||||
|
|
||||||
// RBG***
|
// RBG***
|
||||||
SetActor(pact, p->GetActor()->spr.pos);
|
SetActor(pact, pact->spr.pos);
|
||||||
|
|
||||||
if (psectlotag == 800 && (!isRRRA() || !p->lotag800kill))
|
if (psectlotag == 800 && (!isRRRA() || !p->lotag800kill))
|
||||||
{
|
{
|
||||||
|
|
|
@ -503,11 +503,10 @@ void resetpspritevars(int g, const DVector3& startpos, const DAngle startang)
|
||||||
int aimmode[MAXPLAYERS];
|
int aimmode[MAXPLAYERS];
|
||||||
STATUSBARTYPE tsbar[MAXPLAYERS];
|
STATUSBARTYPE tsbar[MAXPLAYERS];
|
||||||
|
|
||||||
auto newActor = CreateActor(ps[0].cursector, startpos.plusZ(gs.playerheight),
|
auto newActor = CreateActor(ps[0].cursector, startpos,
|
||||||
TILE_APLAYER, 0, DVector2(0, 0), startang, 0., 0., nullptr, 10);
|
TILE_APLAYER, 0, DVector2(0, 0), startang, 0., 0., nullptr, 10);
|
||||||
|
|
||||||
newActor->spr.Angles.Pitch = DAngle::fromDeg(-17.354);
|
newActor->spr.Angles.Pitch = DAngle::fromDeg(-17.354);
|
||||||
newActor->viewzoffset = -gs.playerheight;
|
|
||||||
newActor->backuploc();
|
newActor->backuploc();
|
||||||
|
|
||||||
if (ud.recstat != 2) for (i = 0; i < MAXPLAYERS; i++)
|
if (ud.recstat != 2) for (i = 0; i < MAXPLAYERS; i++)
|
||||||
|
|
Loading…
Reference in a new issue