- SW: added persistent copy of oz.

The door movement code uses oz for its position checks so we need a persistent version of it that survives uncontrolled changes from the engine side.
This commit is contained in:
Christoph Oelckers 2021-02-28 12:35:34 +01:00
parent d31fe01b6d
commit fa8ca81460
8 changed files with 33 additions and 29 deletions

View file

@ -555,7 +555,7 @@ KeepActorOnFloor(short SpriteNum)
// was swimming but have now stopped // was swimming but have now stopped
RESET(u->Flags, SPR_SWIMMING); RESET(u->Flags, SPR_SWIMMING);
RESET(sp->cstat, CSTAT_SPRITE_YCENTER); RESET(sp->cstat, CSTAT_SPRITE_YCENTER);
sp->z = u->loz; u->oz = sp->z = u->loz;
sp->backupz(); sp->backupz();
return; return;
} }
@ -566,7 +566,7 @@ KeepActorOnFloor(short SpriteNum)
} }
// are swimming // are swimming
sp->z = u->loz - Z(depth); u->oz = sp->z = u->loz - Z(depth);
sp->backupz(); sp->backupz();
} }
else else
@ -575,7 +575,7 @@ KeepActorOnFloor(short SpriteNum)
if (u->Rot == u->ActorActionSet->Run || u->Rot == u->ActorActionSet->Swim) if (u->Rot == u->ActorActionSet->Run || u->Rot == u->ActorActionSet->Swim)
{ {
NewStateGroup(SpriteNum, u->ActorActionSet->Swim); NewStateGroup(SpriteNum, u->ActorActionSet->Swim);
sp->z = u->loz - Z(depth); u->oz = sp->z = u->loz - Z(depth);
sp->backupz(); sp->backupz();
SET(u->Flags, SPR_SWIMMING); SET(u->Flags, SPR_SWIMMING);
SET(sp->cstat, CSTAT_SPRITE_YCENTER); SET(sp->cstat, CSTAT_SPRITE_YCENTER);
@ -584,7 +584,7 @@ KeepActorOnFloor(short SpriteNum)
{ {
RESET(u->Flags, SPR_SWIMMING); RESET(u->Flags, SPR_SWIMMING);
RESET(sp->cstat, CSTAT_SPRITE_YCENTER); RESET(sp->cstat, CSTAT_SPRITE_YCENTER);
sp->z = u->loz; u->oz = sp->z = u->loz;
sp->backupz(); sp->backupz();
} }
} }
@ -599,7 +599,7 @@ KeepActorOnFloor(short SpriteNum)
#if 1 #if 1
if (TEST(u->Flags, SPR_MOVED)) if (TEST(u->Flags, SPR_MOVED))
{ {
sp->z = u->loz; u->oz = sp->z = u->loz;
sp->backupz(); sp->backupz();
} }
else else
@ -608,7 +608,7 @@ KeepActorOnFloor(short SpriteNum)
FAFgetzrangepoint(sp->x, sp->y, sp->z, sp->sectnum, FAFgetzrangepoint(sp->x, sp->y, sp->z, sp->sectnum,
&ceilz, &ceilhit, &florz, &florhit); &ceilz, &ceilhit, &florz, &florhit);
sp->z = florz; u->oz = sp->z = florz;
sp->backupz(); sp->backupz();
} }
#endif #endif

View file

@ -1143,6 +1143,7 @@ typedef struct
int Flags; int Flags;
int Flags2; int Flags2;
int Tics; int Tics;
int oz; // serialized copy of sprite.oz
short RotNum; short RotNum;
short ID; short ID;

View file

@ -6865,6 +6865,7 @@ MoveSkipSavePos(void)
continue; continue;
sp->backuppos(); sp->backuppos();
u->oz = sp->oz;
} }
} }
} }
@ -6887,6 +6888,7 @@ MoveSkipSavePos(void)
if (sp == NULL || u == NULL) if (sp == NULL || u == NULL)
continue; continue;
sp->backuppos(); sp->backuppos();
u->oz = sp->oz;
} }
} }
} }

View file

