mirror of
https://github.com/DrBeef/Raze.git
synced 2025-01-18 15:11:51 +00:00
High-level TROR drawing: clean up how things are passed around.
git-svn-id: https://svn.eduke32.com/eduke32@2880 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
8eafee0636
commit
2b2be071d4
8 changed files with 27 additions and 33 deletions
|
@ -132,12 +132,13 @@ static inline int32_t yax_waltosecmask(int32_t walclipmask)
|
|||
return ((walclipmask&1)<<9) | ((walclipmask&64)<<5);
|
||||
}
|
||||
void yax_preparedrawrooms(void);
|
||||
void yax_drawrooms(void (*ExtAnalyzeSprites)(void), int32_t horiz, int16_t sectnum, int32_t didmirror);
|
||||
void yax_drawrooms(void (*SpriteAnimFunc)(int32_t,int32_t,int32_t,int32_t),
|
||||
int16_t sectnum, int32_t didmirror, int32_t smoothr);
|
||||
# define YAX_SKIPSECTOR(i) if (graysectbitmap[(i)>>3]&(1<<((i)&7))) continue
|
||||
# define YAX_SKIPWALL(i) if (graywallbitmap[(i)>>3]&(1<<((i)&7))) continue
|
||||
#else
|
||||
# define yax_preparedrawrooms()
|
||||
# define yax_drawrooms(ExtAnalyzeSprites, horiz, sectnum, didmirror)
|
||||
# define yax_drawrooms(SpriteAnimFunc, sectnum, didmirror, smoothr)
|
||||
# define YAX_SKIPSECTOR(i) (i)=(i)
|
||||
# define YAX_SKIPWALL(i) (i)=(i)
|
||||
#endif
|
||||
|
|
|
@ -158,7 +158,7 @@ extern int32_t ExtInit(void);
|
|||
extern int32_t ExtPreInit(int32_t argc,const char **argv);
|
||||
extern void ExtUnInit(void);
|
||||
extern void ExtPreCheckKeys(void);
|
||||
extern void ExtAnalyzeSprites(void);
|
||||
extern void ExtAnalyzeSprites(int32_t, int32_t, int32_t, int32_t);
|
||||
extern void ExtCheckKeys(void);
|
||||
extern void ExtPreLoadMap(void);
|
||||
extern void ExtSetupMapFilename(const char *mapname);
|
||||
|
|
|
@ -467,9 +467,9 @@ void M32_DrawRoomsAndMasks(void)
|
|||
{
|
||||
yax_preparedrawrooms();
|
||||
drawrooms(pos.x,pos.y,pos.z,ang,horiz,cursectnum);
|
||||
yax_drawrooms(ExtAnalyzeSprites, horiz, cursectnum, 0);
|
||||
yax_drawrooms(ExtAnalyzeSprites, cursectnum, 0, 0);
|
||||
|
||||
ExtAnalyzeSprites();
|
||||
ExtAnalyzeSprites(0,0,0,0);
|
||||
drawmasks();
|
||||
M32_ResetFakeRORTiles();
|
||||
|
||||
|
@ -478,7 +478,7 @@ void M32_DrawRoomsAndMasks(void)
|
|||
{
|
||||
polymer_editorpick();
|
||||
drawrooms(pos.x,pos.y,pos.z,ang,horiz,cursectnum);
|
||||
ExtAnalyzeSprites();
|
||||
ExtAnalyzeSprites(0,0,0,0);
|
||||
drawmasks();
|
||||
M32_ResetFakeRORTiles();
|
||||
}
|
||||
|
|
|
@ -204,6 +204,7 @@ static void scansector(int16_t sectnum);
|
|||
static void draw_rainbow_background(void);
|
||||
|
||||
int16_t editstatus = 0;
|
||||
static int32_t global100horiz; // (-100..300)-scale horiz (the one passed to drawrooms)
|
||||
|
||||
|
||||
////////// YAX //////////
|
||||
|
@ -838,10 +839,13 @@ void yax_preparedrawrooms(void)
|
|||
}
|
||||
}
|
||||
|
||||
void yax_drawrooms(void (*ExtAnalyzeSprites)(void), int32_t horiz, int16_t sectnum, int32_t didmirror)
|
||||
void yax_drawrooms(void (*SpriteAnimFunc)(int32_t,int32_t,int32_t,int32_t),
|
||||
int16_t sectnum, int32_t didmirror, int32_t smoothr)
|
||||
{
|
||||
static uint8_t havebunch[YAX_MAXBUNCHES>>3];
|
||||
|
||||
const int32_t horiz = global100horiz;
|
||||
|
||||
int32_t i, j, k, lev, cf, nmp;
|
||||
int32_t bnchcnt, bnchnum[2] = {0,0}, maxlev[2];
|
||||
int16_t ourbunch[2] = {-1,-1}, osectnum=sectnum;
|
||||
|
@ -1052,7 +1056,7 @@ void yax_drawrooms(void (*ExtAnalyzeSprites)(void), int32_t horiz, int16_t sectn
|
|||
yax_globallev-YAX_MAXDRAWS, j, k, spritesortcnt,
|
||||
(double)(1000*(gethiticks()-t))/hitickspersec);
|
||||
|
||||
ExtAnalyzeSprites();
|
||||
SpriteAnimFunc(globalposx, globalposy, globalang, smoothr);
|
||||
drawmasks();
|
||||
}
|
||||
|
||||
|
@ -8259,6 +8263,8 @@ int32_t drawrooms(int32_t daposx, int32_t daposy, int32_t daposz,
|
|||
globalposx = daposx; globalposy = daposy; globalposz = daposz;
|
||||
globalang = (daang&2047);
|
||||
|
||||
global100horiz = dahoriz;
|
||||
|
||||
// xdimenscale is scale(xdimen,yxaspect,320);
|
||||
// normalization by viewingrange so that center-of-aim doesn't depend on it
|
||||
globalhoriz = mulscale16(dahoriz-100,divscale16(xdimenscale,viewingrange))+(ydimen>>1);
|
||||
|
|
|
@ -2808,7 +2808,7 @@ static void ExtSE40Draw(int32_t spnum,int32_t x,int32_t y,int32_t z,int16_t a,in
|
|||
}
|
||||
|
||||
drawrooms(x+offx,y+offy,z+offz,a,h,sprite[floor2].sectnum);
|
||||
ExtAnalyzeSprites();
|
||||
ExtAnalyzeSprites(0,0,0,0);
|
||||
drawmasks();
|
||||
M32_ResetFakeRORTiles();
|
||||
|
||||
|
@ -2834,7 +2834,7 @@ static void ExtSE40Draw(int32_t spnum,int32_t x,int32_t y,int32_t z,int16_t a,in
|
|||
|
||||
// Now re-draw
|
||||
drawrooms(x+offx,y+offy,z+offz,a,h,sprite[floor2].sectnum);
|
||||
ExtAnalyzeSprites();
|
||||
ExtAnalyzeSprites(0,0,0,0);
|
||||
drawmasks();
|
||||
M32_ResetFakeRORTiles();
|
||||
}
|
||||
|
@ -10874,12 +10874,17 @@ void ExtPreCheckKeys(void) // just before drawrooms
|
|||
enddrawing(); //}}}
|
||||
}
|
||||
|
||||
void ExtAnalyzeSprites(void)
|
||||
void ExtAnalyzeSprites(int32_t ourx, int32_t oury, int32_t oura, int32_t smoothr)
|
||||
{
|
||||
int32_t i, k;
|
||||
spritetype *tspr;
|
||||
int32_t frames=0, sh;
|
||||
|
||||
UNREFERENCED_PARAMETER(ourx);
|
||||
UNREFERENCED_PARAMETER(oury);
|
||||
UNREFERENCED_PARAMETER(oura);
|
||||
UNREFERENCED_PARAMETER(smoothr);
|
||||
|
||||
for (i=0,tspr=&tsprite[0]; i<spritesortcnt; i++,tspr++)
|
||||
{
|
||||
frames=0;
|
||||
|
|
|
@ -3324,14 +3324,6 @@ static void G_SE40(int32_t smoothratio)
|
|||
}
|
||||
}
|
||||
|
||||
int32_t g_yax_smoothratio;
|
||||
#ifdef YAX_ENABLE
|
||||
void G_AnalyzeSprites(void)
|
||||
{
|
||||
G_DoSpriteAnimations(ud.camera.x,ud.camera.y,ud.cameraang,g_yax_smoothratio);
|
||||
}
|
||||
#endif
|
||||
|
||||
void G_HandleMirror(int32_t x, int32_t y, int32_t z, int32_t a, int32_t horiz, int32_t smoothratio)
|
||||
{
|
||||
if ((gotpic[MIRROR>>3]&(1<<(MIRROR&7)))
|
||||
|
@ -3393,8 +3385,7 @@ void G_HandleMirror(int32_t x, int32_t y, int32_t z, int32_t a, int32_t horiz, i
|
|||
|
||||
yax_preparedrawrooms();
|
||||
didmirror = drawrooms(tposx,tposy,z,tang,horiz,g_mirrorSector[i]+MAXSECTORS);
|
||||
g_yax_smoothratio = smoothratio;
|
||||
yax_drawrooms(G_AnalyzeSprites, horiz, g_mirrorSector[i], didmirror);
|
||||
yax_drawrooms(G_DoSpriteAnimations, g_mirrorSector[i], didmirror, smoothratio);
|
||||
}
|
||||
#ifdef USE_OPENGL
|
||||
else
|
||||
|
@ -3470,8 +3461,7 @@ void G_DrawRooms(int32_t snum, int32_t smoothratio)
|
|||
#endif
|
||||
yax_preparedrawrooms();
|
||||
drawrooms(s->x,s->y,s->z-(4<<8),ud.cameraang,s->yvel,s->sectnum);
|
||||
g_yax_smoothratio = smoothratio;
|
||||
yax_drawrooms(G_AnalyzeSprites, s->yvel, s->sectnum, 0);
|
||||
yax_drawrooms(G_DoSpriteAnimations, s->sectnum, 0, smoothratio);
|
||||
G_DoSpriteAnimations(s->x,s->y,ud.cameraang,smoothratio);
|
||||
drawmasks();
|
||||
}
|
||||
|
@ -3684,9 +3674,7 @@ void G_DrawRooms(int32_t snum, int32_t smoothratio)
|
|||
|
||||
yax_preparedrawrooms();
|
||||
drawrooms(ud.camera.x,ud.camera.y,ud.camera.z,ud.cameraang,ud.camerahoriz,ud.camerasect);
|
||||
g_yax_smoothratio = smoothratio;
|
||||
yax_drawrooms(G_AnalyzeSprites, ud.camerahoriz, ud.camerasect, 0);
|
||||
|
||||
yax_drawrooms(G_DoSpriteAnimations, ud.camerasect, 0, smoothratio);
|
||||
|
||||
// dupe the sprites touching the portal to the other sector
|
||||
|
||||
|
|
|
@ -242,8 +242,6 @@ extern int8_t g_noFloorPal[MAXPALOOKUPS];
|
|||
|
||||
extern user_defs ud;
|
||||
|
||||
//extern int32_t g_yax_smoothratio;
|
||||
|
||||
int32_t A_CheckInventorySprite(spritetype *s);
|
||||
int32_t A_InsertSprite(int32_t whatsect,int32_t s_x,int32_t s_y,int32_t s_z,int32_t s_pn,int32_t s_s,int32_t s_xr,int32_t s_yr,int32_t s_a,int32_t s_ve,int32_t s_zv,int32_t s_ow,int32_t s_ss);
|
||||
int32_t A_Spawn(int32_t j,int32_t pn);
|
||||
|
@ -290,9 +288,6 @@ void G_HandleLocalKeys(void);
|
|||
void G_HandleSpecialKeys(void);
|
||||
void G_PrintGameQuotes(void);
|
||||
//void G_SE40(int32_t smoothratio);
|
||||
#ifdef YAX_ENABLE
|
||||
void G_AnalyzeSprites(void);
|
||||
#endif
|
||||
void G_SetCrosshairColor(int32_t r,int32_t g,int32_t b);
|
||||
void G_SetStatusBarScale(int32_t sc);
|
||||
void G_Shutdown(void);
|
||||
|
|
|
@ -572,8 +572,7 @@ void G_SetupCamTile(int32_t i,int32_t wn)
|
|||
|
||||
yax_preparedrawrooms();
|
||||
drawrooms(SX,SY,SZ,SA,100+sprite[i].shade,SECT);
|
||||
// g_yax_smoothratio?
|
||||
yax_drawrooms(G_AnalyzeSprites, 100+sprite[i].shade, SECT, 0);
|
||||
yax_drawrooms(G_DoSpriteAnimations, SECT, 0, 65536);
|
||||
|
||||
display_mirror = 1;
|
||||
G_DoSpriteAnimations(SX,SY,SA,65536L);
|
||||
|
|
Loading…
Reference in a new issue