- fixed floorclipping checks for 3D floors.

Neither the setup nor the in-game checks were correct, because this code comes from a time where ceilings could not have a terrain, meaning that 3D floors couldn't have one.
This commit is contained in:
Christoph Oelckers 2020-06-03 11:17:19 +02:00 committed by drfrag
parent b43d87c4cd
commit 55390b2403

View file

@ -4892,9 +4892,6 @@ void AActor::AdjustFloorClip ()
double shallowestclip = INT_MAX; double shallowestclip = INT_MAX;
const msecnode_t *m; const msecnode_t *m;
// possibly standing on a 3D-floor
if (Sector->e->XFloor.ffloors.Size() && Z() > Sector->floorplane.ZatPoint(this)) Floorclip = 0;
// [RH] clip based on shallowest floor player is standing on // [RH] clip based on shallowest floor player is standing on
// If the sector has a deep water effect, then let that effect // If the sector has a deep water effect, then let that effect
// do the floorclipping instead of the terrain type. // do the floorclipping instead of the terrain type.
@ -4902,7 +4899,9 @@ void AActor::AdjustFloorClip ()
{ {
DVector3 pos = PosRelative(m->m_sector); DVector3 pos = PosRelative(m->m_sector);
sector_t* hsec = m->m_sector->GetHeightSec(); sector_t* hsec = m->m_sector->GetHeightSec();
if (hsec == NULL && m->m_sector->floorplane.ZatPoint (pos) == Z()) if (hsec == NULL)
{
if (m->m_sector->floorplane.ZatPoint(pos) == Z())
{ {
double clip = Terrains[m->m_sector->GetTerrain(sector_t::floor)].FootClip; double clip = Terrains[m->m_sector->GetTerrain(sector_t::floor)].FootClip;
if (clip < shallowestclip) if (clip < shallowestclip)
@ -4910,6 +4909,22 @@ void AActor::AdjustFloorClip ()
shallowestclip = clip; shallowestclip = clip;
} }
} }
else
{
for (auto& ff : m->m_sector->e->XFloor.ffloors)
{
if ((ff->flags & FF_SOLID) && (ff->flags & FF_EXISTS) && ff->top.plane->ZatPoint(pos) == Z())
{
double clip = Terrains[ff->top.model->GetTerrain(ff->top.isceiling)].FootClip;
if (clip < shallowestclip)
{
shallowestclip = clip;
}
}
}
}
}
} }
if (shallowestclip == INT_MAX) if (shallowestclip == INT_MAX)
{ {
@ -5503,6 +5518,11 @@ AActor *P_SpawnMapThing (FMapThing *mthing, int position)
else if (sz == ONCEILINGZ) else if (sz == ONCEILINGZ)
mobj->AddZ(-mthing->pos.Z); mobj->AddZ(-mthing->pos.Z);
if (mobj->flags2 & MF2_FLOORCLIP)
{
mobj->AdjustFloorClip();
}
mobj->SpawnPoint = mthing->pos; mobj->SpawnPoint = mthing->pos;
mobj->SpawnAngle = mthing->angle; mobj->SpawnAngle = mthing->angle;
mobj->SpawnFlags = mthing->flags; mobj->SpawnFlags = mthing->flags;