From 5837c79b16e22983b5f69efc802c990ed9111a70 Mon Sep 17 00:00:00 2001 From: tmyqlfpir <80724828+tmyqlfpir@users.noreply.github.com> Date: Mon, 25 Sep 2023 00:31:56 +1000 Subject: [PATCH] Allow tileGetSurfType() to return ceiling type if supplied nType bitflag --- source/blood/src/actor.cpp | 2 +- source/blood/src/nnexts.cpp | 2 +- source/blood/src/seq.cpp | 2 +- source/blood/src/tile.cpp | 7 +++++-- source/blood/src/tile.h | 2 +- 5 files changed, 9 insertions(+), 6 deletions(-) diff --git a/source/blood/src/actor.cpp b/source/blood/src/actor.cpp index 2b917f051b..8800443224 100644 --- a/source/blood/src/actor.cpp +++ b/source/blood/src/actor.cpp @@ -3922,7 +3922,7 @@ void actTouchFloor(spritetype *pSprite, int nSector) nDamage = 1000; actDamageSprite(pSprite->index, pSprite, nDamageType, scale(4, nDamage, 120) << 4); } - if (tileGetSurfType(nSector + 0x4000) == kSurfLava) + if (tileGetSurfType(nSector, 0x4000) == kSurfLava) { actDamageSprite(pSprite->index, pSprite, kDamageBurn, 16); sfxPlay3DSound(pSprite, 352, 5, 2); diff --git a/source/blood/src/nnexts.cpp b/source/blood/src/nnexts.cpp index 16bd984652..3f15a32e72 100644 --- a/source/blood/src/nnexts.cpp +++ b/source/blood/src/nnexts.cpp @@ -1609,7 +1609,7 @@ int getSpriteMassBySize(spritetype* pSprite) { short xrepeat = pSprite->xrepeat; short yrepeat = pSprite->yrepeat; // take surface type into account - switch (tileGetSurfType(pSprite->index + 0xc000)) { + switch (tileGetSurfType(pSprite->index, 0xc000)) { case 1: massDiv = 16; break; // stone case 2: massDiv = 18; break; // metal case 3: massDiv = 21; break; // wood diff --git a/source/blood/src/seq.cpp b/source/blood/src/seq.cpp index 5061d291f0..a866a025c6 100644 --- a/source/blood/src/seq.cpp +++ b/source/blood/src/seq.cpp @@ -301,7 +301,7 @@ void SEQINST::Update(ACTIVE *pActive) if (!VanillaMode() && pSequence->frames[frameIndex].surfaceSound && zvel[pSprite->index] == 0 && xvel[pSprite->index] != 0) { if (gUpperLink[pSprite->sectnum] >= 0) break; // don't play surface sound for stacked sectors - int surf = tileGetSurfType(pSprite->sectnum + 0x4000); if (!surf) break; + int surf = tileGetSurfType(pSprite->sectnum, 0x4000); if (!surf) break; static int surfSfxMove[15][4] = { /* {snd1, snd2, gameVolume, myVolume} */ {800,801,80,25}, diff --git a/source/blood/src/tile.cpp b/source/blood/src/tile.cpp index cefb98d289..6bb4b853a8 100644 --- a/source/blood/src/tile.cpp +++ b/source/blood/src/tile.cpp @@ -268,10 +268,13 @@ void tilePrecacheTile(int nTile, int nType) } } -char tileGetSurfType(int hit) +char tileGetSurfType(int hit, int nType) { int n = hit & 0x3fff; - switch (hit&0xc000) + if (nType == 0) // no type supplied, get type from hit index + nType = hit & 0xc000; + + switch (nType) { case 0x4000: return surfType[sector[n].floorpicnum]; diff --git a/source/blood/src/tile.h b/source/blood/src/tile.h index 2f21c3a1bc..6760d1d030 100644 --- a/source/blood/src/tile.h +++ b/source/blood/src/tile.h @@ -63,4 +63,4 @@ char * tileLoadTile(int nTile); char * tileAllocTile(int nTile, int x, int y, int ox, int oy); void tilePreloadTile(int nTile); void tilePrecacheTile(int nTile, int nType = 1); -char tileGetSurfType(int hit); +char tileGetSurfType(int hit, int nType = 0);