diff --git a/polymer/eduke32/source/actors.h b/polymer/eduke32/source/actors.h index 0363907f1..874101fa5 100644 --- a/polymer/eduke32/source/actors.h +++ b/polymer/eduke32/source/actors.h @@ -149,6 +149,7 @@ enum sflags_t { SPRITE_USEACTIVATOR = 0x00000200, SPRITE_NULL = 0x00000400, // null sprite in multiplayer SPRITE_NOCLIP = 0x00000800, // clipmove it with cliptype 0 + SPRITE_NOFLOORSHADOW= 0x00001000, // for temp. internal use, per-tile flag not checked }; // custom projectiles diff --git a/polymer/eduke32/source/game.c b/polymer/eduke32/source/game.c index e9ffadfa3..a3c30d5ff 100644 --- a/polymer/eduke32/source/game.c +++ b/polymer/eduke32/source/game.c @@ -6513,10 +6513,17 @@ skip: { if (actor[i].dispicnum < 0) { + // a negative actor[i].dispicnum used to mean 'no floor shadow please' but + // that was a bad hack since the value could propagate to sprite[].picnum + OSD_Printf(OSD_ERROR "actor[%d].dispicnum = %d\n", i, actor[i].dispicnum); actor[i].dispicnum++; continue; } - else if (ud.shadows && spritesortcnt < (MAXSPRITESONSCREEN-2) && getrendermode() != 4) + + if (actor[i].flags & SPRITE_NOFLOORSHADOW) + continue; + + if (ud.shadows && spritesortcnt < (MAXSPRITESONSCREEN-2) && getrendermode() != 4) { int32_t daz,xrep,yrep; diff --git a/polymer/eduke32/source/gameexec.c b/polymer/eduke32/source/gameexec.c index 2458c3c95..83a18aed2 100644 --- a/polymer/eduke32/source/gameexec.c +++ b/polymer/eduke32/source/gameexec.c @@ -302,6 +302,8 @@ void A_GetZLimits(int32_t iActor) s->cstat = cstat; + actor[iActor].flags &= ~SPRITE_NOFLOORSHADOW; + if ((lz&49152) == 49152 && (sprite[lz&(MAXSPRITES-1)].cstat&48) == 0) { const spritetype *hitspr = &sprite[lz&(MAXSPRITES-1)]; @@ -311,7 +313,8 @@ void A_GetZLimits(int32_t iActor) if ((A_CheckEnemySprite(hitspr) && hitspr->pal != 1 && s->statnum != STAT_PROJECTILE) || (hitspr->picnum == APLAYER && A_CheckEnemySprite(s))) { - actor[iActor].dispicnum = -4; // No shadows on actors + actor[iActor].flags |= SPRITE_NOFLOORSHADOW; // No shadows on actors +// actor[iActor].dispicnum = -4; // No shadows on actors s->xvel = -256; A_SetSprite(iActor,CLIPMASK0); }