SW: While not exactly a favorite of mine, this fixes the floorz updates

of the secret rotating pillar in level 1 with SO interpolation.
The drill in level 2 is also covered. So far, SetVatorActive seems
to be the only place where interpolation of ceiling/floorz
may be set, outside of the SO interpolation code.
This commit is contained in:
NY00123 2020-05-21 21:42:48 +03:00 committed by Christoph Oelckers
parent f53b348782
commit 916cd01550
2 changed files with 21 additions and 5 deletions

View file

@ -142,7 +142,7 @@ SWBOOL Global_PLock = FALSE;
#endif #endif
// 12 was original source release. For future releases increment by two. // 12 was original source release. For future releases increment by two.
int GameVersion = 15; int GameVersion = 17;
char DemoText[3][64]; char DemoText[3][64];
int DemoTextYstart = 0; int DemoTextYstart = 0;

View file

@ -32,6 +32,7 @@ Prepared for public release: 03/28/2005 - Charlie Wiederhold, 3D Realms
#include "game.h" #include "game.h"
#include "interp.h" #include "interp.h"
#include "interpso.h" #include "interpso.h"
#include "names2.h"
BEGIN_SW_NS BEGIN_SW_NS
@ -52,6 +53,7 @@ static struct so_interp
int32_t numinterpolations; int32_t numinterpolations;
int32_t tic, lasttic; int32_t tic, lasttic;
SWBOOL hasvator;
} so_interpdata[MAX_SECTOR_OBJECTS]; } so_interpdata[MAX_SECTOR_OBJECTS];
static void so_setpointinterpolation(so_interp *interp, int32_t *posptr) static void so_setpointinterpolation(so_interp *interp, int32_t *posptr)
@ -116,6 +118,7 @@ void so_addinterpolation(SECTOR_OBJECTp sop)
so_interp *interp = &so_interpdata[sop - SectorObject]; so_interp *interp = &so_interpdata[sop - SectorObject];
interp->numinterpolations = 0; interp->numinterpolations = 0;
interp->hasvator = FALSE;
for (sectp = sop->sectp; *sectp; sectp++) for (sectp = sop->sectp; *sectp; sectp++)
{ {
@ -136,10 +139,19 @@ void so_addinterpolation(SECTOR_OBJECTp sop)
} }
} }
so_setpointinterpolation(interp, &(*sectp)->ceilingz); for (SPRITES_OF_SECT(*sectp - sector, i))
so_setpointinterpolation(interp, &(*sectp)->floorz); if (sprite[i].statnum == STAT_VATOR && SP_TAG1(sprite+i) == SECT_VATOR)
break;
interp->hasvator |= (i >= 0);
} }
if (!interp->hasvator)
for (sectp = sop->sectp; *sectp; sectp++)
{
so_setpointinterpolation(interp, &(*sectp)->ceilingz);
so_setpointinterpolation(interp, &(*sectp)->floorz);
}
// interpolate midpoint, for aiming at a remote controlled SO // interpolate midpoint, for aiming at a remote controlled SO
so_setpointinterpolation(interp, &sop->xmid); so_setpointinterpolation(interp, &sop->xmid);
so_setpointinterpolation(interp, &sop->ymid); so_setpointinterpolation(interp, &sop->ymid);
@ -155,7 +167,8 @@ void so_setspriteinterpolation(SECTOR_OBJECTp sop, spritetype *sp)
so_setpointinterpolation(interp, &sp->x); so_setpointinterpolation(interp, &sp->x);
so_setpointinterpolation(interp, &sp->y); so_setpointinterpolation(interp, &sp->y);
so_setpointinterpolation(interp, &sp->z); if (!interp->hasvator)
so_setpointinterpolation(interp, &sp->z);
so_setspriteanginterpolation(interp, &sp->ang, sp - sprite); so_setspriteanginterpolation(interp, &sp->ang, sp - sprite);
} }
@ -165,7 +178,8 @@ void so_stopspriteinterpolation(SECTOR_OBJECTp sop, spritetype *sp)
so_stopdatainterpolation(interp, &sp->x); so_stopdatainterpolation(interp, &sp->x);
so_stopdatainterpolation(interp, &sp->y); so_stopdatainterpolation(interp, &sp->y);
so_stopdatainterpolation(interp, &sp->z); if (!interp->hasvator)
so_stopdatainterpolation(interp, &sp->z);
so_stopdatainterpolation(interp, &sp->ang); so_stopdatainterpolation(interp, &sp->ang);
} }
@ -316,6 +330,7 @@ SWBOOL so_writeinterpolations(MFILE_WRITE fil)
{ {
so_interp::interp_data *data = interp->data; so_interp::interp_data *data = interp->data;
MWRITE(&interp->numinterpolations,sizeof(interp->numinterpolations),1,fil); MWRITE(&interp->numinterpolations,sizeof(interp->numinterpolations),1,fil);
MWRITE(&interp->hasvator,sizeof(interp->hasvator),1,fil);
for (i = 0; i < interp->numinterpolations; i++, data++) for (i = 0; i < interp->numinterpolations; i++, data++)
{ {
saveisshot |= SaveSymDataInfo(fil, data->curipos); saveisshot |= SaveSymDataInfo(fil, data->curipos);
@ -340,6 +355,7 @@ SWBOOL so_readinterpolations(MFILE_READ fil)
{ {
so_interp::interp_data *data = interp->data; so_interp::interp_data *data = interp->data;
MREAD(&interp->numinterpolations,sizeof(interp->numinterpolations),1,fil); MREAD(&interp->numinterpolations,sizeof(interp->numinterpolations),1,fil);
MREAD(&interp->hasvator,sizeof(interp->hasvator),1,fil);
for (i = 0; i < interp->numinterpolations; i++, data++) for (i = 0; i < interp->numinterpolations; i++, data++)
{ {
saveisshot |= LoadSymDataInfo(fil, (void **)&data->curipos); saveisshot |= LoadSymDataInfo(fil, (void **)&data->curipos);