mirror of
https://git.do.srb2.org/STJr/SRB2.git
synced 2025-01-22 09:11:21 +00:00
Add sector gravity field for UDMF
This commit is contained in:
parent
e3d41e0bda
commit
86e2fefcac
8 changed files with 43 additions and 25 deletions
|
@ -51,6 +51,7 @@ enum sector_e {
|
||||||
sector_cslope,
|
sector_cslope,
|
||||||
sector_flags,
|
sector_flags,
|
||||||
sector_friction,
|
sector_friction,
|
||||||
|
sector_gravity,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const char *const sector_opt[] = {
|
static const char *const sector_opt[] = {
|
||||||
|
@ -76,6 +77,7 @@ static const char *const sector_opt[] = {
|
||||||
"c_slope",
|
"c_slope",
|
||||||
"flags",
|
"flags",
|
||||||
"friction",
|
"friction",
|
||||||
|
"gravity",
|
||||||
NULL};
|
NULL};
|
||||||
|
|
||||||
enum subsector_e {
|
enum subsector_e {
|
||||||
|
@ -659,6 +661,9 @@ static int sector_get(lua_State *L)
|
||||||
case sector_friction: // friction
|
case sector_friction: // friction
|
||||||
lua_pushinteger(L, sector->friction);
|
lua_pushinteger(L, sector->friction);
|
||||||
return 1;
|
return 1;
|
||||||
|
case sector_gravity: // gravity
|
||||||
|
lua_pushfixed(L, sector->gravity);
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -749,6 +754,9 @@ static int sector_set(lua_State *L)
|
||||||
case sector_flags:
|
case sector_flags:
|
||||||
sector->flags = luaL_checkinteger(L, 3);
|
sector->flags = luaL_checkinteger(L, 3);
|
||||||
break;
|
break;
|
||||||
|
case sector_gravity:
|
||||||
|
sector->gravity = luaL_checkfixed(L, 3);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -11461,10 +11461,7 @@ void A_BrakLobShot(mobj_t *actor)
|
||||||
return; // Don't even bother if we've got nothing to aim at.
|
return; // Don't even bother if we've got nothing to aim at.
|
||||||
|
|
||||||
// Look up actor's current gravity situation
|
// Look up actor's current gravity situation
|
||||||
if (actor->subsector->sector->gravity)
|
g = FixedMul(gravity, P_GetSectorGravityFactor(actor->subsector->sector));
|
||||||
g = FixedMul(gravity,(FixedDiv(*actor->subsector->sector->gravity>>FRACBITS, 1000)));
|
|
||||||
else
|
|
||||||
g = gravity;
|
|
||||||
|
|
||||||
// Look up distance between actor and its target
|
// Look up distance between actor and its target
|
||||||
x = P_AproxDistance(actor->target->x - actor->x, actor->target->y - actor->y);
|
x = P_AproxDistance(actor->target->x - actor->x, actor->target->y - actor->y);
|
||||||
|
@ -11576,10 +11573,7 @@ void A_NapalmScatter(mobj_t *actor)
|
||||||
airtime = 16<<FRACBITS;
|
airtime = 16<<FRACBITS;
|
||||||
|
|
||||||
// Look up actor's current gravity situation
|
// Look up actor's current gravity situation
|
||||||
if (actor->subsector->sector->gravity)
|
g = FixedMul(gravity, P_GetSectorGravityFactor(actor->subsector->sector));
|
||||||
g = FixedMul(gravity,(FixedDiv(*actor->subsector->sector->gravity>>FRACBITS, 1000)));
|
|
||||||
else
|
|
||||||
g = gravity;
|
|
||||||
|
|
||||||
// vy = (g*(airtime-1))/2
|
// vy = (g*(airtime-1))/2
|
||||||
vy = FixedMul(g,(airtime-(1<<FRACBITS)))>>1;
|
vy = FixedMul(g,(airtime-(1<<FRACBITS)))>>1;
|
||||||
|
@ -12289,10 +12283,7 @@ void A_Boss5Jump(mobj_t *actor)
|
||||||
return; // Don't even bother if we've got nothing to aim at.
|
return; // Don't even bother if we've got nothing to aim at.
|
||||||
|
|
||||||
// Look up actor's current gravity situation
|
// Look up actor's current gravity situation
|
||||||
if (actor->subsector->sector->gravity)
|
g = FixedMul(gravity, P_GetSectorGravityFactor(actor->subsector->sector));
|
||||||
g = FixedMul(gravity,(FixedDiv(*actor->subsector->sector->gravity>>FRACBITS, 1000)));
|
|
||||||
else
|
|
||||||
g = gravity;
|
|
||||||
|
|
||||||
// Look up distance between actor and its tracer
|
// Look up distance between actor and its tracer
|
||||||
x = P_AproxDistance(actor->tracer->x - actor->x, actor->tracer->y - actor->y);
|
x = P_AproxDistance(actor->tracer->x - actor->x, actor->tracer->y - actor->y);
|
||||||
|
|
14
src/p_mobj.c
14
src/p_mobj.c
|
@ -1446,6 +1446,7 @@ fixed_t P_GetMobjGravity(mobj_t *mo)
|
||||||
if (mo->subsector->sector->ffloors) // Check for 3D floor gravity too.
|
if (mo->subsector->sector->ffloors) // Check for 3D floor gravity too.
|
||||||
{
|
{
|
||||||
ffloor_t *rover;
|
ffloor_t *rover;
|
||||||
|
fixed_t gravfactor;
|
||||||
|
|
||||||
for (rover = mo->subsector->sector->ffloors; rover; rover = rover->next)
|
for (rover = mo->subsector->sector->ffloors; rover; rover = rover->next)
|
||||||
{
|
{
|
||||||
|
@ -1455,11 +1456,12 @@ fixed_t P_GetMobjGravity(mobj_t *mo)
|
||||||
if ((rover->flags & (FF_SWIMMABLE|FF_GOOWATER)) == (FF_SWIMMABLE|FF_GOOWATER))
|
if ((rover->flags & (FF_SWIMMABLE|FF_GOOWATER)) == (FF_SWIMMABLE|FF_GOOWATER))
|
||||||
goopgravity = true;
|
goopgravity = true;
|
||||||
|
|
||||||
if (!(rover->master->frontsector->gravity))
|
gravfactor = P_GetSectorGravityFactor(mo->subsector->sector);
|
||||||
|
|
||||||
|
if (gravfactor == FRACUNIT)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
gravityadd = -FixedMul(gravity,
|
gravityadd = -FixedMul(gravity, gravfactor);
|
||||||
(FixedDiv(*rover->master->frontsector->gravity>>FRACBITS, 1000)));
|
|
||||||
|
|
||||||
if (rover->master->frontsector->verticalflip && gravityadd > 0)
|
if (rover->master->frontsector->verticalflip && gravityadd > 0)
|
||||||
mo->eflags |= MFE_VERTICALFLIP;
|
mo->eflags |= MFE_VERTICALFLIP;
|
||||||
|
@ -1471,11 +1473,7 @@ fixed_t P_GetMobjGravity(mobj_t *mo)
|
||||||
|
|
||||||
if (no3dfloorgrav)
|
if (no3dfloorgrav)
|
||||||
{
|
{
|
||||||
if (mo->subsector->sector->gravity)
|
gravityadd = -FixedMul(gravity, P_GetSectorGravityFactor(mo->subsector->sector));
|
||||||
gravityadd = -FixedMul(gravity,
|
|
||||||
(FixedDiv(*mo->subsector->sector->gravity>>FRACBITS, 1000)));
|
|
||||||
else
|
|
||||||
gravityadd = -gravity;
|
|
||||||
|
|
||||||
if (mo->subsector->sector->verticalflip && gravityadd > 0)
|
if (mo->subsector->sector->verticalflip && gravityadd > 0)
|
||||||
mo->eflags |= MFE_VERTICALFLIP;
|
mo->eflags |= MFE_VERTICALFLIP;
|
||||||
|
|
|
@ -853,6 +853,7 @@ static void P_NetUnArchiveWaypoints(void)
|
||||||
#define SD_FLOORLIGHT 0x08
|
#define SD_FLOORLIGHT 0x08
|
||||||
#define SD_CEILLIGHT 0x10
|
#define SD_CEILLIGHT 0x10
|
||||||
#define SD_FLAG 0x20
|
#define SD_FLAG 0x20
|
||||||
|
#define SD_GRAVITY 0x40
|
||||||
|
|
||||||
#define LD_FLAG 0x01
|
#define LD_FLAG 0x01
|
||||||
#define LD_SPECIAL 0x02
|
#define LD_SPECIAL 0x02
|
||||||
|
@ -1040,6 +1041,8 @@ static void ArchiveSectors(void)
|
||||||
diff3 |= SD_CEILLIGHT;
|
diff3 |= SD_CEILLIGHT;
|
||||||
if (ss->flags != spawnss->flags)
|
if (ss->flags != spawnss->flags)
|
||||||
diff3 |= SD_FLAG;
|
diff3 |= SD_FLAG;
|
||||||
|
if (ss->gravity != spawnss->gravity)
|
||||||
|
diff3 |= SD_GRAVITY;
|
||||||
|
|
||||||
if (ss->ffloors && CheckFFloorDiff(ss))
|
if (ss->ffloors && CheckFFloorDiff(ss))
|
||||||
diff |= SD_FFLOORS;
|
diff |= SD_FFLOORS;
|
||||||
|
@ -1106,6 +1109,8 @@ static void ArchiveSectors(void)
|
||||||
}
|
}
|
||||||
if (diff3 & SD_FLAG)
|
if (diff3 & SD_FLAG)
|
||||||
WRITEUINT32(save_p, ss->flags);
|
WRITEUINT32(save_p, ss->flags);
|
||||||
|
if (diff3 & SD_GRAVITY)
|
||||||
|
WRITEFIXED(save_p, ss->gravity);
|
||||||
if (diff & SD_FFLOORS)
|
if (diff & SD_FFLOORS)
|
||||||
ArchiveFFloors(ss);
|
ArchiveFFloors(ss);
|
||||||
}
|
}
|
||||||
|
@ -1209,7 +1214,8 @@ static void UnArchiveSectors(void)
|
||||||
}
|
}
|
||||||
if (diff3 & SD_FLAG)
|
if (diff3 & SD_FLAG)
|
||||||
sectors[i].flags = READUINT32(save_p);
|
sectors[i].flags = READUINT32(save_p);
|
||||||
|
if (diff3 & SD_GRAVITY)
|
||||||
|
sectors[i].gravity = READFIXED(save_p);
|
||||||
|
|
||||||
if (diff & SD_FFLOORS)
|
if (diff & SD_FFLOORS)
|
||||||
UnArchiveFFloors(§ors[i]);
|
UnArchiveFFloors(§ors[i]);
|
||||||
|
|
|
@ -999,7 +999,7 @@ static void P_InitializeSector(sector_t *ss)
|
||||||
|
|
||||||
ss->extra_colormap = NULL;
|
ss->extra_colormap = NULL;
|
||||||
|
|
||||||
ss->gravity = NULL;
|
ss->gravityptr = NULL;
|
||||||
ss->verticalflip = false;
|
ss->verticalflip = false;
|
||||||
|
|
||||||
ss->cullheight = NULL;
|
ss->cullheight = NULL;
|
||||||
|
@ -1047,6 +1047,8 @@ static void P_LoadSectors(UINT8 *data)
|
||||||
|
|
||||||
ss->colormap_protected = false;
|
ss->colormap_protected = false;
|
||||||
|
|
||||||
|
ss->gravity = FRACUNIT;
|
||||||
|
|
||||||
ss->flags = MSF_FLIPSPECIAL_FLOOR;
|
ss->flags = MSF_FLIPSPECIAL_FLOOR;
|
||||||
|
|
||||||
P_InitializeSector(ss);
|
P_InitializeSector(ss);
|
||||||
|
@ -1676,6 +1678,8 @@ static void ParseTextmapSectorParameter(UINT32 i, char *param, char *val)
|
||||||
sectors[i].flags |= MSF_HEATWAVE;
|
sectors[i].flags |= MSF_HEATWAVE;
|
||||||
else if (fastcmp(param, "friction"))
|
else if (fastcmp(param, "friction"))
|
||||||
sectors[i].friction = atol(val);
|
sectors[i].friction = atol(val);
|
||||||
|
else if (fastcmp(param, "gravity"))
|
||||||
|
sectors[i].gravity = FLOAT_TO_FIXED(atof(val));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ParseTextmapSidedefParameter(UINT32 i, char *param, char *val)
|
static void ParseTextmapSidedefParameter(UINT32 i, char *param, char *val)
|
||||||
|
@ -1952,6 +1956,8 @@ static void P_LoadTextmap(void)
|
||||||
|
|
||||||
sc->colormap_protected = false;
|
sc->colormap_protected = false;
|
||||||
|
|
||||||
|
sc->gravity = FRACUNIT;
|
||||||
|
|
||||||
sc->flags = MSF_FLIPSPECIAL_FLOOR;
|
sc->flags = MSF_FLIPSPECIAL_FLOOR;
|
||||||
|
|
||||||
textmap_colormap.used = false;
|
textmap_colormap.used = false;
|
||||||
|
|
10
src/p_spec.c
10
src/p_spec.c
|
@ -5958,6 +5958,14 @@ static boolean P_CheckGametypeRules(INT32 checktype, UINT32 target)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fixed_t P_GetSectorGravityFactor(sector_t *sec)
|
||||||
|
{
|
||||||
|
if (sec->gravityptr)
|
||||||
|
return FixedDiv(*sec->gravityptr >> FRACBITS, 1000);
|
||||||
|
else
|
||||||
|
return sec->gravity;
|
||||||
|
}
|
||||||
|
|
||||||
/** After the map has loaded, scans for specials that spawn 3Dfloors and
|
/** After the map has loaded, scans for specials that spawn 3Dfloors and
|
||||||
* thinkers.
|
* thinkers.
|
||||||
*
|
*
|
||||||
|
@ -6105,7 +6113,7 @@ void P_SpawnSpecials(boolean fromnetsave)
|
||||||
sec = sides[*lines[i].sidenum].sector - sectors;
|
sec = sides[*lines[i].sidenum].sector - sectors;
|
||||||
TAG_ITER_SECTORS(tag, s)
|
TAG_ITER_SECTORS(tag, s)
|
||||||
{
|
{
|
||||||
sectors[s].gravity = §ors[sec].floorheight; // This allows it to change in realtime!
|
sectors[s].gravityptr = §ors[sec].floorheight; // This allows it to change in realtime!
|
||||||
|
|
||||||
if (lines[i].flags & ML_NOCLIMB)
|
if (lines[i].flags & ML_NOCLIMB)
|
||||||
sectors[s].verticalflip = true;
|
sectors[s].verticalflip = true;
|
||||||
|
|
|
@ -467,6 +467,7 @@ void P_SetupLevelFlatAnims(void);
|
||||||
// at map load
|
// at map load
|
||||||
void P_InitSpecials(void);
|
void P_InitSpecials(void);
|
||||||
void P_ApplyFlatAlignment(sector_t* sector, angle_t flatangle, fixed_t xoffs, fixed_t yoffs, boolean floor, boolean ceiling);
|
void P_ApplyFlatAlignment(sector_t* sector, angle_t flatangle, fixed_t xoffs, fixed_t yoffs, boolean floor, boolean ceiling);
|
||||||
|
fixed_t P_GetSectorGravityFactor(sector_t *sec);
|
||||||
void P_SpawnSpecials(boolean fromnetsave);
|
void P_SpawnSpecials(boolean fromnetsave);
|
||||||
|
|
||||||
// every tic
|
// every tic
|
||||||
|
|
|
@ -366,8 +366,8 @@ typedef struct sector_s
|
||||||
extracolormap_t *extra_colormap;
|
extracolormap_t *extra_colormap;
|
||||||
boolean colormap_protected;
|
boolean colormap_protected;
|
||||||
|
|
||||||
// This points to the master's floorheight, so it can be changed in realtime!
|
fixed_t gravity; // per-sector gravity factor
|
||||||
fixed_t *gravity; // per-sector gravity
|
fixed_t *gravityptr; // For binary format: Read gravity from floor height of master sector
|
||||||
boolean verticalflip; // If gravity < 0, then allow flipped physics
|
boolean verticalflip; // If gravity < 0, then allow flipped physics
|
||||||
sectorflags_t flags;
|
sectorflags_t flags;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue