- added sprite collection loop to ProcessSector and did a bit of cleanup on the TSprite code.

This commit is contained in:
Christoph Oelckers 2021-03-25 23:16:32 +01:00
parent f6568fee0c
commit 0b1e81023f
8 changed files with 57 additions and 64 deletions

View file

@ -161,25 +161,33 @@ extern sectortype sectorbackup[MAXSECTORS];
extern walltype wallbackup[MAXWALLS]; extern walltype wallbackup[MAXWALLS];
static inline tspriteptr_t renderMakeTSpriteFromSprite(tspriteptr_t const tspr, uint16_t const spritenum) inline tspriteptr_t renderAddNewTSprite()
{ {
auto const spr = &sprite[spritenum]; auto tspr = &tsprite[spritesortcnt++];
*tspr = {};
*tspr = *spr;
tspr->clipdist = 0;
tspr->owner = spritenum;
return tspr; return tspr;
} }
static inline tspriteptr_t renderAddTSpriteFromSprite(uint16_t const spritenum) inline tspriteptr_t renderAddTSpriteFromSprite(uint16_t const spritenum)
{ {
return renderMakeTSpriteFromSprite(&tsprite[spritesortcnt++], spritenum); auto tspr = &tsprite[spritesortcnt++];
auto const spr = &sprite[spritenum];
*tspr = *spr;
tspr->clipdist = 0;
tspr->owner = spritenum;
return tspr;
}
// returns: 0=continue sprite collecting;
// 1=break out of sprite collecting;
inline int32_t renderAddTsprite(int16_t z, int16_t sectnum)
{
if (spritesortcnt >= MAXSPRITESONSCREEN) return 1;
renderAddTSpriteFromSprite(z);
return 0;
} }
EXTERN tspriteptr_t tspriteptr[MAXSPRITESONSCREEN + 1];
EXTERN int32_t xdim, ydim; EXTERN int32_t xdim, ydim;
EXTERN int32_t yxaspect, viewingrange; EXTERN int32_t yxaspect, viewingrange;
@ -192,8 +200,6 @@ EXTERN int32_t randomseed;
EXTERN uint8_t paletteloaded; EXTERN uint8_t paletteloaded;
EXTERN int32_t maxspritesonscreen;
enum { enum {
PALETTE_MAIN = 1<<0, PALETTE_MAIN = 1<<0,
PALETTE_SHADE = 1<<1, PALETTE_SHADE = 1<<1,

View file

@ -172,20 +172,6 @@ char inpreparemirror = 0;
// Internal Engine Functions // Internal Engine Functions
// //
// returns: 0=continue sprite collecting;
// 1=break out of sprite collecting;
int32_t renderAddTsprite(int16_t z, int16_t sectnum)
{
auto const spr = (uspriteptr_t)&sprite[z];
if (spritesortcnt >= maxspritesonscreen)
return 1;
renderAddTSpriteFromSprite(z);
return 0;
}
// //
// animateoffs (internal) // animateoffs (internal)
@ -703,8 +689,6 @@ int32_t engineInit(void)
g_visibility = 512; g_visibility = 512;
parallaxvisibility = 512; parallaxvisibility = 512;
maxspritesonscreen = MAXSPRITESONSCREEN;
GPalette.Init(MAXPALOOKUPS + 1); // one slot for each translation, plus a separate one for the base palettes. GPalette.Init(MAXPALOOKUPS + 1); // one slot for each translation, plus a separate one for the base palettes.
gi->loadPalette(); gi->loadPalette();

View file

@ -14,7 +14,6 @@
#define ENGINE_PRIV_H #define ENGINE_PRIV_H
extern int32_t globalpal, globalfloorpal; extern int32_t globalpal, globalfloorpal;
extern tspriteptr_t tspriteptr[MAXSPRITESONSCREEN + 1];
extern int32_t xdimen, xdimenscale, xdimscale, ydimen; extern int32_t xdimen, xdimenscale, xdimscale, ydimen;
extern float fxdimen; extern float fxdimen;
extern int32_t globalposx, globalposy, globalposz; extern int32_t globalposx, globalposy, globalposz;

View file

@ -61,6 +61,7 @@ static int16_t bunchfirst[MAXWALLSB], bunchlast[MAXWALLSB];
static int16_t numscans, numbunches; static int16_t numscans, numbunches;
static int16_t maskwall[MAXWALLSB], maskwallcnt; static int16_t maskwall[MAXWALLSB], maskwallcnt;
static int16_t sectorborder[256]; static int16_t sectorborder[256];
static tspriteptr_t tspriteptr[MAXSPRITESONSCREEN + 1];

View file

@ -53,8 +53,13 @@ void BunchDrawer::Init(HWDrawInfo *_di, Clipper* c, vec2_t& view)
clipper = c; clipper = c;
viewx = view.x * (1/ 16.f); viewx = view.x * (1/ 16.f);
viewy = view.y * -(1/ 16.f); viewy = view.y * -(1/ 16.f);
iview = view;
StartScene(); StartScene();
clipper->SetViewpoint(view); clipper->SetViewpoint(view);
gcosang = bamang(di->Viewpoint.RotAngle).fcos();
gsinang = bamang(di->Viewpoint.RotAngle).fsin();
for (int i = 0; i < numwalls; i++) for (int i = 0; i < numwalls; i++)
{ {
// Precalculate the clip angles to avoid doing this repeatedly during level traversal. // Precalculate the clip angles to avoid doing this repeatedly during level traversal.
@ -419,16 +424,40 @@ void BunchDrawer::ProcessSector(int sectnum)
if (gotsector[sectnum]) return; if (gotsector[sectnum]) return;
gotsector.Set(sectnum); gotsector.Set(sectnum);
Bsp.Clock();
auto sect = &sector[sectnum]; auto sect = &sector[sectnum];
bool inbunch; bool inbunch;
binangle startangle; binangle startangle;
SetupSprite.Clock();
int z;
SectIterator it(sectnum);
while ((z = it.NextIndex()) >= 0)
{
auto const spr = (uspriteptr_t)&sprite[z];
if ((spr->cstat & CSTAT_SPRITE_INVISIBLE) || spr->xrepeat == 0 || spr->yrepeat == 0) // skip invisible sprites
continue;
int sx = spr->x - iview.x, sy = spr->y - int(iview.y);
if ((spr->cstat & CSTAT_SPRITE_ALIGNMENT_MASK) || (hw_models && tile2model[spr->picnum].modelid >= 0) || ((sx * gcosang) + (sy * gsinang) > 0)) // is it behind the camera? (fixme!)
{
if ((spr->cstat & (CSTAT_SPRITE_ONE_SIDED | CSTAT_SPRITE_ALIGNMENT_MASK)) != (CSTAT_SPRITE_ONE_SIDED | CSTAT_SPRITE_ALIGNMENT_WALL + 16) ||
(r_voxels && tiletovox[spr->picnum] >= 0 && voxmodels[tiletovox[spr->picnum]]) ||
DMulScale(bcos(spr->ang), -sx, bsin(spr->ang), -sy, 6) > 0)
if (renderAddTsprite(z, sectnum))
break;
}
}
SetupSprite.Unclock();
SetupFlat.Clock(); SetupFlat.Clock();
HWFlat flat; HWFlat flat;
flat.ProcessSector(di, &sector[sectnum]); flat.ProcessSector(di, &sector[sectnum]);
SetupFlat.Unclock(); SetupFlat.Unclock();
Bsp.Clock();
//Todo: process subsectors //Todo: process subsectors
inbunch = false; inbunch = false;

View file

@ -24,6 +24,8 @@ class BunchDrawer
TArray<FBunch> Bunches; TArray<FBunch> Bunches;
TArray<int> CompareData; TArray<int> CompareData;
double viewx, viewy; double viewx, viewy;
vec2_t iview;
float gcosang, gsinang;
FixedBitArray<MAXSECTORS> gotsector; FixedBitArray<MAXSECTORS> gotsector;
private: private:

View file

@ -126,7 +126,7 @@ static tspritetype *viewAddEffect(int nTSprite, VIEW_EFFECT nViewEffect)
{ {
assert(nViewEffect >= 0 && nViewEffect < kViewEffectMax); assert(nViewEffect >= 0 && nViewEffect < kViewEffectMax);
auto pTSprite = &tsprite[nTSprite]; auto pTSprite = &tsprite[nTSprite];
if (gDetail < effectDetail[nViewEffect] || nTSprite >= maxspritesonscreen) return NULL; if (gDetail < effectDetail[nViewEffect] || nTSprite >= MAXSPRITESONSCREEN) return NULL;
switch (nViewEffect) switch (nViewEffect)
{ {
case VIEW_EFFECT_18: case VIEW_EFFECT_18:
@ -220,7 +220,7 @@ static tspritetype *viewAddEffect(int nTSprite, VIEW_EFFECT nViewEffect)
{ {
nAng = (nAng+1024)&2047; nAng = (nAng+1024)&2047;
} }
for (int i = 0; i < 5 && spritesortcnt < maxspritesonscreen; i++) for (int i = 0; i < 5 && spritesortcnt < MAXSPRITESONSCREEN; i++)
{ {
int nSector = pTSprite->sectnum; int nSector = pTSprite->sectnum;
auto pNSprite = viewInsertTSprite<tspritetype>(nSector, 32767, NULL); auto pNSprite = viewInsertTSprite<tspritetype>(nSector, 32767, NULL);
@ -433,7 +433,7 @@ void viewProcessSprites(int32_t cX, int32_t cY, int32_t cZ, int32_t cA, int32_t
{ {
// shift before interpolating to increase precision. // shift before interpolating to increase precision.
int myclock = (PlayClock<<3) + MulScale(4<<3, smoothratio, 16); int myclock = (PlayClock<<3) + MulScale(4<<3, smoothratio, 16);
assert(spritesortcnt <= maxspritesonscreen); assert(spritesortcnt <= MAXSPRITESONSCREEN);
gCameraAng = cA; gCameraAng = cA;
int nViewSprites = spritesortcnt; int nViewSprites = spritesortcnt;
for (int nTSprite = spritesortcnt-1; nTSprite >= 0; nTSprite--) for (int nTSprite = spritesortcnt-1; nTSprite >= 0; nTSprite--)
@ -633,7 +633,7 @@ void viewProcessSprites(int32_t cX, int32_t cY, int32_t cZ, int32_t cA, int32_t
pTSprite->xrepeat = pTSprite->yrepeat = 0; pTSprite->xrepeat = pTSprite->yrepeat = 0;
} }
} }
if (spritesortcnt >= maxspritesonscreen) continue; if (spritesortcnt >= MAXSPRITESONSCREEN) continue;
if (pTXSprite && pTXSprite->burnTime > 0) if (pTXSprite && pTXSprite->burnTime > 0)
{ {
pTSprite->shade = ClipRange(pTSprite->shade-16-QRandom(8), -128, 127); pTSprite->shade = ClipRange(pTSprite->shade-16-QRandom(8), -128, 127);

View file

@ -1094,34 +1094,6 @@ void PrintSpriteInfo(PLAYERp pp)
} }
void SpriteSortList2D(int tx, int ty)
{
SPRITEp sp;
int i;
int dist,a,b,c;
spritesortcnt = 0;
for (i = 0; i < MAXSPRITES; i++)
{
if (sprite[i].statnum < MAXSTATUS)
{
sp = &sprite[i];
if (!TEST(sp->cstat, CSTAT_SPRITE_INVISIBLE) &&
(sp->xrepeat > 0) && (sp->yrepeat > 0) &&
(spritesortcnt < MAXSPRITESONSCREEN))
{
DISTANCE(tx,ty,sp->x,sp->y,dist,a,b,c);
if (dist < 22000)
{
renderAddTSpriteFromSprite(i);
}
}
}
}
}
void DrawCrosshair(PLAYERp pp) void DrawCrosshair(PLAYERp pp)
{ {
extern bool CameraTestMode; extern bool CameraTestMode;