mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-14 20:00:49 +00:00
- 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:
parent
d31fe01b6d
commit
fa8ca81460
8 changed files with 33 additions and 29 deletions
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)
|
||||||
{
|
{
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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))
|
||||||
|
|
Loading…
Reference in a new issue