@ -55,18 +55,18 @@ void ReverseSpike(short SpriteNum)
} }
// moving toward to OFF pos // moving toward to OFF pos
if (u->z_tgt == sp->oz) if (u->z_tgt == u->oz)
{ {
if (sp->z == sp->oz) if (sp->z == u->oz)
u->z_tgt = u->sz; u->z_tgt = u->sz;
else if (u->sz == sp->oz) else if (u->sz == u->oz)
u->z_tgt = sp->z; u->z_tgt = sp->z;
} }
else if (u->z_tgt == u->sz) else if (u->z_tgt == u->sz)
{ {
if (sp->z == sp->oz) if (sp->z == u->oz)
u->z_tgt = sp->z; u->z_tgt = sp->z;
else if (u->sz == sp->oz) else if (u->sz == u->oz)
u->z_tgt = u->sz; u->z_tgt = u->sz;
} }
@ -389,7 +389,7 @@ int DoSpike(short SpriteNum)
} }
// setup to go back to the original z // setup to go back to the original z
if (*lptr != sp->oz) if (*lptr != u->oz)
{ {
if (u->WaitTics) if (u->WaitTics)
u->Tics = u->WaitTics; u->Tics = u->WaitTics;
@ -398,7 +398,7 @@ int DoSpike(short SpriteNum)
else // if (*lptr == u->z_tgt) else // if (*lptr == u->z_tgt)
{ {
// if heading for the OFF (original) position and should NOT CRUSH // if heading for the OFF (original) position and should NOT CRUSH
if (TEST_BOOL3(sp) && u->z_tgt == sp->oz) if (TEST_BOOL3(sp) && u->z_tgt == u->oz)
{ {
int i; int i;
SPRITEp bsp; SPRITEp bsp;

View file

@ -916,6 +916,7 @@ SpawnUser(short SpriteNum, short id, STATEp state)
u->motion_blur_dist = 256; u->motion_blur_dist = 256;
sp->backuppos(); sp->backuppos();
u->oz = sp->oz;
u->active_range = MIN_ACTIVE_RANGE; u->active_range = MIN_ACTIVE_RANGE;
@ -2345,7 +2346,7 @@ SpriteSetup(void)
} }
// set orig z // set orig z
sp->oz = sectp->floorz; u->oz = sp->oz = sectp->floorz;
} }
else else
{ {
@ -2366,7 +2367,7 @@ SpriteSetup(void)
} }
// set orig z // set orig z
sp->oz = sectp->ceilingz; u->oz = sp->oz = sectp->ceilingz;
} }
@ -2557,7 +2558,7 @@ SpriteSetup(void)
} }
// set orig z // set orig z
sp->oz = u->zclip; u->oz = sp->oz = u->zclip;
} }
else else
{ {
@ -2575,7 +2576,7 @@ SpriteSetup(void)
} }
// set orig z // set orig z
sp->oz = u->zclip; u->oz = sp->oz = u->zclip;
} }
change_sprite_stat(SpriteNum, STAT_SPIKE); change_sprite_stat(SpriteNum, STAT_SPIKE);
@ -7120,6 +7121,7 @@ void MissileWarpUpdatePos(short SpriteNum, short sectnum)
USERp u = User[SpriteNum]; USERp u = User[SpriteNum];
SPRITEp sp = u->SpriteP; SPRITEp sp = u->SpriteP;
sp->backuppos(); sp->backuppos();
u->oz = sp->oz;
changespritesect(SpriteNum, sectnum); changespritesect(SpriteNum, sectnum);
MissileZrange(SpriteNum); MissileZrange(SpriteNum);
} }
@ -7129,6 +7131,7 @@ void ActorWarpUpdatePos(short SpriteNum, short sectnum)
USERp u = User[SpriteNum]; USERp u = User[SpriteNum];
SPRITEp sp = u->SpriteP; SPRITEp sp = u->SpriteP;
sp->backuppos(); sp->backuppos();
u->oz = sp->oz;
changespritesect(SpriteNum, sectnum); changespritesect(SpriteNum, sectnum);
DoActorZrange(SpriteNum); DoActorZrange(SpriteNum);
} }

