mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-15 20:20:54 +00:00
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:
parent
f53b348782
commit
916cd01550
2 changed files with 21 additions and 5 deletions
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in a new issue