View file

@ -912,6 +912,7 @@ SectorObjectSetupBounds(SECTOR_OBJECTp sop)
u->RotNum = 0; u->RotNum = 0;
sp->backuppos(); sp->backuppos();
u->oz = sp->oz;
switch (sp->statnum) switch (sp->statnum)
{ {

View file

@ -59,18 +59,18 @@ void ReverseVator(short SpriteNum)
} }
// moving toward to OFF pos // moving toward to OFF pos
if (u->z_tgt == sp->oz) if (u->z_tgt == u->oz)
{ {
if (sp->z == sp->oz) if (sp->z == u->oz)
u->z_tgt = u->sz; u->z_tgt = u->sz;
else if (u->sz == sp->oz) else if (u->sz == u->oz)
u->z_tgt = sp->z; u->z_tgt = sp->z;
} }
else if (u->z_tgt == u->sz) else if (u->z_tgt == u->sz)
{ {
if (sp->z == sp->oz) if (sp->z == u->oz)
u->z_tgt = sp->z; u->z_tgt = sp->z;
else if (u->sz == sp->oz) else if (u->sz == u->oz)
u->z_tgt = u->sz; u->z_tgt = u->sz;
} }
@ -530,7 +530,7 @@ int DoVator(short SpriteNum)
} }
// setup to go back to the original z // setup to go back to the original z
if (*lptr != sp->oz) if (*lptr != u->oz)
{ {
if (u->WaitTics) if (u->WaitTics)
u->Tics = u->WaitTics; u->Tics = u->WaitTics;
@ -539,7 +539,7 @@ int DoVator(short SpriteNum)
else // if (*lptr == u->z_tgt) else // if (*lptr == u->z_tgt)
{ {
// if heading for the OFF (original) position and should NOT CRUSH // if heading for the OFF (original) position and should NOT CRUSH
if (TEST_BOOL3(sp) && u->z_tgt == sp->oz) if (TEST_BOOL3(sp) && u->z_tgt == u->oz)
{ {
int i; int i;
SPRITEp bsp; SPRITEp bsp;

View file

@ -10158,6 +10158,7 @@ DoRocket(int16_t Weapon)
SPRITEp sp = &sprite[Weapon]; SPRITEp sp = &sprite[Weapon];
USERp u = User[Weapon]; USERp u = User[Weapon];
int dist,a,b,c; int dist,a,b,c;
auto pos = sp->pos;
if ((u->FlagOwner -= ACTORMOVETICS)<=0 && u->spal == 20) if ((u->FlagOwner -= ACTORMOVETICS)<=0 && u->spal == 20)
@ -10211,7 +10212,7 @@ DoRocket(int16_t Weapon)
short New; short New;
New = SpawnSprite(STAT_MISSILE, PUFF, s_Puff, sp->sectnum, New = SpawnSprite(STAT_MISSILE, PUFF, s_Puff, sp->sectnum,
sp->ox, sp->oy, sp->oz, sp->ang, 100); pos.x, pos.y, pos.z, sp->ang, 100);
np = &sprite[New]; np = &sprite[New];
nu = User[New]; nu = User[New];
@ -11433,10 +11434,6 @@ SpawnBigGunFlames(int16_t Weapon, int16_t Operator, SECTOR_OBJECTp sop)
sop->sp_num[sn] = explosion; sop->sp_num[sn] = explosion;
so_setspriteinterpolation(sop, exp); so_setspriteinterpolation(sop, exp);
// Place sprite exactly where shoot point is
//exp->x = eu->ox = sop->xmid - u->sx;
//exp->y = eu->oy = sop->ymid - u->sy;
SET(eu->Flags, TEST(u->Flags, SPR_ON_SO_SECTOR|SPR_SO_ATTACHED)); SET(eu->Flags, TEST(u->Flags, SPR_ON_SO_SECTOR|SPR_SO_ATTACHED));
if (TEST(u->Flags, SPR_ON_SO_SECTOR)) if (TEST(u->Flags, SPR_ON_SO_SECTOR))