mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-23 15:40:39 +00:00
Vectorize a few more things.
git-svn-id: https://svn.eduke32.com/eduke32@5800 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
29a9b93517
commit
03daded192
15 changed files with 291 additions and 320 deletions
|
@ -616,7 +616,7 @@ FORCE_INLINE void sector_tracker_hook(uintptr_t address)
|
||||||
Bassert(usector < ((MAXSECTORS + M32_FIXME_SECTORS) * sizeof(sectortype)));
|
Bassert(usector < ((MAXSECTORS + M32_FIXME_SECTORS) * sizeof(sectortype)));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
sectorchanged[usector / sizeof(sectortype)]++;
|
++sectorchanged[usector / sizeof(sectortype)];
|
||||||
}
|
}
|
||||||
|
|
||||||
FORCE_INLINE void wall_tracker_hook(uintptr_t address)
|
FORCE_INLINE void wall_tracker_hook(uintptr_t address)
|
||||||
|
@ -627,7 +627,7 @@ FORCE_INLINE void wall_tracker_hook(uintptr_t address)
|
||||||
Bassert(uwall < ((MAXWALLS + M32_FIXME_WALLS) * sizeof(walltype)));
|
Bassert(uwall < ((MAXWALLS + M32_FIXME_WALLS) * sizeof(walltype)));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
wallchanged[uwall / sizeof(walltype)]++;
|
++wallchanged[uwall / sizeof(walltype)];
|
||||||
}
|
}
|
||||||
|
|
||||||
FORCE_INLINE void sprite_tracker_hook(uintptr_t address)
|
FORCE_INLINE void sprite_tracker_hook(uintptr_t address)
|
||||||
|
@ -638,7 +638,7 @@ FORCE_INLINE void sprite_tracker_hook(uintptr_t address)
|
||||||
Bassert(usprite < (MAXSPRITES * sizeof(spritetype)));
|
Bassert(usprite < (MAXSPRITES * sizeof(spritetype)));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
spritechanged[usprite / sizeof(spritetype)]++;
|
++spritechanged[usprite / sizeof(spritetype)];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -712,7 +712,7 @@ EXTERN int32_t g_rotatespriteNoWidescreen;
|
||||||
// alpha-blending tables:
|
// alpha-blending tables:
|
||||||
EXTERN uint8_t numalphatabs;
|
EXTERN uint8_t numalphatabs;
|
||||||
|
|
||||||
EXTERN int32_t windowx1, windowy1, windowx2, windowy2;
|
EXTERN vec2_t windowxy1, windowxy2;
|
||||||
EXTERN int16_t *startumost, *startdmost;
|
EXTERN int16_t *startumost, *startdmost;
|
||||||
|
|
||||||
// The maximum tile offset ever used in any tiled parallaxed multi-sky.
|
// The maximum tile offset ever used in any tiled parallaxed multi-sky.
|
||||||
|
@ -1098,7 +1098,7 @@ FORCE_INLINE void rotatesprite_fs_alpha(int32_t sx, int32_t sy, int32_t z, int16
|
||||||
FORCE_INLINE void rotatesprite_win(int32_t sx, int32_t sy, int32_t z, int16_t a, int16_t picnum,
|
FORCE_INLINE void rotatesprite_win(int32_t sx, int32_t sy, int32_t z, int16_t a, int16_t picnum,
|
||||||
int8_t dashade, char dapalnum, int32_t dastat)
|
int8_t dashade, char dapalnum, int32_t dastat)
|
||||||
{
|
{
|
||||||
rotatesprite_(sx, sy, z, a, picnum, dashade, dapalnum, dastat, 0, 0, windowx1,windowy1,windowx2,windowy2);
|
rotatesprite_(sx, sy, z, a, picnum, dashade, dapalnum, dastat, 0, 0, windowxy1.x,windowxy1.y,windowxy2.x,windowxy2.y);
|
||||||
}
|
}
|
||||||
|
|
||||||
void bfirst_search_init(int16_t *list, uint8_t *bitmap, int32_t *eltnumptr, int32_t maxnum, int16_t firstelt);
|
void bfirst_search_init(int16_t *list, uint8_t *bitmap, int32_t *eltnumptr, int32_t maxnum, int16_t firstelt);
|
||||||
|
@ -1188,7 +1188,7 @@ FORCE_INLINE int32_t E_SpriteIsValid(const int32_t i)
|
||||||
return ((unsigned)i < MAXSPRITES && sprite[i].statnum != MAXSTATUS);
|
return ((unsigned)i < MAXSPRITES && sprite[i].statnum != MAXSTATUS);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t clipshape_idx_for_sprite(spritetype *curspr, int32_t curidx);
|
int32_t clipshape_idx_for_sprite(uspritetype const * const curspr, int32_t curidx);
|
||||||
|
|
||||||
void alignceilslope(int16_t dasect, int32_t x, int32_t y, int32_t z);
|
void alignceilslope(int16_t dasect, int32_t x, int32_t y, int32_t z);
|
||||||
void alignflorslope(int16_t dasect, int32_t x, int32_t y, int32_t z);
|
void alignflorslope(int16_t dasect, int32_t x, int32_t y, int32_t z);
|
||||||
|
@ -1216,10 +1216,10 @@ int32_t changespritestat(int16_t spritenum, int16_t newstatnum);
|
||||||
int32_t setsprite(int16_t spritenum, const vec3_t *) ATTRIBUTE((nonnull(2)));
|
int32_t setsprite(int16_t spritenum, const vec3_t *) ATTRIBUTE((nonnull(2)));
|
||||||
int32_t setspritez(int16_t spritenum, const vec3_t *) ATTRIBUTE((nonnull(2)));
|
int32_t setspritez(int16_t spritenum, const vec3_t *) ATTRIBUTE((nonnull(2)));
|
||||||
|
|
||||||
int32_t spriteheightofsptr(const spritetype *spr, int32_t *height, int32_t alsotileyofs);
|
int32_t spriteheightofsptr(const uspritetype *spr, int32_t *height, int32_t alsotileyofs);
|
||||||
FORCE_INLINE int32_t spriteheightofs(int16_t i, int32_t *height, int32_t alsotileyofs)
|
FORCE_INLINE int32_t spriteheightofs(int16_t i, int32_t *height, int32_t alsotileyofs)
|
||||||
{
|
{
|
||||||
return spriteheightofsptr(&sprite[i], height, alsotileyofs);
|
return spriteheightofsptr((uspritetype *)&sprite[i], height, alsotileyofs);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t screencapture(const char *filename, char inverseit, const char *versionstr) ATTRIBUTE((nonnull(1)));
|
int32_t screencapture(const char *filename, char inverseit, const char *versionstr) ATTRIBUTE((nonnull(1)));
|
||||||
|
|
|
@ -58,8 +58,8 @@ extern int16_t *sectq;
|
||||||
extern int16_t pictoidx[MAXTILES]; // maps tile num to clipinfo[] index
|
extern int16_t pictoidx[MAXTILES]; // maps tile num to clipinfo[] index
|
||||||
extern int16_t clipspritelist[MAXCLIPNUM];
|
extern int16_t clipspritelist[MAXCLIPNUM];
|
||||||
extern void mapinfo_set(mapinfo_t *bak, mapinfo_t *newmap);
|
extern void mapinfo_set(mapinfo_t *bak, mapinfo_t *newmap);
|
||||||
extern int32_t clipsprite_try(const spritetype *spr, int32_t xmin, int32_t ymin, int32_t xmax, int32_t ymax);
|
extern int32_t clipsprite_try(uspritetype const * const spr, int32_t xmin, int32_t ymin, int32_t xmax, int32_t ymax);
|
||||||
extern int32_t clipsprite_initindex(int32_t curidx, spritetype *curspr, int32_t *clipsectcnt, const vec3_t *vect);
|
extern int32_t clipsprite_initindex(int32_t curidx, uspritetype const * const curspr, int32_t *clipsectcnt, const vec3_t *vect);
|
||||||
|
|
||||||
#endif // HAVE_CLIPSHAPE_FEATURE
|
#endif // HAVE_CLIPSHAPE_FEATURE
|
||||||
typedef struct
|
typedef struct
|
||||||
|
|
|
@ -504,7 +504,7 @@ int32_t clipmapinfo_load(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int32_t clipshape_idx_for_sprite(spritetype *curspr, int32_t curidx)
|
int32_t clipshape_idx_for_sprite(uspritetype const * const curspr, int32_t curidx)
|
||||||
{
|
{
|
||||||
if (curidx < 0) // per-sprite init
|
if (curidx < 0) // per-sprite init
|
||||||
curidx = pictoidx[curspr->picnum];
|
curidx = pictoidx[curspr->picnum];
|
||||||
|
@ -517,7 +517,7 @@ int32_t clipshape_idx_for_sprite(spritetype *curspr, int32_t curidx)
|
||||||
return curidx;
|
return curidx;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
int32_t clipshape_idx_for_sprite(spritetype *curspr, int32_t curidx)
|
int32_t clipshape_idx_for_sprite(uspritetype const * const curspr, int32_t curidx)
|
||||||
{
|
{
|
||||||
UNREFERENCED_PARAMETER(curspr);
|
UNREFERENCED_PARAMETER(curspr);
|
||||||
UNREFERENCED_PARAMETER(curidx);
|
UNREFERENCED_PARAMETER(curidx);
|
||||||
|
@ -593,7 +593,7 @@ int32_t clipinsideboxline(int32_t x, int32_t y, int32_t x1, int32_t y1, int32_t
|
||||||
|
|
||||||
|
|
||||||
#ifdef HAVE_CLIPSHAPE_FEATURE
|
#ifdef HAVE_CLIPSHAPE_FEATURE
|
||||||
int32_t clipsprite_try(const spritetype *spr, int32_t xmin, int32_t ymin, int32_t xmax, int32_t ymax)
|
int32_t clipsprite_try(uspritetype const * const spr, int32_t xmin, int32_t ymin, int32_t xmax, int32_t ymax)
|
||||||
{
|
{
|
||||||
// try and see whether this sprite's picnum has sector-like clipping data
|
// try and see whether this sprite's picnum has sector-like clipping data
|
||||||
int32_t i = pictoidx[spr->picnum];
|
int32_t i = pictoidx[spr->picnum];
|
||||||
|
@ -626,7 +626,7 @@ int32_t clipsprite_try(const spritetype *spr, int32_t xmin, int32_t ymin, int32_
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
if (clipspritenum < MAXCLIPNUM)
|
if (clipspritenum < MAXCLIPNUM)
|
||||||
clipspritelist[clipspritenum++] = spr-sprite;
|
clipspritelist[clipspritenum++] = spr-(uspritetype *)sprite;
|
||||||
//initprintf("%d: clip sprite[%d]\n",clipspritenum,j);
|
//initprintf("%d: clip sprite[%d]\n",clipspritenum,j);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -635,7 +635,7 @@ int32_t clipsprite_try(const spritetype *spr, int32_t xmin, int32_t ymin, int32_
|
||||||
}
|
}
|
||||||
|
|
||||||
// return: -1 if curspr has x-flip xor y-flip (in the horizontal map plane!), 1 else
|
// return: -1 if curspr has x-flip xor y-flip (in the horizontal map plane!), 1 else
|
||||||
int32_t clipsprite_initindex(int32_t curidx, spritetype *curspr, int32_t *clipsectcnt, const vec3_t *vect)
|
int32_t clipsprite_initindex(int32_t curidx, uspritetype const * const curspr, int32_t *clipsectcnt, const vec3_t *vect)
|
||||||
{
|
{
|
||||||
int32_t k, daz = curspr->z;
|
int32_t k, daz = curspr->z;
|
||||||
int32_t scalex, scaley, scalez, flipx, flipy;
|
int32_t scalex, scaley, scalez, flipx, flipy;
|
||||||
|
@ -868,7 +868,7 @@ int32_t clipmove(vec3_t *pos, int16_t *sectnum,
|
||||||
int32_t dax, day;
|
int32_t dax, day;
|
||||||
int32_t retval=0;
|
int32_t retval=0;
|
||||||
|
|
||||||
spritetype *curspr=NULL; // non-NULL when handling sprite with sector-like clipping
|
uspritetype const * curspr=NULL; // non-NULL when handling sprite with sector-like clipping
|
||||||
int32_t curidx=-1, clipsectcnt, clipspritecnt;
|
int32_t curidx=-1, clipsectcnt, clipspritecnt;
|
||||||
|
|
||||||
const int32_t dawalclipmask = (cliptype&65535); //CLIPMASK0 = 0x00010001
|
const int32_t dawalclipmask = (cliptype&65535); //CLIPMASK0 = 0x00010001
|
||||||
|
@ -917,7 +917,7 @@ int32_t clipmove(vec3_t *pos, int16_t *sectnum,
|
||||||
mapinfo_set(&origmapinfo, &clipmapinfo);
|
mapinfo_set(&origmapinfo, &clipmapinfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
curspr = &sprite[clipspritelist[clipspritecnt]];
|
curspr = (uspritetype *)&sprite[clipspritelist[clipspritecnt]];
|
||||||
curidx = clipshape_idx_for_sprite(curspr, curidx);
|
curidx = clipshape_idx_for_sprite(curspr, curidx);
|
||||||
|
|
||||||
if (curidx < 0)
|
if (curidx < 0)
|
||||||
|
@ -1029,7 +1029,7 @@ int32_t clipmove(vec3_t *pos, int16_t *sectnum,
|
||||||
if (!curspr)
|
if (!curspr)
|
||||||
objtype = (int16_t) j+32768;
|
objtype = (int16_t) j+32768;
|
||||||
else
|
else
|
||||||
objtype = (int16_t) (curspr-sprite)+49152;
|
objtype = (int16_t) (curspr-(uspritetype *)sprite)+49152;
|
||||||
|
|
||||||
//Add 2 boxes at endpoints
|
//Add 2 boxes at endpoints
|
||||||
bsz = walldist; if (gx < 0) bsz = -bsz;
|
bsz = walldist; if (gx < 0) bsz = -bsz;
|
||||||
|
@ -1062,7 +1062,7 @@ int32_t clipmove(vec3_t *pos, int16_t *sectnum,
|
||||||
#endif
|
#endif
|
||||||
for (j=headspritesect[dasect]; j>=0; j=nextspritesect[j])
|
for (j=headspritesect[dasect]; j>=0; j=nextspritesect[j])
|
||||||
{
|
{
|
||||||
const spritetype *const spr = &sprite[j];
|
const uspritetype *const spr = (uspritetype *)&sprite[j];
|
||||||
const int32_t cstat = spr->cstat;
|
const int32_t cstat = spr->cstat;
|
||||||
|
|
||||||
if ((cstat&dasprclipmask) == 0)
|
if ((cstat&dasprclipmask) == 0)
|
||||||
|
|
|
@ -362,7 +362,7 @@ uint8_t yax_gotsector[MAXSECTORS>>3]; // engine internal
|
||||||
int16_t yax_bunchnum[MAXSECTORS][2];
|
int16_t yax_bunchnum[MAXSECTORS][2];
|
||||||
int16_t yax_nextwall[MAXWALLS][2];
|
int16_t yax_nextwall[MAXWALLS][2];
|
||||||
|
|
||||||
static inline int32_t yax_islockededge(int32_t line, int32_t cf)
|
FORCE_INLINE int32_t yax_islockededge(int32_t line, int32_t cf)
|
||||||
{
|
{
|
||||||
return !!(wall[line].cstat&(YAX_NEXTWALLBIT(cf)));
|
return !!(wall[line].cstat&(YAX_NEXTWALLBIT(cf)));
|
||||||
}
|
}
|
||||||
|
@ -376,17 +376,14 @@ int16_t yax_getbunch(int16_t i, int16_t cf)
|
||||||
if (editstatus==0)
|
if (editstatus==0)
|
||||||
return yax_bunchnum[i][cf];
|
return yax_bunchnum[i][cf];
|
||||||
|
|
||||||
if (((*(§or[i].ceilingstat + cf))&YAX_BIT)==0)
|
return (*(§or[i].ceilingstat + cf) & YAX_BIT) ? YAX_BUNCHNUM(i, cf) : -1;
|
||||||
return -1;
|
|
||||||
|
|
||||||
return YAX_BUNCHNUM(i, cf);
|
|
||||||
}
|
}
|
||||||
# else
|
# else
|
||||||
# define YAX_PTRBUNCHNUM(Ptr, Sect, Cf) (*((Cf) ? &(Ptr)[Sect].floorbunch : &(Ptr)[Sect].ceilingbunch))
|
# define YAX_PTRBUNCHNUM(Ptr, Sect, Cf) (*((Cf) ? &(Ptr)[Sect].floorbunch : &(Ptr)[Sect].ceilingbunch))
|
||||||
# define YAX_BUNCHNUM(Sect, Cf) YAX_PTRBUNCHNUM(sector, Sect, Cf)
|
# define YAX_BUNCHNUM(Sect, Cf) YAX_PTRBUNCHNUM(sector, Sect, Cf)
|
||||||
|
|
||||||
# if !defined NEW_MAP_FORMAT
|
# if !defined NEW_MAP_FORMAT
|
||||||
static inline int32_t yax_islockededge(int32_t line, int32_t cf)
|
FORCE_INLINE int32_t yax_islockededge(int32_t line, int32_t cf)
|
||||||
{
|
{
|
||||||
return (yax_getnextwall(line, cf) >= 0);
|
return (yax_getnextwall(line, cf) >= 0);
|
||||||
}
|
}
|
||||||
|
@ -410,13 +407,10 @@ void yax_setbunch(int16_t i, int16_t cf, int16_t bunchnum)
|
||||||
|
|
||||||
if (bunchnum < 0)
|
if (bunchnum < 0)
|
||||||
{
|
{
|
||||||
int32_t j;
|
|
||||||
int16_t ynw;
|
|
||||||
|
|
||||||
if (bunchnum > -3)
|
if (bunchnum > -3)
|
||||||
{
|
{
|
||||||
// TODO: for in-game too?
|
// TODO: for in-game too?
|
||||||
for (j=sector[i].wallptr; j<sector[i].wallptr+sector[i].wallnum; j++)
|
for (int ynw, j=sector[i].wallptr; j<sector[i].wallptr+sector[i].wallnum; j++)
|
||||||
{
|
{
|
||||||
ynw = yax_getnextwall(j, cf);
|
ynw = yax_getnextwall(j, cf);
|
||||||
if (ynw >= 0)
|
if (ynw >= 0)
|
||||||
|
@ -458,10 +452,7 @@ int16_t yax_getnextwall(int16_t wal, int16_t cf)
|
||||||
if (editstatus==0)
|
if (editstatus==0)
|
||||||
return yax_nextwall[wal][cf];
|
return yax_nextwall[wal][cf];
|
||||||
|
|
||||||
if (!yax_islockededge(wal, cf))
|
return yax_islockededge(wal, cf) ? YAX_NEXTWALL(wal, cf) : -1;
|
||||||
return -1;
|
|
||||||
|
|
||||||
return YAX_NEXTWALL(wal, cf);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// unchecked!
|
// unchecked!
|
||||||
|
@ -655,12 +646,11 @@ void yax_update(int32_t resetstat)
|
||||||
int32_t yax_getneighborsect(int32_t x, int32_t y, int32_t sectnum, int32_t cf)
|
int32_t yax_getneighborsect(int32_t x, int32_t y, int32_t sectnum, int32_t cf)
|
||||||
{
|
{
|
||||||
int16_t bunchnum = yax_getbunch(sectnum, cf);
|
int16_t bunchnum = yax_getbunch(sectnum, cf);
|
||||||
int32_t i;
|
|
||||||
|
|
||||||
if (bunchnum < 0)
|
if (bunchnum < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
for (SECTORS_OF_BUNCH(bunchnum, !cf, i))
|
for (int SECTORS_OF_BUNCH(bunchnum, !cf, i))
|
||||||
if (inside(x, y, i)==1)
|
if (inside(x, y, i)==1)
|
||||||
return i;
|
return i;
|
||||||
|
|
||||||
|
@ -1974,7 +1964,7 @@ static void maskwallscan(int32_t x1, int32_t x2, int32_t saturatevplc)
|
||||||
setupmvlineasm(globalshiftval, saturatevplc);
|
setupmvlineasm(globalshiftval, saturatevplc);
|
||||||
|
|
||||||
int32_t x = x1;
|
int32_t x = x1;
|
||||||
while ((x <= x2) && (startumost[x+windowx1] > startdmost[x+windowx1]))
|
while ((x <= x2) && (startumost[x+windowxy1.x] > startdmost[x+windowxy1.x]))
|
||||||
x++;
|
x++;
|
||||||
|
|
||||||
intptr_t p = x+frameoffset;
|
intptr_t p = x+frameoffset;
|
||||||
|
@ -1989,8 +1979,8 @@ static void maskwallscan(int32_t x1, int32_t x2, int32_t saturatevplc)
|
||||||
#ifdef MULTI_COLUMN_VLINE
|
#ifdef MULTI_COLUMN_VLINE
|
||||||
for (; (x<=x2)&&(p&3); x++,p++)
|
for (; (x<=x2)&&(p&3); x++,p++)
|
||||||
{
|
{
|
||||||
y1ve[0] = max(uwall[x],startumost[x+windowx1]-windowy1);
|
y1ve[0] = max(uwall[x],startumost[x+windowxy1.x]-windowxy1.y);
|
||||||
y2ve[0] = min(dwall[x],startdmost[x+windowx1]-windowy1);
|
y2ve[0] = min(dwall[x],startdmost[x+windowxy1.x]-windowxy1.y);
|
||||||
if (y2ve[0] <= y1ve[0]) continue;
|
if (y2ve[0] <= y1ve[0]) continue;
|
||||||
|
|
||||||
palookupoffse[0] = fpalookup + getpalookupsh(mulscale16(swall[x],globvis));
|
palookupoffse[0] = fpalookup + getpalookupsh(mulscale16(swall[x],globvis));
|
||||||
|
@ -2006,8 +1996,8 @@ static void maskwallscan(int32_t x1, int32_t x2, int32_t saturatevplc)
|
||||||
|
|
||||||
for (int z=3,dax=x+3; z>=0; z--,dax--)
|
for (int z=3,dax=x+3; z>=0; z--,dax--)
|
||||||
{
|
{
|
||||||
y1ve[z] = max(uwall[dax],startumost[dax+windowx1]-windowy1);
|
y1ve[z] = max(uwall[dax],startumost[dax+windowxy1.x]-windowxy1.y);
|
||||||
y2ve[z] = min(dwall[dax],startdmost[dax+windowx1]-windowy1)-1;
|
y2ve[z] = min(dwall[dax],startdmost[dax+windowxy1.x]-windowxy1.y)-1;
|
||||||
if (y2ve[z] < y1ve[z]) { bad += pow2char[z]; continue; }
|
if (y2ve[z] < y1ve[z]) { bad += pow2char[z]; continue; }
|
||||||
|
|
||||||
calc_bufplc(&bufplce[z], lwall[dax], tsiz);
|
calc_bufplc(&bufplce[z], lwall[dax], tsiz);
|
||||||
|
@ -2062,8 +2052,8 @@ do_mvlineasm1:
|
||||||
#endif
|
#endif
|
||||||
for (; x<=x2; x++,p++)
|
for (; x<=x2; x++,p++)
|
||||||
{
|
{
|
||||||
y1ve[0] = max(uwall[x],startumost[x+windowx1]-windowy1);
|
y1ve[0] = max(uwall[x],startumost[x+windowxy1.x]-windowxy1.y);
|
||||||
y2ve[0] = min(dwall[x],startdmost[x+windowx1]-windowy1);
|
y2ve[0] = min(dwall[x],startdmost[x+windowxy1.x]-windowxy1.y);
|
||||||
if (y2ve[0] <= y1ve[0]) continue;
|
if (y2ve[0] <= y1ve[0]) continue;
|
||||||
|
|
||||||
palookupoffse[0] = fpalookup + getpalookupsh(mulscale16(swall[x],globvis));
|
palookupoffse[0] = fpalookup + getpalookupsh(mulscale16(swall[x],globvis));
|
||||||
|
@ -3102,10 +3092,10 @@ do_vlineasm1:
|
||||||
//
|
//
|
||||||
static void transmaskvline(int32_t x)
|
static void transmaskvline(int32_t x)
|
||||||
{
|
{
|
||||||
if ((unsigned)x >= xdimen) return;
|
if ((unsigned)x >= (unsigned)xdimen) return;
|
||||||
|
|
||||||
int32_t const y1v = max(uwall[x],startumost[x+windowx1]-windowy1);
|
int32_t const y1v = max(uwall[x],startumost[x+windowxy1.x]-windowxy1.y);
|
||||||
int32_t const y2v = min(dwall[x],startdmost[x+windowx1]-windowy1) - 1;
|
int32_t const y2v = min(dwall[x],startdmost[x+windowxy1.x]-windowxy1.y) - 1;
|
||||||
|
|
||||||
if (y2v < y1v) return;
|
if (y2v < y1v) return;
|
||||||
|
|
||||||
|
@ -3135,17 +3125,17 @@ static void transmaskvline(int32_t x)
|
||||||
#ifdef MULTI_COLUMN_VLINE
|
#ifdef MULTI_COLUMN_VLINE
|
||||||
static void transmaskvline2(int32_t x)
|
static void transmaskvline2(int32_t x)
|
||||||
{
|
{
|
||||||
if ((unsigned)x >= xdimen) return;
|
if ((unsigned)x >= (unsigned)xdimen) return;
|
||||||
if (x == xdimen-1) { transmaskvline(x); return; }
|
if (x == xdimen-1) { transmaskvline(x); return; }
|
||||||
|
|
||||||
int32_t y1ve[2], y2ve[2];
|
int32_t y1ve[2], y2ve[2];
|
||||||
int32_t x2 = x+1;
|
int32_t x2 = x+1;
|
||||||
|
|
||||||
y1ve[0] = max(uwall[x],startumost[x+windowx1]-windowy1);
|
y1ve[0] = max(uwall[x],startumost[x+windowxy1.x]-windowxy1.y);
|
||||||
y2ve[0] = min(dwall[x],startdmost[x+windowx1]-windowy1)-1;
|
y2ve[0] = min(dwall[x],startdmost[x+windowxy1.x]-windowxy1.y)-1;
|
||||||
if (y2ve[0] < y1ve[0]) { transmaskvline(x2); return; }
|
if (y2ve[0] < y1ve[0]) { transmaskvline(x2); return; }
|
||||||
y1ve[1] = max(uwall[x2],startumost[x2+windowx1]-windowy1);
|
y1ve[1] = max(uwall[x2],startumost[x2+windowxy1.x]-windowxy1.y);
|
||||||
y2ve[1] = min(dwall[x2],startdmost[x2+windowx1]-windowy1)-1;
|
y2ve[1] = min(dwall[x2],startdmost[x2+windowxy1.x]-windowxy1.y)-1;
|
||||||
if (y2ve[1] < y1ve[1]) { transmaskvline(x); return; }
|
if (y2ve[1] < y1ve[1]) { transmaskvline(x); return; }
|
||||||
|
|
||||||
palookupoffse[0] = FP_OFF(palookup[globalpal]) + getpalookupsh(mulscale16(swall[x],globvis));
|
palookupoffse[0] = FP_OFF(palookup[globalpal]) + getpalookupsh(mulscale16(swall[x],globvis));
|
||||||
|
@ -3211,7 +3201,7 @@ static void transmaskwallscan(int32_t x1, int32_t x2, int32_t saturatevplc)
|
||||||
setuptvlineasm(globalshiftval, saturatevplc);
|
setuptvlineasm(globalshiftval, saturatevplc);
|
||||||
|
|
||||||
int32_t x = x1;
|
int32_t x = x1;
|
||||||
while ((x <= x2) && (startumost[x+windowx1] > startdmost[x+windowx1]))
|
while ((x <= x2) && (startumost[x+windowxy1.x] > startdmost[x+windowxy1.x]))
|
||||||
++x;
|
++x;
|
||||||
|
|
||||||
#ifndef ENGINE_USING_A_C
|
#ifndef ENGINE_USING_A_C
|
||||||
|
@ -4872,8 +4862,7 @@ static void drawsprite_classic(int32_t snum)
|
||||||
if (cstat&2)
|
if (cstat&2)
|
||||||
setup_blend(blendidx, cstat&512);
|
setup_blend(blendidx, cstat&512);
|
||||||
|
|
||||||
int32_t xoff = picanm[tilenum].xofs + tspr->xoffset;
|
vec2_t off = { picanm[tilenum].xofs + tspr->xoffset, picanm[tilenum].yofs + tspr->yoffset };
|
||||||
int32_t yoff = picanm[tilenum].yofs + tspr->yoffset;
|
|
||||||
|
|
||||||
if ((cstat&48) == 0)
|
if ((cstat&48) == 0)
|
||||||
{
|
{
|
||||||
|
@ -4883,49 +4872,39 @@ static void drawsprite_classic(int32_t snum)
|
||||||
draw_as_face_sprite:
|
draw_as_face_sprite:
|
||||||
if (yp <= (4<<8)) return;
|
if (yp <= (4<<8)) return;
|
||||||
|
|
||||||
const int32_t siz = divscale19(xdimenscale,yp);
|
int const isiz = divscale19(xdimenscale,yp);
|
||||||
|
int const xv = mulscale16(((int32_t)tspr->xrepeat)<<16,xyaspect);
|
||||||
|
vec2_t const span = tilesiz[tilenum];
|
||||||
|
vec2_t const siz = { mulscale30(isiz, xv * span.x), mulscale14(isiz, tspr->yrepeat * span.y) };
|
||||||
|
|
||||||
const int32_t xv = mulscale16(((int32_t)tspr->xrepeat)<<16,xyaspect);
|
if (EDUKE32_PREDICT_FALSE((span.x>>11) >= siz.x || span.y >= (siz.y>>1)))
|
||||||
|
|
||||||
const int32_t xspan = tilesiz[tilenum].x;
|
|
||||||
const int32_t yspan = tilesiz[tilenum].y;
|
|
||||||
|
|
||||||
const int32_t xsiz = mulscale30(siz,xv*xspan);
|
|
||||||
const int32_t ysiz = mulscale14(siz,tspr->yrepeat*yspan);
|
|
||||||
|
|
||||||
if (EDUKE32_PREDICT_FALSE((xspan>>11) >= xsiz || yspan >= (ysiz>>1)))
|
|
||||||
return; //Watch out for divscale overflow
|
return; //Watch out for divscale overflow
|
||||||
|
|
||||||
x1 = xb-(xsiz>>1);
|
x1 = xb-(siz.x>>1);
|
||||||
if (xspan&1) x1 += mulscale31(siz,xv); //Odd xspans
|
if (span.x&1) x1 += mulscale31(isiz,xv); //Odd xspans
|
||||||
i = mulscale30(siz,xv*xoff);
|
i = mulscale30(isiz,xv*off.x);
|
||||||
if ((cstat&4) == 0) x1 -= i; else x1 += i;
|
if ((cstat&4) == 0) x1 -= i; else x1 += i;
|
||||||
|
|
||||||
y1 = mulscale16(tspr->z-globalposz,siz);
|
y1 = mulscale16(tspr->z-globalposz,isiz);
|
||||||
y1 -= mulscale14(siz,tspr->yrepeat*yoff);
|
y1 -= mulscale14(isiz,tspr->yrepeat*off.y);
|
||||||
y1 += (globalhoriz<<8)-ysiz;
|
y1 += (globalhoriz<<8)-siz.y;
|
||||||
if (cstat&128)
|
if (cstat&128)
|
||||||
{
|
{
|
||||||
y1 += (ysiz>>1);
|
y1 += (siz.y>>1);
|
||||||
if (yspan&1) y1 += mulscale15(siz,tspr->yrepeat); //Odd yspans
|
if (span.y&1) y1 += mulscale15(isiz,tspr->yrepeat); //Odd yspans
|
||||||
}
|
}
|
||||||
|
|
||||||
x2 = x1+xsiz-1;
|
x2 = x1+siz.x-1;
|
||||||
y2 = y1+ysiz-1;
|
y2 = y1+siz.y-1;
|
||||||
if ((y1|255) >= (y2|255)) return;
|
if ((y1|255) >= (y2|255)) return;
|
||||||
|
|
||||||
int32_t lx = (x1>>8)+1; if (lx < 0) lx = 0;
|
int32_t lx = (x1>>8)+1; if (lx < 0) lx = 0;
|
||||||
int32_t rx = (x2>>8); if (rx >= xdimen) rx = xdimen-1;
|
int32_t rx = (x2>>8); if (rx >= xdimen) rx = xdimen-1;
|
||||||
if (lx > rx) return;
|
if (lx > rx) return;
|
||||||
|
|
||||||
if ((sec->ceilingstat&3) == 0)
|
startum = ((sec->ceilingstat&3) == 0) ? globalhoriz+mulscale24(isiz,sec->ceilingz-globalposz)-1 : 0;
|
||||||
startum = globalhoriz+mulscale24(siz,sec->ceilingz-globalposz)-1;
|
startdm = ((sec->floorstat&3) == 0) ? globalhoriz+mulscale24(isiz,sec->floorz-globalposz)+1 : INT32_MAX;
|
||||||
else
|
|
||||||
startum = 0;
|
|
||||||
if ((sec->floorstat&3) == 0)
|
|
||||||
startdm = globalhoriz+mulscale24(siz,sec->floorz-globalposz)+1;
|
|
||||||
else
|
|
||||||
startdm = INT32_MAX;
|
|
||||||
if ((y1>>8) > startum) startum = (y1>>8);
|
if ((y1>>8) > startum) startum = (y1>>8);
|
||||||
if ((y2>>8) < startdm) startdm = (y2>>8);
|
if ((y2>>8) < startdm) startdm = (y2>>8);
|
||||||
|
|
||||||
|
@ -4935,12 +4914,12 @@ draw_as_face_sprite:
|
||||||
|
|
||||||
if ((cstat&4) == 0)
|
if ((cstat&4) == 0)
|
||||||
{
|
{
|
||||||
linuminc = divscale24(xspan,xsiz);
|
linuminc = divscale24(span.x,siz.x);
|
||||||
linum = mulscale8((lx<<8)-x1,linuminc);
|
linum = mulscale8((lx<<8)-x1,linuminc);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
linuminc = -divscale24(xspan,xsiz);
|
linuminc = -divscale24(span.x,siz.x);
|
||||||
linum = mulscale8((lx<<8)-x2,linuminc);
|
linum = mulscale8((lx<<8)-x2,linuminc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4951,21 +4930,21 @@ draw_as_face_sprite:
|
||||||
#ifdef CLASSIC_SLICE_BY_4
|
#ifdef CLASSIC_SLICE_BY_4
|
||||||
for (; x<=rx-4; x+=4)
|
for (; x<=rx-4; x+=4)
|
||||||
{
|
{
|
||||||
uwall[x] = max(startumost[windowx1+x]-windowy1, (int16_t) startum);
|
uwall[x] = max(startumost[windowxy1.x+x]-windowxy1.y, (int16_t) startum);
|
||||||
uwall[x+1] = max(startumost[windowx1+x+1]-windowy1, (int16_t) startum);
|
uwall[x+1] = max(startumost[windowxy1.x+x+1]-windowxy1.y, (int16_t) startum);
|
||||||
uwall[x+2] = max(startumost[windowx1+x+2]-windowy1, (int16_t) startum);
|
uwall[x+2] = max(startumost[windowxy1.x+x+2]-windowxy1.y, (int16_t) startum);
|
||||||
uwall[x+3] = max(startumost[windowx1+x+3]-windowy1, (int16_t) startum);
|
uwall[x+3] = max(startumost[windowxy1.x+x+3]-windowxy1.y, (int16_t) startum);
|
||||||
|
|
||||||
dwall[x] = min(startdmost[windowx1+x]-windowy1, (int16_t) startdm);
|
dwall[x] = min(startdmost[windowxy1.x+x]-windowxy1.y, (int16_t) startdm);
|
||||||
dwall[x+1] = min(startdmost[windowx1+x+1]-windowy1, (int16_t) startdm);
|
dwall[x+1] = min(startdmost[windowxy1.x+x+1]-windowxy1.y, (int16_t) startdm);
|
||||||
dwall[x+2] = min(startdmost[windowx1+x+2]-windowy1, (int16_t) startdm);
|
dwall[x+2] = min(startdmost[windowxy1.x+x+2]-windowxy1.y, (int16_t) startdm);
|
||||||
dwall[x+3] = min(startdmost[windowx1+x+3]-windowy1, (int16_t) startdm);
|
dwall[x+3] = min(startdmost[windowxy1.x+x+3]-windowxy1.y, (int16_t) startdm);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
for (; x<=rx; x++)
|
for (; x<=rx; x++)
|
||||||
{
|
{
|
||||||
uwall[x] = max(startumost[windowx1+x]-windowy1,(int16_t)startum);
|
uwall[x] = max(startumost[windowxy1.x+x]-windowxy1.y,(int16_t)startum);
|
||||||
dwall[x] = min(startdmost[windowx1+x]-windowy1,(int16_t)startdm);
|
dwall[x] = min(startdmost[windowxy1.x+x]-windowxy1.y,(int16_t)startdm);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t daclip = 0;
|
int32_t daclip = 0;
|
||||||
|
@ -5041,7 +5020,7 @@ draw_as_face_sprite:
|
||||||
searchstat = 3; searchit = 1;
|
searchstat = 3; searchit = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
setup_globals_sprite1(tspr, sec, yspan, yoff, tilenum, cstat, &z1, &z2);
|
setup_globals_sprite1(tspr, sec, span.y, off.y, tilenum, cstat, &z1, &z2);
|
||||||
|
|
||||||
qinterpolatedown16((intptr_t)&lwall[lx],rx-lx+1,linum,linuminc);
|
qinterpolatedown16((intptr_t)&lwall[lx],rx-lx+1,linum,linuminc);
|
||||||
clearbuf(&swall[lx],rx-lx+1,mulscale19(yp,xdimscale));
|
clearbuf(&swall[lx],rx-lx+1,mulscale19(yp,xdimscale));
|
||||||
|
@ -5052,7 +5031,7 @@ draw_as_face_sprite:
|
||||||
// initialize the float of the union
|
// initialize the float of the union
|
||||||
((cstat&8) ? -1 : 1)
|
((cstat&8) ? -1 : 1)
|
||||||
* (float)yp * xdimscale
|
* (float)yp * xdimscale
|
||||||
* (1<<(22-19)) / (yspan*tspr->yrepeat)
|
* (1<<(22-19)) / (span.y*tspr->yrepeat)
|
||||||
};
|
};
|
||||||
|
|
||||||
clearbuf(&swallf[lx], rx-lx+1, sw.i);
|
clearbuf(&swallf[lx], rx-lx+1, sw.i);
|
||||||
|
@ -5075,10 +5054,10 @@ draw_as_face_sprite:
|
||||||
const int32_t xv = tspr->xrepeat*sintable[(tspr->ang+2560+1536)&2047];
|
const int32_t xv = tspr->xrepeat*sintable[(tspr->ang+2560+1536)&2047];
|
||||||
const int32_t yv = tspr->xrepeat*sintable[(tspr->ang+2048+1536)&2047];
|
const int32_t yv = tspr->xrepeat*sintable[(tspr->ang+2048+1536)&2047];
|
||||||
|
|
||||||
if ((cstat&4) > 0) xoff = -xoff;
|
if ((cstat&4) > 0) off.x = -off.x;
|
||||||
if ((cstat&8) > 0) yoff = -yoff;
|
if ((cstat&8) > 0) off.y = -off.y;
|
||||||
|
|
||||||
i = (xspan>>1) + xoff;
|
i = (xspan>>1) + off.x;
|
||||||
x1 = tspr->x-globalposx-mulscale16(xv,i); x2 = x1+mulscale16(xv,xspan);
|
x1 = tspr->x-globalposx-mulscale16(xv,i); x2 = x1+mulscale16(xv,xspan);
|
||||||
y1 = tspr->y-globalposy-mulscale16(yv,i); y2 = y1+mulscale16(yv,xspan);
|
y1 = tspr->y-globalposy-mulscale16(yv,i); y2 = y1+mulscale16(yv,xspan);
|
||||||
|
|
||||||
|
@ -5142,7 +5121,7 @@ draw_as_face_sprite:
|
||||||
rx1[MAXWALLSB-1] = p1.x; ry1[MAXWALLSB-1] = p1.y;
|
rx1[MAXWALLSB-1] = p1.x; ry1[MAXWALLSB-1] = p1.y;
|
||||||
rx2[MAXWALLSB-1] = p2.x; ry2[MAXWALLSB-1] = p2.y;
|
rx2[MAXWALLSB-1] = p2.x; ry2[MAXWALLSB-1] = p2.y;
|
||||||
|
|
||||||
setup_globals_sprite1(tspr, sec, yspan, yoff, tilenum, cstat, &z1, &z2);
|
setup_globals_sprite1(tspr, sec, yspan, off.y, tilenum, cstat, &z1, &z2);
|
||||||
|
|
||||||
if ((sec->ceilingstat&1) == 0 && z1 < sec->ceilingz)
|
if ((sec->ceilingstat&1) == 0 && z1 < sec->ceilingz)
|
||||||
z1 = sec->ceilingz;
|
z1 = sec->ceilingz;
|
||||||
|
@ -5352,8 +5331,8 @@ draw_as_face_sprite:
|
||||||
if ((globalposz > tspr->z) == ((cstat&8)==0))
|
if ((globalposz > tspr->z) == ((cstat&8)==0))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if ((cstat&4) > 0) xoff = -xoff;
|
if ((cstat&4) > 0) off.x = -off.x;
|
||||||
if ((cstat&8) > 0) yoff = -yoff;
|
if ((cstat&8) > 0) off.y = -off.y;
|
||||||
|
|
||||||
const int32_t xspan = tilesiz[tilenum].x;
|
const int32_t xspan = tilesiz[tilenum].x;
|
||||||
const int32_t yspan = tilesiz[tilenum].y;
|
const int32_t yspan = tilesiz[tilenum].y;
|
||||||
|
@ -5368,8 +5347,8 @@ draw_as_face_sprite:
|
||||||
i = ((tspr->ang+2048-globalang)&2047);
|
i = ((tspr->ang+2048-globalang)&2047);
|
||||||
int32_t cosang = sintable[(i+512)&2047];
|
int32_t cosang = sintable[(i+512)&2047];
|
||||||
int32_t sinang = sintable[i];
|
int32_t sinang = sintable[i];
|
||||||
dax = ((xspan>>1)+xoff)*tspr->xrepeat;
|
dax = ((xspan>>1)+off.x)*tspr->xrepeat;
|
||||||
day = ((yspan>>1)+yoff)*tspr->yrepeat;
|
day = ((yspan>>1)+off.y)*tspr->yrepeat;
|
||||||
rzi[0] += dmulscale12(sinang,dax,cosang,day);
|
rzi[0] += dmulscale12(sinang,dax,cosang,day);
|
||||||
rxi[0] += dmulscale12(sinang,day,-cosang,dax);
|
rxi[0] += dmulscale12(sinang,day,-cosang,dax);
|
||||||
|
|
||||||
|
@ -5582,8 +5561,8 @@ draw_as_face_sprite:
|
||||||
|
|
||||||
for (x=lx; x<=rx; x++)
|
for (x=lx; x<=rx; x++)
|
||||||
{
|
{
|
||||||
uwall[x] = max(uwall[x],startumost[x+windowx1]-windowy1);
|
uwall[x] = max(uwall[x],startumost[x+windowxy1.x]-windowxy1.y);
|
||||||
dwall[x] = min(dwall[x],startdmost[x+windowx1]-windowy1);
|
dwall[x] = min(dwall[x],startdmost[x+windowxy1.x]-windowxy1.y);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Additional uwall/dwall clipping goes here
|
//Additional uwall/dwall clipping goes here
|
||||||
|
@ -5691,8 +5670,8 @@ draw_as_face_sprite:
|
||||||
|
|
||||||
for (x=lx; x<=rx; x++)
|
for (x=lx; x<=rx; x++)
|
||||||
{
|
{
|
||||||
lwall[x] = startumost[x+windowx1]-windowy1;
|
lwall[x] = startumost[x+windowxy1.x]-windowxy1.y;
|
||||||
swall[x] = startdmost[x+windowx1]-windowy1;
|
swall[x] = startdmost[x+windowxy1.x]-windowxy1.y;
|
||||||
}
|
}
|
||||||
for (i=smostwallcnt-1; i>=0; i--)
|
for (i=smostwallcnt-1; i>=0; i--)
|
||||||
{
|
{
|
||||||
|
@ -5781,8 +5760,8 @@ draw_as_face_sprite:
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(cstat&128)) tspr->z -= mulscale22(B_LITTLE32(longptr[5]),nyrepeat);
|
if (!(cstat&128)) tspr->z -= mulscale22(B_LITTLE32(longptr[5]),nyrepeat);
|
||||||
yoff = /*picanm[sprite[tspr->owner].picnum].yofs +*/ tspr->yoffset;
|
off.y = /*picanm[sprite[tspr->owner].picnum].yofs +*/ tspr->yoffset;
|
||||||
tspr->z -= mulscale14(yoff,nyrepeat);
|
tspr->z -= mulscale14(off.y,nyrepeat);
|
||||||
|
|
||||||
globvis = globalvisibility;
|
globvis = globalvisibility;
|
||||||
if (sec->visibility != 0) globvis = mulscale4(globvis, (uint8_t)(sec->visibility+16));
|
if (sec->visibility != 0) globvis = mulscale4(globvis, (uint8_t)(sec->visibility+16));
|
||||||
|
@ -5805,7 +5784,7 @@ draw_as_face_sprite:
|
||||||
{
|
{
|
||||||
x1 = xb-(siz.x>>1);
|
x1 = xb-(siz.x>>1);
|
||||||
if (xspan&1) x1 += mulscale31(xdsiz,xv); //Odd xspans
|
if (xspan&1) x1 += mulscale31(xdsiz,xv); //Odd xspans
|
||||||
i = mulscale30(xdsiz,xv*xoff);
|
i = mulscale30(xdsiz,xv*off.x);
|
||||||
if ((cstat&4) == 0) x1 -= i; else x1 += i;
|
if ((cstat&4) == 0) x1 -= i; else x1 += i;
|
||||||
|
|
||||||
y1 = mulscale16(tspr->z-globalposz,xdsiz);
|
y1 = mulscale16(tspr->z-globalposz,xdsiz);
|
||||||
|
@ -6158,10 +6137,10 @@ static int32_t clippoly(int32_t npoints, int32_t clipstat)
|
||||||
int32_t z, zz, s1, s2, t, npoints2, start2, z1, z2, z3, z4, splitcnt;
|
int32_t z, zz, s1, s2, t, npoints2, start2, z1, z2, z3, z4, splitcnt;
|
||||||
int32_t cx1, cy1, cx2, cy2;
|
int32_t cx1, cy1, cx2, cy2;
|
||||||
|
|
||||||
cx1 = windowx1;
|
cx1 = windowxy1.x;
|
||||||
cy1 = windowy1;
|
cy1 = windowxy1.y;
|
||||||
cx2 = windowx2+1;
|
cx2 = windowxy2.x+1;
|
||||||
cy2 = windowy2+1;
|
cy2 = windowxy2.y+1;
|
||||||
cx1 <<= 12; cy1 <<= 12; cx2 <<= 12; cy2 <<= 12;
|
cx1 <<= 12; cy1 <<= 12; cx2 <<= 12; cy2 <<= 12;
|
||||||
|
|
||||||
if (clipstat&0xa) //Need to clip top or left
|
if (clipstat&0xa) //Need to clip top or left
|
||||||
|
@ -7974,17 +7953,17 @@ int32_t drawrooms(int32_t daposx, int32_t daposy, int32_t daposz,
|
||||||
#endif
|
#endif
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
shortptr1 = (int16_t *)&startumost[windowx1];
|
shortptr1 = (int16_t *)&startumost[windowxy1.x];
|
||||||
shortptr2 = (int16_t *)&startdmost[windowx1];
|
shortptr2 = (int16_t *)&startdmost[windowxy1.x];
|
||||||
i = xdimen-1;
|
i = xdimen-1;
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
umost[i] = shortptr1[i]-windowy1;
|
umost[i] = shortptr1[i]-windowxy1.y;
|
||||||
dmost[i] = shortptr2[i]-windowy1;
|
dmost[i] = shortptr2[i]-windowxy1.y;
|
||||||
}
|
}
|
||||||
while (i--); // xdimen == 1 is OK!
|
while (i--); // xdimen == 1 is OK!
|
||||||
umost[0] = shortptr1[0]-windowy1;
|
umost[0] = shortptr1[0]-windowxy1.y;
|
||||||
dmost[0] = shortptr2[0]-windowy1;
|
dmost[0] = shortptr2[0]-windowxy1.y;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
|
@ -8044,7 +8023,7 @@ int32_t drawrooms(int32_t daposx, int32_t daposy, int32_t daposz,
|
||||||
draw_rainbow_background();
|
draw_rainbow_background();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
frameoffset = frameplace + windowy1*bytesperline + windowx1;
|
frameoffset = frameplace + windowxy1.y*bytesperline + windowxy1.x;
|
||||||
|
|
||||||
//if (smostwallcnt < 0)
|
//if (smostwallcnt < 0)
|
||||||
// if (getkensmessagecrc(FP_OFF(kensmessage)) != 0x56c764d4)
|
// if (getkensmessagecrc(FP_OFF(kensmessage)) != 0x56c764d4)
|
||||||
|
@ -8278,7 +8257,7 @@ static inline int32_t sameside(const _equation *eq, const vec2f_t *p1, c
|
||||||
|
|
||||||
// x1, y1: in/out
|
// x1, y1: in/out
|
||||||
// rest x/y: out
|
// rest x/y: out
|
||||||
void get_wallspr_points(const spritetype *spr, int32_t *x1, int32_t *x2,
|
void get_wallspr_points(const uspritetype *spr, int32_t *x1, int32_t *x2,
|
||||||
int32_t *y1, int32_t *y2);
|
int32_t *y1, int32_t *y2);
|
||||||
void get_floorspr_points(const uspritetype *spr, int32_t px, int32_t py,
|
void get_floorspr_points(const uspritetype *spr, int32_t px, int32_t py,
|
||||||
int32_t *x1, int32_t *x2, int32_t *x3, int32_t *x4,
|
int32_t *x1, int32_t *x2, int32_t *x3, int32_t *x4,
|
||||||
|
@ -8531,7 +8510,7 @@ killsprite:
|
||||||
if ((tspr->cstat & 48) != 16)
|
if ((tspr->cstat & 48) != 16)
|
||||||
tspriteptr[i]->ang = globalang;
|
tspriteptr[i]->ang = globalang;
|
||||||
|
|
||||||
get_wallspr_points((const spritetype *)tspr, &xx[0], &xx[1], &yy[0], &yy[1]);
|
get_wallspr_points((const uspritetype *)tspr, &xx[0], &xx[1], &yy[0], &yy[1]);
|
||||||
|
|
||||||
if ((tspr->cstat & 48) == 0)
|
if ((tspr->cstat & 48) == 0)
|
||||||
tspriteptr[i]->ang = oang;
|
tspriteptr[i]->ang = oang;
|
||||||
|
@ -8663,8 +8642,8 @@ void drawmapview(int32_t dax, int32_t day, int32_t zoome, int16_t ang)
|
||||||
|
|
||||||
Bmemset(gotsector, 0, (numsectors+7)>>3);
|
Bmemset(gotsector, 0, (numsectors+7)>>3);
|
||||||
|
|
||||||
vec2_t const c1 ={ (windowx1<<12), (windowy1<<12) };
|
vec2_t const c1 ={ (windowxy1.x<<12), (windowxy1.y<<12) };
|
||||||
vec2_t const c2 ={ ((windowx2+1)<<12)-1, ((windowy2+1)<<12)-1 };
|
vec2_t const c2 ={ ((windowxy2.x+1)<<12)-1, ((windowxy2.y+1)<<12)-1 };
|
||||||
|
|
||||||
zoome <<= 8;
|
zoome <<= 8;
|
||||||
|
|
||||||
|
@ -9835,8 +9814,8 @@ int32_t saveboard(const char *filename, const vec3_t *dapos, int16_t daang, int1
|
||||||
|
|
||||||
if (numsprites > 0)
|
if (numsprites > 0)
|
||||||
{
|
{
|
||||||
spritetype *const tspri = (spritetype *)Xmalloc(sizeof(spritetype) * numsprites);
|
uspritetype *const tspri = (uspritetype *)Xmalloc(sizeof(spritetype) * numsprites);
|
||||||
spritetype *spri = tspri;
|
uspritetype *spri = tspri;
|
||||||
|
|
||||||
for (j=0; j<MAXSPRITES; j++)
|
for (j=0; j<MAXSPRITES; j++)
|
||||||
{
|
{
|
||||||
|
@ -10814,7 +10793,7 @@ int32_t Mulscale(int32_t a, int32_t b, int32_t sh)
|
||||||
|
|
||||||
// Gets the BUILD unit height and z offset of a sprite.
|
// Gets the BUILD unit height and z offset of a sprite.
|
||||||
// Returns the z offset, 'height' may be NULL.
|
// Returns the z offset, 'height' may be NULL.
|
||||||
int32_t spriteheightofsptr(const spritetype *spr, int32_t *height, int32_t alsotileyofs)
|
int32_t spriteheightofsptr(const uspritetype *spr, int32_t *height, int32_t alsotileyofs)
|
||||||
{
|
{
|
||||||
int32_t hei, zofs=0;
|
int32_t hei, zofs=0;
|
||||||
const int32_t picnum=spr->picnum, yrepeat=spr->yrepeat;
|
const int32_t picnum=spr->picnum, yrepeat=spr->yrepeat;
|
||||||
|
@ -11163,13 +11142,13 @@ static int32_t hitscan_trysector(const vec3_t *sv, const usectortype *sec, hitda
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const int32_t curidx=(int32_t)tmp[0];
|
const int32_t curidx=(int32_t)tmp[0];
|
||||||
const spritetype *const curspr=(spritetype *)tmp[1];
|
const uspritetype *const curspr=(uspritetype *)tmp[1];
|
||||||
const int32_t thislastsec = tmp[2];
|
const int32_t thislastsec = tmp[2];
|
||||||
|
|
||||||
if (!thislastsec)
|
if (!thislastsec)
|
||||||
{
|
{
|
||||||
if (inside(x1,y1,sec-(usectortype *)sector) == 1)
|
if (inside(x1,y1,sec-(usectortype *)sector) == 1)
|
||||||
hit_set(hit, curspr->sectnum, -1, curspr-sprite, x1, y1, z1);
|
hit_set(hit, curspr->sectnum, -1, curspr-(uspritetype *)sprite, x1, y1, z1);
|
||||||
}
|
}
|
||||||
#ifdef HAVE_CLIPSHAPE_FEATURE
|
#ifdef HAVE_CLIPSHAPE_FEATURE
|
||||||
else
|
else
|
||||||
|
@ -11178,7 +11157,7 @@ static int32_t hitscan_trysector(const vec3_t *sv, const usectortype *sec, hitda
|
||||||
{
|
{
|
||||||
if (inside(x1,y1,sectq[i]) == 1)
|
if (inside(x1,y1,sectq[i]) == 1)
|
||||||
{
|
{
|
||||||
hit_set(hit, curspr->sectnum, -1, curspr-sprite, x1, y1, z1);
|
hit_set(hit, curspr->sectnum, -1, curspr-(uspritetype *)sprite, x1, y1, z1);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -11192,7 +11171,7 @@ static int32_t hitscan_trysector(const vec3_t *sv, const usectortype *sec, hitda
|
||||||
|
|
||||||
// x1, y1: in/out
|
// x1, y1: in/out
|
||||||
// rest x/y: out
|
// rest x/y: out
|
||||||
void get_wallspr_points(const spritetype *spr, int32_t *x1, int32_t *x2,
|
void get_wallspr_points(uspritetype const * const spr, int32_t *x1, int32_t *x2,
|
||||||
int32_t *y1, int32_t *y2)
|
int32_t *y1, int32_t *y2)
|
||||||
{
|
{
|
||||||
//These lines get the 2 points of the rotated sprite
|
//These lines get the 2 points of the rotated sprite
|
||||||
|
@ -11221,7 +11200,7 @@ void get_wallspr_points(const spritetype *spr, int32_t *x1, int32_t *x2,
|
||||||
|
|
||||||
// x1, y1: in/out
|
// x1, y1: in/out
|
||||||
// rest x/y: out
|
// rest x/y: out
|
||||||
void get_floorspr_points(const uspritetype *spr, int32_t px, int32_t py,
|
void get_floorspr_points(uspritetype const * const spr, int32_t px, int32_t py,
|
||||||
int32_t *x1, int32_t *x2, int32_t *x3, int32_t *x4,
|
int32_t *x1, int32_t *x2, int32_t *x3, int32_t *x4,
|
||||||
int32_t *y1, int32_t *y2, int32_t *y3, int32_t *y4)
|
int32_t *y1, int32_t *y2, int32_t *y3, int32_t *y4)
|
||||||
{
|
{
|
||||||
|
@ -11289,7 +11268,7 @@ static int32_t get_floorspr_clipyou(int32_t x1, int32_t x2, int32_t x3, int32_t
|
||||||
}
|
}
|
||||||
|
|
||||||
// intp: point of currently best (closest) intersection
|
// intp: point of currently best (closest) intersection
|
||||||
static int32_t try_facespr_intersect(const spritetype *spr, const vec3_t *refpos,
|
static int32_t try_facespr_intersect(uspritetype const * const spr, const vec3_t *refpos,
|
||||||
int32_t vx, int32_t vy, int32_t vz,
|
int32_t vx, int32_t vy, int32_t vz,
|
||||||
vec3_t *intp, int32_t strictly_smaller_than_p)
|
vec3_t *intp, int32_t strictly_smaller_than_p)
|
||||||
{
|
{
|
||||||
|
@ -11346,7 +11325,7 @@ int32_t hitscan(const vec3_t *sv, int16_t sectnum, int32_t vx, int32_t vy, int32
|
||||||
int32_t i, k, daz;
|
int32_t i, k, daz;
|
||||||
int16_t tempshortcnt, tempshortnum;
|
int16_t tempshortcnt, tempshortnum;
|
||||||
|
|
||||||
spritetype *curspr = NULL;
|
uspritetype *curspr = NULL;
|
||||||
int32_t clipspritecnt, curidx=-1;
|
int32_t clipspritecnt, curidx=-1;
|
||||||
// tmp: { (int32_t)curidx, (spritetype *)curspr, (!=0 if outer sector) }
|
// tmp: { (int32_t)curidx, (spritetype *)curspr, (!=0 if outer sector) }
|
||||||
intptr_t tmp[3], *tmpptr=NULL;
|
intptr_t tmp[3], *tmpptr=NULL;
|
||||||
|
@ -11382,7 +11361,7 @@ restart_grand:
|
||||||
if (!curspr)
|
if (!curspr)
|
||||||
mapinfo_set(&origmapinfo, &clipmapinfo); // replace sector and wall with clip map
|
mapinfo_set(&origmapinfo, &clipmapinfo); // replace sector and wall with clip map
|
||||||
|
|
||||||
curspr = &sprite[clipspritelist[clipspritecnt]];
|
curspr = (uspritetype *)&sprite[clipspritelist[clipspritecnt]];
|
||||||
curidx = clipshape_idx_for_sprite(curspr, curidx);
|
curidx = clipshape_idx_for_sprite(curspr, curidx);
|
||||||
|
|
||||||
if (curidx < 0)
|
if (curidx < 0)
|
||||||
|
@ -11460,7 +11439,7 @@ restart_grand:
|
||||||
|
|
||||||
if (wal->cstat&dawalclipmask)
|
if (wal->cstat&dawalclipmask)
|
||||||
{
|
{
|
||||||
hit_set(hit, curspr->sectnum, -1, curspr-sprite, intx, inty, intz);
|
hit_set(hit, curspr->sectnum, -1, curspr-(uspritetype *)sprite, intx, inty, intz);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11469,7 +11448,7 @@ restart_grand:
|
||||||
// ceil cz daz daz2 fz floor
|
// ceil cz daz daz2 fz floor
|
||||||
if ((cz <= intz && intz <= daz) || (daz2 <= intz && intz <= fz))
|
if ((cz <= intz && intz <= daz) || (daz2 <= intz && intz <= fz))
|
||||||
{
|
{
|
||||||
hit_set(hit, curspr->sectnum, -1, curspr-sprite, intx, inty, intz);
|
hit_set(hit, curspr->sectnum, -1, curspr-(uspritetype *)sprite, intx, inty, intz);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -11490,7 +11469,7 @@ restart_grand:
|
||||||
#endif
|
#endif
|
||||||
for (z=headspritesect[dasector]; z>=0; z=nextspritesect[z])
|
for (z=headspritesect[dasector]; z>=0; z=nextspritesect[z])
|
||||||
{
|
{
|
||||||
const spritetype *const spr = &sprite[z];
|
const uspritetype *const spr = (uspritetype *)&sprite[z];
|
||||||
const int32_t cstat = spr->cstat;
|
const int32_t cstat = spr->cstat;
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
if (!hitallsprites)
|
if (!hitallsprites)
|
||||||
|
@ -11740,7 +11719,7 @@ void neartag(int32_t xs, int32_t ys, int32_t zs, int16_t sectnum, int16_t ange,
|
||||||
|
|
||||||
for (z=headspritesect[dasector]; z>=0; z=nextspritesect[z])
|
for (z=headspritesect[dasector]; z>=0; z=nextspritesect[z])
|
||||||
{
|
{
|
||||||
const spritetype *const spr = &sprite[z];
|
const uspritetype *const spr = (uspritetype *)&sprite[z];
|
||||||
|
|
||||||
if (blacklist_sprite_func && blacklist_sprite_func(z))
|
if (blacklist_sprite_func && blacklist_sprite_func(z))
|
||||||
continue;
|
continue;
|
||||||
|
@ -12265,7 +12244,7 @@ void getzrange(const vec3_t *pos, int16_t sectnum,
|
||||||
int32_t mcf=-1;
|
int32_t mcf=-1;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
spritetype *curspr=NULL; // non-NULL when handling sprite with sector-like clipping
|
uspritetype *curspr=NULL; // non-NULL when handling sprite with sector-like clipping
|
||||||
int32_t curidx=-1, clipspritecnt = 0;
|
int32_t curidx=-1, clipspritecnt = 0;
|
||||||
|
|
||||||
//Extra walldist for sprites on sector lines
|
//Extra walldist for sprites on sector lines
|
||||||
|
@ -12307,7 +12286,7 @@ restart_grand:
|
||||||
{
|
{
|
||||||
// one set of clip-sprite sectors completed, prepare the next
|
// one set of clip-sprite sectors completed, prepare the next
|
||||||
|
|
||||||
curspr = &sprite[clipspritelist[clipspritecnt]];
|
curspr = (uspritetype *)&sprite[clipspritelist[clipspritecnt]];
|
||||||
curidx = clipshape_idx_for_sprite(curspr, curidx);
|
curidx = clipshape_idx_for_sprite(curspr, curidx);
|
||||||
|
|
||||||
if (curidx < 0)
|
if (curidx < 0)
|
||||||
|
@ -12329,7 +12308,7 @@ restart_grand:
|
||||||
int32_t fz, cz;
|
int32_t fz, cz;
|
||||||
getzsofslope(k,pos->x,pos->y,&daz,&daz2);
|
getzsofslope(k,pos->x,pos->y,&daz,&daz2);
|
||||||
getzsofslope(sectq[clipinfo[curidx].qend],pos->x,pos->y,&cz,&fz);
|
getzsofslope(sectq[clipinfo[curidx].qend],pos->x,pos->y,&cz,&fz);
|
||||||
const int hitwhat = (curspr-sprite)+49152;
|
const int hitwhat = (curspr-(uspritetype *)sprite)+49152;
|
||||||
|
|
||||||
if ((sector[k].ceilingstat&1)==0)
|
if ((sector[k].ceilingstat&1)==0)
|
||||||
{
|
{
|
||||||
|
@ -12413,7 +12392,7 @@ restart_grand:
|
||||||
#ifdef HAVE_CLIPSHAPE_FEATURE
|
#ifdef HAVE_CLIPSHAPE_FEATURE
|
||||||
if (curspr)
|
if (curspr)
|
||||||
{
|
{
|
||||||
int32_t fz,cz, hitwhat=(curspr-sprite)+49152;
|
int32_t fz,cz, hitwhat=(curspr-(uspritetype *)sprite)+49152;
|
||||||
getzsofslope(sectq[clipinfo[curidx].qend],pos->x,pos->y,&cz,&fz);
|
getzsofslope(sectq[clipinfo[curidx].qend],pos->x,pos->y,&cz,&fz);
|
||||||
|
|
||||||
if ((sec->ceilingstat&1)==0)
|
if ((sec->ceilingstat&1)==0)
|
||||||
|
@ -12476,7 +12455,7 @@ restart_grand:
|
||||||
int32_t clipyou = 0;
|
int32_t clipyou = 0;
|
||||||
|
|
||||||
#ifdef HAVE_CLIPSHAPE_FEATURE
|
#ifdef HAVE_CLIPSHAPE_FEATURE
|
||||||
if (clipsprite_try(&sprite[j], xmin,ymin, xmax,ymax))
|
if (clipsprite_try((uspritetype *)&sprite[j], xmin,ymin, xmax,ymax))
|
||||||
continue;
|
continue;
|
||||||
#endif
|
#endif
|
||||||
x1 = sprite[j].x; y1 = sprite[j].y;
|
x1 = sprite[j].x; y1 = sprite[j].y;
|
||||||
|
@ -12497,7 +12476,7 @@ restart_grand:
|
||||||
|
|
||||||
case 16:
|
case 16:
|
||||||
{
|
{
|
||||||
get_wallspr_points(&sprite[j], &x1, &x2, &y1, &y2);
|
get_wallspr_points((uspritetype *)&sprite[j], &x1, &x2, &y1, &y2);
|
||||||
|
|
||||||
if (clipinsideboxline(pos->x,pos->y,x1,y1,x2,y2,walldist+1) != 0)
|
if (clipinsideboxline(pos->x,pos->y,x1,y1,x2,y2,walldist+1) != 0)
|
||||||
{
|
{
|
||||||
|
@ -12710,10 +12689,10 @@ void setview(int32_t x1, int32_t y1, int32_t x2, int32_t y2)
|
||||||
{
|
{
|
||||||
int32_t i;
|
int32_t i;
|
||||||
|
|
||||||
windowx1 = x1; wx1 = (x1<<12);
|
windowxy1.x = x1; wx1 = (x1<<12);
|
||||||
windowy1 = y1; wy1 = (y1<<12);
|
windowxy1.y = y1; wy1 = (y1<<12);
|
||||||
windowx2 = x2; wx2 = ((x2+1)<<12);
|
windowxy2.x = x2; wx2 = ((x2+1)<<12);
|
||||||
windowy2 = y2; wy2 = ((y2+1)<<12);
|
windowxy2.y = y2; wy2 = ((y2+1)<<12);
|
||||||
|
|
||||||
xdimen = (x2-x1)+1; halfxdimen = (xdimen>>1);
|
xdimen = (x2-x1)+1; halfxdimen = (xdimen>>1);
|
||||||
xdimenrecip = divscale32(1L,xdimen);
|
xdimenrecip = divscale32(1L,xdimen);
|
||||||
|
@ -12725,11 +12704,11 @@ void setview(int32_t x1, int32_t y1, int32_t x2, int32_t y2)
|
||||||
#endif
|
#endif
|
||||||
setaspect_new();
|
setaspect_new();
|
||||||
|
|
||||||
for (i=0; i<windowx1; i++) { startumost[i] = 1, startdmost[i] = 0; }
|
for (i=0; i<windowxy1.x; i++) { startumost[i] = 1, startdmost[i] = 0; }
|
||||||
Bassert(windowx2 < xdim); // xdim is the number of alloc'd elements in start*most[].
|
Bassert(windowxy2.x < xdim); // xdim is the number of alloc'd elements in start*most[].
|
||||||
for (i=windowx1; i<=windowx2; i++)
|
for (i=windowxy1.x; i<=windowxy2.x; i++)
|
||||||
{ startumost[i] = windowy1, startdmost[i] = windowy2+1; }
|
{ startumost[i] = windowxy1.y, startdmost[i] = windowxy2.y+1; }
|
||||||
for (i=windowx2+1; i<xdim; i++) { startumost[i] = 1, startdmost[i] = 0; }
|
for (i=windowxy2.x+1; i<xdim; i++) { startumost[i] = 1, startdmost[i] = 0; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -12881,10 +12860,10 @@ void clearview(int32_t dacol)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
begindrawing(); //{{{
|
begindrawing(); //{{{
|
||||||
dx = windowx2-windowx1+1;
|
dx = windowxy2.x-windowxy1.x+1;
|
||||||
//dacol += (dacol<<8); dacol += (dacol<<16);
|
//dacol += (dacol<<8); dacol += (dacol<<16);
|
||||||
p = frameplace+ylookup[windowy1]+windowx1;
|
p = frameplace+ylookup[windowxy1.y]+windowxy1.x;
|
||||||
for (y=windowy1; y<=windowy2; y++)
|
for (y=windowxy1.y; y<=windowxy2.y; y++)
|
||||||
{
|
{
|
||||||
//clearbufbyte((void*)p,dx,dacol);
|
//clearbufbyte((void*)p,dx,dacol);
|
||||||
Bmemset((void *)p,dacol,dx);
|
Bmemset((void *)p,dacol,dx);
|
||||||
|
@ -12939,8 +12918,8 @@ void setviewtotile(int16_t tilenume, int32_t xsiz, int32_t ysiz)
|
||||||
tilesiz[tilenume].x = xsiz; tilesiz[tilenume].y = ysiz;
|
tilesiz[tilenume].x = xsiz; tilesiz[tilenume].y = ysiz;
|
||||||
bakxsiz[setviewcnt] = xsiz; bakysiz[setviewcnt] = ysiz;
|
bakxsiz[setviewcnt] = xsiz; bakysiz[setviewcnt] = ysiz;
|
||||||
bakframeplace[setviewcnt] = frameplace; frameplace = waloff[tilenume];
|
bakframeplace[setviewcnt] = frameplace; frameplace = waloff[tilenume];
|
||||||
bakwindowx1[setviewcnt] = windowx1; bakwindowy1[setviewcnt] = windowy1;
|
bakwindowx1[setviewcnt] = windowxy1.x; bakwindowy1[setviewcnt] = windowxy1.y;
|
||||||
bakwindowx2[setviewcnt] = windowx2; bakwindowy2[setviewcnt] = windowy2;
|
bakwindowx2[setviewcnt] = windowxy2.x; bakwindowy2[setviewcnt] = windowxy2.y;
|
||||||
|
|
||||||
if (setviewcnt == 0)
|
if (setviewcnt == 0)
|
||||||
{
|
{
|
||||||
|
@ -12954,8 +12933,8 @@ void setviewtotile(int16_t tilenume, int32_t xsiz, int32_t ysiz)
|
||||||
rendmode = REND_CLASSIC;
|
rendmode = REND_CLASSIC;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
copybufbyte(&startumost[windowx1],&bakumost[windowx1],(windowx2-windowx1+1)*sizeof(bakumost[0]));
|
copybufbyte(&startumost[windowxy1.x],&bakumost[windowxy1.x],(windowxy2.x-windowxy1.x+1)*sizeof(bakumost[0]));
|
||||||
copybufbyte(&startdmost[windowx1],&bakdmost[windowx1],(windowx2-windowx1+1)*sizeof(bakdmost[0]));
|
copybufbyte(&startdmost[windowxy1.x],&bakdmost[windowxy1.x],(windowxy2.x-windowxy1.x+1)*sizeof(bakdmost[0]));
|
||||||
setviewcnt++;
|
setviewcnt++;
|
||||||
|
|
||||||
offscreenrendering = 1;
|
offscreenrendering = 1;
|
||||||
|
@ -12985,8 +12964,8 @@ void setviewback(void)
|
||||||
|
|
||||||
setview(bakwindowx1[setviewcnt],bakwindowy1[setviewcnt],
|
setview(bakwindowx1[setviewcnt],bakwindowy1[setviewcnt],
|
||||||
bakwindowx2[setviewcnt],bakwindowy2[setviewcnt]);
|
bakwindowx2[setviewcnt],bakwindowy2[setviewcnt]);
|
||||||
copybufbyte(&bakumost[windowx1],&startumost[windowx1],(windowx2-windowx1+1)*sizeof(startumost[0]));
|
copybufbyte(&bakumost[windowxy1.x],&startumost[windowxy1.x],(windowxy2.x-windowxy1.x+1)*sizeof(startumost[0]));
|
||||||
copybufbyte(&bakdmost[windowx1],&startdmost[windowx1],(windowx2-windowx1+1)*sizeof(startdmost[0]));
|
copybufbyte(&bakdmost[windowxy1.x],&startdmost[windowxy1.x],(windowxy2.x-windowxy1.x+1)*sizeof(startdmost[0]));
|
||||||
frameplace = bakframeplace[setviewcnt];
|
frameplace = bakframeplace[setviewcnt];
|
||||||
|
|
||||||
calc_ylookup(bytesperline,
|
calc_ylookup(bytesperline,
|
||||||
|
@ -13088,11 +13067,11 @@ void completemirror(void)
|
||||||
const int32_t height = mirrorsy2-mirrorsy1;
|
const int32_t height = mirrorsy2-mirrorsy1;
|
||||||
|
|
||||||
// Address of the mirror wall's top left corner in the source scene:
|
// Address of the mirror wall's top left corner in the source scene:
|
||||||
intptr_t p = frameplace + ylookup[windowy1+mirrorsy1] + windowx1+mirrorsx1;
|
intptr_t p = frameplace + ylookup[windowxy1.y+mirrorsy1] + windowxy1.x+mirrorsx1;
|
||||||
|
|
||||||
// Offset (wrt p) of a mirror line's left corner in the destination:
|
// Offset (wrt p) of a mirror line's left corner in the destination:
|
||||||
// p+destof == frameplace + ylookup[...] + windowx2-mirrorsx2
|
// p+destof == frameplace + ylookup[...] + windowx2-mirrorsx2
|
||||||
const int32_t destofs = windowx2-mirrorsx2-windowx1-mirrorsx1;
|
const int32_t destofs = windowxy2.x-mirrorsx2-windowxy1.x-mirrorsx1;
|
||||||
|
|
||||||
for (int y=0; y<height; y++)
|
for (int y=0; y<height; y++)
|
||||||
{
|
{
|
||||||
|
@ -13131,7 +13110,7 @@ static int32_t sectorofwall_internal(int16_t theline)
|
||||||
|
|
||||||
int32_t sectorofwall(int16_t theline)
|
int32_t sectorofwall(int16_t theline)
|
||||||
{
|
{
|
||||||
if (theline < 0 || theline >= numwalls)
|
if ((unsigned)theline >= (unsigned)numwalls)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
int i = wall[theline].nextwall;
|
int i = wall[theline].nextwall;
|
||||||
|
@ -13143,7 +13122,7 @@ int32_t sectorofwall(int16_t theline)
|
||||||
|
|
||||||
int32_t sectorofwall_noquick(int16_t theline)
|
int32_t sectorofwall_noquick(int16_t theline)
|
||||||
{
|
{
|
||||||
if ((unsigned)theline >= numwalls)
|
if ((unsigned)theline >= (unsigned)numwalls)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
return sectorofwall_internal(theline);
|
return sectorofwall_internal(theline);
|
||||||
|
@ -13158,7 +13137,7 @@ int32_t getceilzofslopeptr(const sectortype *sec, int32_t dax, int32_t day)
|
||||||
uwalltype const *wal = (uwalltype *)&wall[sec->wallptr];
|
uwalltype const *wal = (uwalltype *)&wall[sec->wallptr];
|
||||||
|
|
||||||
// floor(sqrt(2**31-1)) == 46340
|
// floor(sqrt(2**31-1)) == 46340
|
||||||
vec2_t const w = *(vec2_t *) wal;
|
vec2_t const w = *(vec2_t const *)wal;
|
||||||
vec2_t const d ={ wall[wal->point2].x-w.x , wall[wal->point2].y-w.y };
|
vec2_t const d ={ wall[wal->point2].x-w.x , wall[wal->point2].y-w.y };
|
||||||
|
|
||||||
int32_t const i = nsqrtasm(uhypsq(d.x,d.y))<<5;
|
int32_t const i = nsqrtasm(uhypsq(d.x,d.y))<<5;
|
||||||
|
@ -13175,7 +13154,7 @@ int32_t getflorzofslopeptr(const sectortype *sec, int32_t dax, int32_t day)
|
||||||
|
|
||||||
uwalltype const *wal = (uwalltype *) &wall[sec->wallptr];
|
uwalltype const *wal = (uwalltype *) &wall[sec->wallptr];
|
||||||
|
|
||||||
vec2_t const w = *(vec2_t *) wal;
|
vec2_t const w = *(vec2_t const *)wal;
|
||||||
vec2_t const d ={ wall[wal->point2].x-w.x , wall[wal->point2].y-w.y };
|
vec2_t const d ={ wall[wal->point2].x-w.x , wall[wal->point2].y-w.y };
|
||||||
|
|
||||||
int32_t const i = nsqrtasm(uhypsq(d.x,d.y))<<5;
|
int32_t const i = nsqrtasm(uhypsq(d.x,d.y))<<5;
|
||||||
|
@ -13344,7 +13323,6 @@ void setfirstwall(int16_t sectnum, int16_t newfirstwall)
|
||||||
wall[wall[i].nextwall].nextwall = i;
|
wall[wall[i].nextwall].nextwall = i;
|
||||||
|
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
{
|
|
||||||
int16_t cb, fb;
|
int16_t cb, fb;
|
||||||
yax_getbunches(sectnum, &cb, &fb);
|
yax_getbunches(sectnum, &cb, &fb);
|
||||||
|
|
||||||
|
@ -13361,7 +13339,6 @@ void setfirstwall(int16_t sectnum, int16_t newfirstwall)
|
||||||
yax_setnextwall(j, YAX_CEILING, i);
|
yax_setnextwall(j, YAX_CEILING, i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
Bfree(tmpwall);
|
Bfree(tmpwall);
|
||||||
|
|
|
@ -316,9 +316,9 @@ void calc_and_apply_fog(int32_t tile, int32_t shade, int32_t vis, int32_t pal);
|
||||||
void calc_and_apply_fog_factor(int32_t tile, int32_t shade, int32_t vis, int32_t pal, float factor);
|
void calc_and_apply_fog_factor(int32_t tile, int32_t shade, int32_t vis, int32_t pal, float factor);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern void get_wallspr_points(const spritetype *spr, int32_t *x1, int32_t *x2,
|
extern void get_wallspr_points(uspritetype const * const spr, int32_t *x1, int32_t *x2,
|
||||||
int32_t *y1, int32_t *y2);
|
int32_t *y1, int32_t *y2);
|
||||||
extern void get_floorspr_points(const uspritetype *spr, int32_t px, int32_t py,
|
extern void get_floorspr_points(uspritetype const * const spr, int32_t px, int32_t py,
|
||||||
int32_t *x1, int32_t *x2, int32_t *x3, int32_t *x4,
|
int32_t *x1, int32_t *x2, int32_t *x3, int32_t *x4,
|
||||||
int32_t *y1, int32_t *y2, int32_t *y3, int32_t *y4);
|
int32_t *y1, int32_t *y2, int32_t *y3, int32_t *y4);
|
||||||
|
|
||||||
|
|
|
@ -917,8 +917,8 @@ void polymer_setaspect(int32_t ang)
|
||||||
if (pr_customaspect != 0.0f)
|
if (pr_customaspect != 0.0f)
|
||||||
aspect = pr_customaspect;
|
aspect = pr_customaspect;
|
||||||
else
|
else
|
||||||
aspect = (float)(windowx2-windowx1+1) /
|
aspect = (float)(windowxy2.x-windowxy1.x+1) /
|
||||||
(float)(windowy2-windowy1+1);
|
(float)(windowxy2.y-windowxy1.y+1);
|
||||||
|
|
||||||
bglMatrixMode(GL_PROJECTION);
|
bglMatrixMode(GL_PROJECTION);
|
||||||
bglLoadIdentity();
|
bglLoadIdentity();
|
||||||
|
@ -930,7 +930,7 @@ void polymer_glinit(void)
|
||||||
bglClearColor(0.0f, 0.0f, 0.0f, 1.0f);
|
bglClearColor(0.0f, 0.0f, 0.0f, 1.0f);
|
||||||
bglClearStencil(0);
|
bglClearStencil(0);
|
||||||
bglClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT | GL_STENCIL_BUFFER_BIT);
|
bglClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT | GL_STENCIL_BUFFER_BIT);
|
||||||
bglViewport(windowx1, yres-(windowy2+1),windowx2-windowx1+1, windowy2-windowy1+1);
|
bglViewport(windowxy1.x, yres-(windowxy2.y+1),windowxy2.x-windowxy1.x+1, windowxy2.y-windowxy1.y+1);
|
||||||
|
|
||||||
// texturing
|
// texturing
|
||||||
bglEnable(GL_TEXTURE_2D);
|
bglEnable(GL_TEXTURE_2D);
|
||||||
|
@ -2033,7 +2033,7 @@ static void polymer_displayrooms(const int16_t dacursectnum)
|
||||||
{
|
{
|
||||||
bglBindFramebufferEXT(GL_FRAMEBUFFER_EXT, prrts[0].fbo);
|
bglBindFramebufferEXT(GL_FRAMEBUFFER_EXT, prrts[0].fbo);
|
||||||
bglPushAttrib(GL_VIEWPORT_BIT);
|
bglPushAttrib(GL_VIEWPORT_BIT);
|
||||||
bglViewport(windowx1, yres-(windowy2+1),windowx2-windowx1+1, windowy2-windowy1+1);
|
bglViewport(windowxy1.x, yres-(windowxy2.y+1),windowxy2.x-windowxy1.x+1, windowxy2.y-windowxy1.y+1);
|
||||||
|
|
||||||
bglClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
bglClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||||
|
|
||||||
|
|
|
@ -570,19 +570,19 @@ static void resizeglcheck(void)
|
||||||
bglPolygonMode(GL_FRONT_AND_BACK,GL_FILL);
|
bglPolygonMode(GL_FRONT_AND_BACK,GL_FILL);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if ((glox1 != windowx1) || (gloy1 != windowy1) || (glox2 != windowx2) || (gloy2 != windowy2))
|
if ((glox1 != windowxy1.x) || (gloy1 != windowxy1.y) || (glox2 != windowxy2.x) || (gloy2 != windowxy2.y))
|
||||||
{
|
{
|
||||||
const int32_t ourxdimen = (windowx2-windowx1+1);
|
const int32_t ourxdimen = (windowxy2.x-windowxy1.x+1);
|
||||||
float ratio = get_projhack_ratio();
|
float ratio = get_projhack_ratio();
|
||||||
const int32_t fovcorrect = (int32_t)(ourxdimen*ratio - ourxdimen);
|
const int32_t fovcorrect = (int32_t)(ourxdimen*ratio - ourxdimen);
|
||||||
|
|
||||||
ratio = 1.f/ratio;
|
ratio = 1.f/ratio;
|
||||||
|
|
||||||
glox1 = (float)windowx1; gloy1 = (float)windowy1;
|
glox1 = (float)windowxy1.x; gloy1 = (float)windowxy1.y;
|
||||||
glox2 = (float)windowx2; gloy2 = (float)windowy2;
|
glox2 = (float)windowxy2.x; gloy2 = (float)windowxy2.y;
|
||||||
|
|
||||||
bglViewport(windowx1-(fovcorrect/2), yres-(windowy2+1),
|
bglViewport(windowxy1.x-(fovcorrect/2), yres-(windowxy2.y+1),
|
||||||
ourxdimen+fovcorrect, windowy2-windowy1+1);
|
ourxdimen+fovcorrect, windowxy2.y-windowxy1.y+1);
|
||||||
|
|
||||||
bglMatrixMode(GL_PROJECTION);
|
bglMatrixMode(GL_PROJECTION);
|
||||||
|
|
||||||
|
@ -1632,11 +1632,12 @@ static inline pthtyp *our_texcache_fetch(int32_t dameth)
|
||||||
|
|
||||||
static void polymost_drawpoly(vec2f_t const * const dpxy, int32_t const n, int32_t method)
|
static void polymost_drawpoly(vec2f_t const * const dpxy, int32_t const n, int32_t method)
|
||||||
{
|
{
|
||||||
|
if (method == DAMETH_BACKFACECULL ||
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
if (g_nodraw) return;
|
g_nodraw ||
|
||||||
#endif
|
#endif
|
||||||
|
(uint32_t)globalpicnum >= MAXTILES)
|
||||||
if (method == DAMETH_BACKFACECULL || (uint32_t)globalpicnum >= MAXTILES) return;
|
return;
|
||||||
|
|
||||||
const int32_t method_ = method;
|
const int32_t method_ = method;
|
||||||
|
|
||||||
|
@ -1758,10 +1759,10 @@ static void polymost_drawpoly(vec2f_t const * const dpxy, int32_t const n, int32
|
||||||
int32_t texunits = GL_TEXTURE0_ARB;
|
int32_t texunits = GL_TEXTURE0_ARB;
|
||||||
|
|
||||||
// detail texture
|
// detail texture
|
||||||
pthtyp *detailpth = NULL;
|
|
||||||
|
|
||||||
if (r_detailmapping)
|
if (r_detailmapping)
|
||||||
{
|
{
|
||||||
|
pthtyp *detailpth = NULL;
|
||||||
|
|
||||||
if (usehightile && !drawingskybox && hicfindsubst(globalpicnum, DETAILPAL) &&
|
if (usehightile && !drawingskybox && hicfindsubst(globalpicnum, DETAILPAL) &&
|
||||||
(detailpth = texcache_fetch(globalpicnum, DETAILPAL, 0, method & ~DAMETH_MASKPROPS)) &&
|
(detailpth = texcache_fetch(globalpicnum, DETAILPAL, 0, method & ~DAMETH_MASKPROPS)) &&
|
||||||
detailpth->hicr && detailpth->hicr->palnum == DETAILPAL)
|
detailpth->hicr && detailpth->hicr->palnum == DETAILPAL)
|
||||||
|
@ -1782,10 +1783,10 @@ static void polymost_drawpoly(vec2f_t const * const dpxy, int32_t const n, int32
|
||||||
}
|
}
|
||||||
|
|
||||||
// glow texture
|
// glow texture
|
||||||
pthtyp *glowpth = NULL;
|
|
||||||
|
|
||||||
if (r_glowmapping)
|
if (r_glowmapping)
|
||||||
{
|
{
|
||||||
|
pthtyp *glowpth = NULL;
|
||||||
|
|
||||||
if (usehightile && !drawingskybox && hicfindsubst(globalpicnum, GLOWPAL) &&
|
if (usehightile && !drawingskybox && hicfindsubst(globalpicnum, GLOWPAL) &&
|
||||||
(glowpth = texcache_fetch(globalpicnum, GLOWPAL, 0, (method & ~DAMETH_MASKPROPS) | DAMETH_MASK)) &&
|
(glowpth = texcache_fetch(globalpicnum, GLOWPAL, 0, (method & ~DAMETH_MASKPROPS) | DAMETH_MASK)) &&
|
||||||
glowpth->hicr && (glowpth->hicr->palnum == GLOWPAL))
|
glowpth->hicr && (glowpth->hicr->palnum == GLOWPAL))
|
||||||
|
@ -1868,26 +1869,23 @@ static void polymost_drawpoly(vec2f_t const * const dpxy, int32_t const n, int32
|
||||||
|
|
||||||
float const r = 1.f / (opxy[0].x*px[0] + opxy[0].y*px[1] + opxy[0].z*px[2]);
|
float const r = 1.f / (opxy[0].x*px[0] + opxy[0].y*px[1] + opxy[0].z*px[2]);
|
||||||
|
|
||||||
float ngdx = (opxy[0].x*dd[0] + opxy[0].y*dd[1] + opxy[0].z*dd[2])*r,
|
vec3f_t ngx = { (opxy[0].x * dd[0] + opxy[0].y * dd[1] + opxy[0].z * dd[2]) * r,
|
||||||
ngux = (opxy[0].x*uu[0] + opxy[0].y*uu[1] + opxy[0].z*uu[2])*r,
|
((opxy[0].x * uu[0] + opxy[0].y * uu[1] + opxy[0].z * uu[2]) * r) * hacksc.x,
|
||||||
ngvx = (opxy[0].x*vv[0] + opxy[0].y*vv[1] + opxy[0].z*vv[2])*r;
|
((opxy[0].x * vv[0] + opxy[0].y * vv[1] + opxy[0].z * vv[2]) * r) * hacksc.y };
|
||||||
|
|
||||||
float ngdy = (opxy[1].x*dd[0] + opxy[1].y*dd[1] + opxy[1].z*dd[2])*r,
|
vec3f_t ngy = { (opxy[1].x * dd[0] + opxy[1].y * dd[1] + opxy[1].z * dd[2]) * r,
|
||||||
nguy = (opxy[1].x*uu[0] + opxy[1].y*uu[1] + opxy[1].z*uu[2])*r,
|
((opxy[1].x * uu[0] + opxy[1].y * uu[1] + opxy[1].z * uu[2]) * r) * hacksc.x,
|
||||||
ngvy = (opxy[1].x*vv[0] + opxy[1].y*vv[1] + opxy[1].z*vv[2])*r;
|
((opxy[1].x * vv[0] + opxy[1].y * vv[1] + opxy[1].z * vv[2]) * r) * hacksc.y };
|
||||||
|
|
||||||
float ngdo = dd[0] - opxy[2].x * ngdx - opxy[2].y * ngdy,
|
vec3f_t ngo = { dd[0] - opxy[2].x * ngx.d - opxy[2].y * ngy.d,
|
||||||
nguo = uu[0] - opxy[2].x * ngux - opxy[2].y * nguy,
|
(uu[0] - opxy[2].x * ngx.u - opxy[2].y * ngy.u) * hacksc.x,
|
||||||
ngvo = vv[0] - opxy[2].x * ngvx - opxy[2].y * ngvy;
|
(vv[0] - opxy[2].x * ngx.v - opxy[2].y * ngy.v) * hacksc.y };
|
||||||
|
|
||||||
ngux *= hacksc.x; nguy *= hacksc.x; nguo *= hacksc.x;
|
|
||||||
ngvx *= hacksc.y; ngvy *= hacksc.y; ngvo *= hacksc.y;
|
|
||||||
|
|
||||||
float const uoffs = ((float)(tsiz2.x - tsiz.x) * 0.5f);
|
float const uoffs = ((float)(tsiz2.x - tsiz.x) * 0.5f);
|
||||||
|
|
||||||
ngux -= ngdx * uoffs;
|
ngx.u -= ngx.d * uoffs;
|
||||||
nguy -= ngdy * uoffs;
|
ngy.u -= ngy.d * uoffs;
|
||||||
nguo -= ngdo * uoffs;
|
ngo.u -= ngo.d * uoffs;
|
||||||
|
|
||||||
float du0, du1;
|
float du0, du1;
|
||||||
|
|
||||||
|
@ -1895,23 +1893,21 @@ static void polymost_drawpoly(vec2f_t const * const dpxy, int32_t const n, int32
|
||||||
for (int i=0; i<npoints; ++i)
|
for (int i=0; i<npoints; ++i)
|
||||||
{
|
{
|
||||||
vec2f_t const o = { px[i], py[i] };
|
vec2f_t const o = { px[i], py[i] };
|
||||||
float const f = (o.x*ngux + o.y*nguy + nguo) / (o.x*ngdx + o.y*ngdy + ngdo);
|
float const f = (o.x*ngx.u + o.y*ngy.u + ngo.u) / (o.x*ngx.d + o.y*ngy.d + ngo.d);
|
||||||
if (!i) { du0 = du1 = f; continue; }
|
if (!i) { du0 = du1 = f; continue; }
|
||||||
if (f < du0) du0 = f;
|
if (f < du0) du0 = f;
|
||||||
else if (f > du1) du1 = f;
|
else if (f > du1) du1 = f;
|
||||||
}
|
}
|
||||||
|
|
||||||
float const rf = 1.0f / tsiz.x;
|
float const rf = 1.0f / tsiz.x;
|
||||||
|
int const ix1 = (int)floorf(du1 * rf);
|
||||||
|
|
||||||
int32_t ix0 = (int)floorf(du0 * rf);
|
for (int ix0 = (int)floorf(du0 * rf); ix0 <= ix1; ++ix0)
|
||||||
int32_t const ix1 = (int)floorf(du1 * rf);
|
|
||||||
|
|
||||||
for (; ix0<=ix1; ++ix0)
|
|
||||||
{
|
{
|
||||||
du0 = (float)(ix0 * tsiz.x); // + uoffs;
|
du0 = (float)(ix0 * tsiz.x); // + uoffs;
|
||||||
du1 = (float)((ix0 + 1) * tsiz.x); // + uoffs;
|
du1 = (float)((ix0 + 1) * tsiz.x); // + uoffs;
|
||||||
|
|
||||||
float duj = (px[0]*ngux + py[0]*nguy + nguo) / (px[0]*ngdx + py[0]*ngdy + ngdo);
|
float duj = (px[0]*ngx.u + py[0]*ngy.u + ngo.u) / (px[0]*ngx.d + py[0]*ngy.d + ngo.d);
|
||||||
int i = 0, nn = 0;
|
int i = 0, nn = 0;
|
||||||
|
|
||||||
do
|
do
|
||||||
|
@ -1923,7 +1919,7 @@ static void polymost_drawpoly(vec2f_t const * const dpxy, int32_t const n, int32
|
||||||
|
|
||||||
float const dui = duj;
|
float const dui = duj;
|
||||||
|
|
||||||
duj = (px[j]*ngux + py[j]*nguy + nguo) / (px[j]*ngdx + py[j]*ngdy + ngdo);
|
duj = (px[j]*ngx.u + py[j]*ngy.u + ngo.u) / (px[j]*ngx.d + py[j]*ngy.d + ngo.d);
|
||||||
|
|
||||||
if ((du0 <= dui) && (dui <= du1))
|
if ((du0 <= dui) && (dui <= du1))
|
||||||
{
|
{
|
||||||
|
@ -1932,22 +1928,22 @@ static void polymost_drawpoly(vec2f_t const * const dpxy, int32_t const n, int32
|
||||||
nn++;
|
nn++;
|
||||||
}
|
}
|
||||||
|
|
||||||
//ox*(ngux-ngdx*du1) + oy*(nguy-ngdy*du1) + (nguo-ngdo*du1) = 0
|
//ox*(ngx.u-ngx.d*du1) + oy*(ngy.u-ngdy*du1) + (ngo.u-ngo.d*du1) = 0
|
||||||
//(px[j]-px[i])*f + px[i] = ox
|
//(px[j]-px[i])*f + px[i] = ox
|
||||||
//(py[j]-py[i])*f + py[i] = oy
|
//(py[j]-py[i])*f + py[i] = oy
|
||||||
|
|
||||||
///Solve for f
|
///Solve for f
|
||||||
//((px[j]-px[i])*f + px[i])*(ngux-ngdx*du1) +
|
//((px[j]-px[i])*f + px[i])*(ngx.u-ngx.d*du1) +
|
||||||
//((py[j]-py[i])*f + py[i])*(nguy-ngdy*du1) + (nguo-ngdo*du1) = 0
|
//((py[j]-py[i])*f + py[i])*(ngy.u-ngdy*du1) + (ngo.u-ngo.d*du1) = 0
|
||||||
|
|
||||||
#define DRAWPOLY_MATH_BULLSHIT(XXX) \
|
#define DRAWPOLY_MATH_BULLSHIT(XXX) \
|
||||||
do \
|
do \
|
||||||
{ \
|
{ \
|
||||||
float const f = -(px[i] * (ngux - ngdx * XXX) + py[i] * (nguy - ngdy * XXX) + (nguo - ngdo * XXX)) / \
|
float const f = -(px[i] * (ngx.u - ngx.d * XXX) + py[i] * (ngy.u - ngy.d * XXX) + (ngo.u - ngo.d * XXX)) / \
|
||||||
((px[j] - px[i]) * (ngux - ngdx * XXX) + (py[j] - py[i]) * (nguy - ngdy * XXX)); \
|
((px[j] - px[i]) * (ngx.u - ngx.d * XXX) + (py[j] - py[i]) * (ngy.u - ngy.d * XXX)); \
|
||||||
uu[nn] = (px[j] - px[i]) * f + px[i]; \
|
uu[nn] = (px[j] - px[i]) * f + px[i]; \
|
||||||
vv[nn] = (py[j] - py[i]) * f + py[i]; \
|
vv[nn] = (py[j] - py[i]) * f + py[i]; \
|
||||||
nn++; \
|
++nn; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
if (duj <= dui)
|
if (duj <= dui)
|
||||||
|
@ -1969,30 +1965,28 @@ do
|
||||||
|
|
||||||
if (nn < 3) continue;
|
if (nn < 3) continue;
|
||||||
|
|
||||||
vec2f_t const invtsiz2 ={ 1.f / tsiz2.x, 1.f / tsiz2.y };
|
vec2f_t const invtsiz2 = { 1.f / tsiz2.x, 1.f / tsiz2.y };
|
||||||
|
|
||||||
bglBegin(GL_TRIANGLE_FAN);
|
bglBegin(GL_TRIANGLE_FAN);
|
||||||
|
|
||||||
for (i=0; i<nn; i++)
|
for (i=0; i<nn; ++i)
|
||||||
{
|
{
|
||||||
vec2f_t const o = { uu[i], vv[i] };
|
vec2f_t const o = { uu[i], vv[i] };
|
||||||
|
vec3f_t const p = { o.x * ngx.d + o.y * ngy.d + ngo.d,
|
||||||
float const dp = o.x*ngdx + o.y*ngdy + ngdo,
|
o.x * ngx.u + o.y * ngy.u + ngo.u,
|
||||||
up = o.x*ngux + o.y*nguy + nguo,
|
o.x * ngx.v + o.y * ngy.v + ngo.v };
|
||||||
vp = o.x*ngvx + o.y*ngvy + ngvo;
|
float const r = 1.f/p.d;
|
||||||
|
|
||||||
float const r = 1.f/dp;
|
|
||||||
|
|
||||||
#ifdef USE_GLEXT
|
#ifdef USE_GLEXT
|
||||||
if (texunits > GL_TEXTURE0_ARB)
|
if (texunits > GL_TEXTURE0_ARB)
|
||||||
{
|
{
|
||||||
j = GL_TEXTURE0_ARB;
|
j = GL_TEXTURE0_ARB;
|
||||||
while (j <= texunits)
|
while (j <= texunits)
|
||||||
bglMultiTexCoord2fARB(j++, (up * r - du0 + uoffs) * invtsiz2.x, vp * r * invtsiz2.y);
|
bglMultiTexCoord2fARB(j++, (p.u * r - du0 + uoffs) * invtsiz2.x, p.v * r * invtsiz2.y);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
bglTexCoord2f((up * r - du0 + uoffs) * invtsiz2.x, vp * r * invtsiz2.y);
|
bglTexCoord2f((p.u * r - du0 + uoffs) * invtsiz2.x, p.v * r * invtsiz2.y);
|
||||||
|
|
||||||
bglVertex3f((o.x - ghalfx) * r * grhalfxdown10x,
|
bglVertex3f((o.x - ghalfx) * r * grhalfxdown10x,
|
||||||
(ghoriz - o.y) * r * grhalfxdown10,
|
(ghoriz - o.y) * r * grhalfxdown10,
|
||||||
|
@ -2003,11 +1997,11 @@ do
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
vec2f_t const scale ={ 1.f / tsiz2.x * hacksc.x, 1.f / tsiz2.y * hacksc.y };
|
vec2f_t const scale = { 1.f / tsiz2.x * hacksc.x, 1.f / tsiz2.y * hacksc.y };
|
||||||
|
|
||||||
bglBegin(GL_TRIANGLE_FAN);
|
bglBegin(GL_TRIANGLE_FAN);
|
||||||
|
|
||||||
for (int i = 0; i < npoints; i++)
|
for (int i = 0; i < npoints; ++i)
|
||||||
{
|
{
|
||||||
float const r = 1.f / dd[i];
|
float const r = 1.f / dd[i];
|
||||||
|
|
||||||
|
@ -2048,8 +2042,9 @@ do
|
||||||
bglLoadIdentity();
|
bglLoadIdentity();
|
||||||
bglMatrixMode(GL_MODELVIEW);
|
bglMatrixMode(GL_MODELVIEW);
|
||||||
|
|
||||||
if (getrendermode() == REND_POLYMOST)
|
if (getrendermode() != REND_POLYMOST)
|
||||||
{
|
return;
|
||||||
|
|
||||||
int const clamp_mode = glinfo.clamptoedge ? GL_CLAMP_TO_EDGE : GL_CLAMP;
|
int const clamp_mode = glinfo.clamptoedge ? GL_CLAMP_TO_EDGE : GL_CLAMP;
|
||||||
|
|
||||||
if (drawpoly_srepeat)
|
if (drawpoly_srepeat)
|
||||||
|
@ -2057,7 +2052,6 @@ do
|
||||||
|
|
||||||
if (drawpoly_trepeat)
|
if (drawpoly_trepeat)
|
||||||
bglTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, clamp_mode);
|
bglTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, clamp_mode);
|
||||||
}
|
|
||||||
|
|
||||||
if (fullbright_pass == 1)
|
if (fullbright_pass == 1)
|
||||||
{
|
{
|
||||||
|
@ -2085,7 +2079,7 @@ do
|
||||||
|
|
||||||
static inline void vsp_finalize_init(int32_t const vcnt)
|
static inline void vsp_finalize_init(int32_t const vcnt)
|
||||||
{
|
{
|
||||||
for (int i=0; i<vcnt; i++)
|
for (int i=0; i<vcnt; ++i)
|
||||||
{
|
{
|
||||||
vsp[i].cy[1] = vsp[i+1].cy[0]; vsp[i].ctag = i;
|
vsp[i].cy[1] = vsp[i+1].cy[0]; vsp[i].ctag = i;
|
||||||
vsp[i].fy[1] = vsp[i+1].fy[0]; vsp[i].ftag = i;
|
vsp[i].fy[1] = vsp[i+1].fy[0]; vsp[i].ftag = i;
|
||||||
|
@ -2141,7 +2135,7 @@ static int32_t domostpolymethod = DAMETH_NOMASK;
|
||||||
|
|
||||||
static void polymost_domost(float x0, float y0, float x1, float y1)
|
static void polymost_domost(float x0, float y0, float x1, float y1)
|
||||||
{
|
{
|
||||||
int32_t const dir = (x0 < x1);
|
int const dir = (x0 < x1);
|
||||||
|
|
||||||
if (dir) //clip dmost (floor)
|
if (dir) //clip dmost (floor)
|
||||||
{
|
{
|
||||||
|
@ -2215,8 +2209,8 @@ static void polymost_domost(float x0, float y0, float x1, float y1)
|
||||||
//Test if right edge requires split
|
//Test if right edge requires split
|
||||||
if ((dm1.x > n0.x) && (dm1.x < n1.x))
|
if ((dm1.x > n0.x) && (dm1.x < n1.x))
|
||||||
{
|
{
|
||||||
const float t = (dm1.x-n0.x)*cv[dir] - (dm1.y-cy[dir])*dx;
|
float const t = (dm1.x-n0.x)*cv[dir] - (dm1.y-cy[dir])*dx;
|
||||||
if (((!dir) && (t < 0)) || ((dir) && (t > 0)))
|
if (((!dir) && (t < 0.f)) || ((dir) && (t > 0.f)))
|
||||||
{ spx[scnt] = dm1.x; spt[scnt] = -1; scnt++; }
|
{ spx[scnt] = dm1.x; spt[scnt] = -1; scnt++; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3864,7 +3858,7 @@ void polymost_drawrooms()
|
||||||
if (getrendermode() == REND_CLASSIC) return;
|
if (getrendermode() == REND_CLASSIC) return;
|
||||||
|
|
||||||
begindrawing();
|
begindrawing();
|
||||||
frameoffset = frameplace + windowy1*bytesperline + windowx1;
|
frameoffset = frameplace + windowxy1.y*bytesperline + windowxy1.x;
|
||||||
|
|
||||||
resizeglcheck();
|
resizeglcheck();
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
|
@ -3889,14 +3883,14 @@ void polymost_drawrooms()
|
||||||
if (redblueclearcnt < numpages) { redblueclearcnt++; bglColorMask(1,1,1,1); bglClear(GL_COLOR_BUFFER_BIT); }
|
if (redblueclearcnt < numpages) { redblueclearcnt++; bglColorMask(1,1,1,1); bglClear(GL_COLOR_BUFFER_BIT); }
|
||||||
if (grbfcnt&1)
|
if (grbfcnt&1)
|
||||||
{
|
{
|
||||||
bglViewport(windowx1-16,yres-(windowy2+1),windowx2-(windowx1-16)+1,windowy2-windowy1+1);
|
bglViewport(windowxy1.x-16,yres-(windowxy2.y+1),windowxy2.x-(windowxy1.x-16)+1,windowxy2.y-windowxy1.y+1);
|
||||||
bglColorMask(1,0,0,1);
|
bglColorMask(1,0,0,1);
|
||||||
globalposx += singlobalang>>10;
|
globalposx += singlobalang>>10;
|
||||||
globalposy -= cosglobalang>>10;
|
globalposy -= cosglobalang>>10;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bglViewport(windowx1,yres-(windowy2+1),windowx2+16-windowx1+1,windowy2-windowy1+1);
|
bglViewport(windowxy1.x,yres-(windowxy2.y+1),windowxy2.x+16-windowxy1.x+1,windowxy2.y-windowxy1.y+1);
|
||||||
bglColorMask(0,1,1,1);
|
bglColorMask(0,1,1,1);
|
||||||
globalposx -= singlobalang>>10;
|
globalposx -= singlobalang>>10;
|
||||||
globalposy += cosglobalang>>10;
|
globalposy += cosglobalang>>10;
|
||||||
|
@ -3943,9 +3937,9 @@ void polymost_drawrooms()
|
||||||
|
|
||||||
//Generate viewport trapezoid (for handling screen up/down)
|
//Generate viewport trapezoid (for handling screen up/down)
|
||||||
vec3f_t p[4] = { { 0-1, 0-1, 0 },
|
vec3f_t p[4] = { { 0-1, 0-1, 0 },
|
||||||
{ (float)(windowx2 + 1 - windowx1 + 2), 0-1, 0 },
|
{ (float)(windowxy2.x + 1 - windowxy1.x + 2), 0-1, 0 },
|
||||||
{ (float)(windowx2 + 1 - windowx1 + 2), (float)(windowy2 + 1 - windowy1 + 2), 0 },
|
{ (float)(windowxy2.x + 1 - windowxy1.x + 2), (float)(windowxy2.y + 1 - windowxy1.y + 2), 0 },
|
||||||
{ 0-1, (float)(windowy2 + 1 - windowy1 + 2), 0 } };
|
{ 0-1, (float)(windowxy2.y + 1 - windowxy1.y + 2), 0 } };
|
||||||
|
|
||||||
for (int i=0; i<4; i++)
|
for (int i=0; i<4; i++)
|
||||||
{
|
{
|
||||||
|
@ -5070,7 +5064,7 @@ void polymost_dorotatespritemodel(int32_t sx, int32_t sy, int32_t z, int16_t a,
|
||||||
tspr.cstat = globalorientation = (dastat&RS_TRANS1) | ((dastat&RS_TRANS2)<<4) | ((dastat&RS_YFLIP)<<1);
|
tspr.cstat = globalorientation = (dastat&RS_TRANS1) | ((dastat&RS_TRANS2)<<4) | ((dastat&RS_YFLIP)<<1);
|
||||||
|
|
||||||
if ((dastat&(RS_AUTO|RS_NOCLIP)) == RS_AUTO)
|
if ((dastat&(RS_AUTO|RS_NOCLIP)) == RS_AUTO)
|
||||||
bglViewport(windowx1, yres-(windowy2+1), windowx2-windowx1+1, windowy2-windowy1+1);
|
bglViewport(windowxy1.x, yres-(windowxy2.y+1), windowxy2.x-windowxy1.x+1, windowxy2.y-windowxy1.y+1);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bglViewport(0, 0, xdim, ydim);
|
bglViewport(0, 0, xdim, ydim);
|
||||||
|
|
|
@ -339,10 +339,10 @@ int32_t G_ToggleWallInterpolation(int32_t w, int32_t doset);
|
||||||
# define ACTOR_INLINE_HEADER EXTERN_INLINE_HEADER
|
# define ACTOR_INLINE_HEADER EXTERN_INLINE_HEADER
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern int32_t A_MoveSpriteClipdist(int32_t spritenum, const vec3_t *change, uint32_t cliptype, int32_t clipdist);
|
extern int32_t A_MoveSpriteClipdist(int32_t spritenum, vec3_t const * const change, uint32_t cliptype, int32_t clipdist);
|
||||||
ACTOR_INLINE_HEADER int A_CheckEnemyTile(int32_t pn);
|
ACTOR_INLINE_HEADER int A_CheckEnemyTile(int32_t pn);
|
||||||
ACTOR_INLINE_HEADER int32_t A_SetSprite(int32_t i,uint32_t cliptype);
|
ACTOR_INLINE_HEADER int32_t A_SetSprite(int32_t i,uint32_t cliptype);
|
||||||
ACTOR_INLINE_HEADER int32_t A_MoveSprite(int32_t spritenum, const vec3_t *change, uint32_t cliptype);
|
ACTOR_INLINE_HEADER int32_t A_MoveSprite(int32_t spritenum, vec3_t const * const change, uint32_t cliptype);
|
||||||
|
|
||||||
EXTERN_INLINE_HEADER int32_t G_CheckForSpaceCeiling(int32_t sectnum);
|
EXTERN_INLINE_HEADER int32_t G_CheckForSpaceCeiling(int32_t sectnum);
|
||||||
EXTERN_INLINE_HEADER int32_t G_CheckForSpaceFloor(int32_t sectnum);
|
EXTERN_INLINE_HEADER int32_t G_CheckForSpaceFloor(int32_t sectnum);
|
||||||
|
@ -371,7 +371,7 @@ ACTOR_INLINE int32_t A_SetSprite(int32_t i,uint32_t cliptype)
|
||||||
return (A_MoveSprite(i,&davect,cliptype)==0);
|
return (A_MoveSprite(i,&davect,cliptype)==0);
|
||||||
}
|
}
|
||||||
|
|
||||||
ACTOR_INLINE int32_t A_MoveSprite(int32_t spritenum, const vec3_t *change, uint32_t cliptype)
|
ACTOR_INLINE int32_t A_MoveSprite(int32_t spritenum, vec3_t const * const change, uint32_t cliptype)
|
||||||
{
|
{
|
||||||
return A_MoveSpriteClipdist(spritenum, change, cliptype, -1);
|
return A_MoveSpriteClipdist(spritenum, change, cliptype, -1);
|
||||||
}
|
}
|
||||||
|
|
|
@ -5425,8 +5425,8 @@ static void Keys3d(void)
|
||||||
int32_t x = (xdim <= 640);
|
int32_t x = (xdim <= 640);
|
||||||
int32_t chars = Bsprintf(tempbuf, "%2u ms (%3u fps)", howlong, LastCount);
|
int32_t chars = Bsprintf(tempbuf, "%2u ms (%3u fps)", howlong, LastCount);
|
||||||
|
|
||||||
int32_t const dax = m32_is2d3dmode() ? m32_2d3d.x + XSIZE_2D3D - 3: windowx2;
|
int32_t const dax = m32_is2d3dmode() ? m32_2d3d.x + XSIZE_2D3D - 3: windowxy2.x;
|
||||||
int32_t const day = m32_is2d3dmode() ? m32_2d3d.y + 4 : windowy1;
|
int32_t const day = m32_is2d3dmode() ? m32_2d3d.y + 4 : windowxy1.y;
|
||||||
|
|
||||||
if (!x)
|
if (!x)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1062,18 +1062,18 @@ void G_DrawRooms(int32_t snum, int32_t smoothratio)
|
||||||
{
|
{
|
||||||
begindrawing();
|
begindrawing();
|
||||||
{
|
{
|
||||||
const int32_t height = windowy2-windowy1+1;
|
const int32_t height = windowxy2.y-windowxy1.y+1;
|
||||||
const int32_t width = windowx2-windowx1+1;
|
const int32_t width = windowxy2.x-windowxy1.x+1;
|
||||||
|
|
||||||
uint8_t *f = (uint8_t *)(frameplace + ylookup[windowy1]);
|
uint8_t *f = (uint8_t *)(frameplace + ylookup[windowxy1.y]);
|
||||||
int32_t x, y;
|
int32_t x, y;
|
||||||
|
|
||||||
for (y=0; y < (height>>1); y++)
|
for (y=0; y < (height>>1); y++)
|
||||||
swapbufreverse(f + y*bytesperline + windowx2,
|
swapbufreverse(f + y*bytesperline + windowxy2.x,
|
||||||
f + (height-1-y)*bytesperline + windowx1,
|
f + (height-1-y)*bytesperline + windowxy1.x,
|
||||||
width);
|
width);
|
||||||
|
|
||||||
f += (height>>1)*bytesperline + windowx1;
|
f += (height>>1)*bytesperline + windowxy1.x;
|
||||||
|
|
||||||
if (height&1)
|
if (height&1)
|
||||||
for (x=0; x<(width>>1); x++)
|
for (x=0; x<(width>>1); x++)
|
||||||
|
|
|
@ -1661,10 +1661,10 @@ static void Gv_AddSystemVars(void)
|
||||||
Gv_NewVar("looking_angSR1",(intptr_t)&hudweap.lookhalfang, GAMEVAR_INTPTR | GAMEVAR_SYSTEM);
|
Gv_NewVar("looking_angSR1",(intptr_t)&hudweap.lookhalfang, GAMEVAR_INTPTR | GAMEVAR_SYSTEM);
|
||||||
Gv_NewVar("xdim",(intptr_t)&xdim, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("xdim",(intptr_t)&xdim, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("ydim",(intptr_t)&ydim, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("ydim",(intptr_t)&ydim, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("windowx1",(intptr_t)&windowx1, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("windowx1",(intptr_t)&windowxy1.x, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("windowx2",(intptr_t)&windowx2, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("windowx2",(intptr_t)&windowxy2.x, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("windowy1",(intptr_t)&windowy1, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("windowy1",(intptr_t)&windowxy1.y, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("windowy2",(intptr_t)&windowy2, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("windowy2",(intptr_t)&windowxy2.y, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("totalclock",(intptr_t)&totalclock, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("totalclock",(intptr_t)&totalclock, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("lastvisinc",(intptr_t)&lastvisinc, GAMEVAR_SYSTEM | GAMEVAR_INTPTR);
|
Gv_NewVar("lastvisinc",(intptr_t)&lastvisinc, GAMEVAR_SYSTEM | GAMEVAR_INTPTR);
|
||||||
Gv_NewVar("numsectors",(intptr_t)&numsectors, GAMEVAR_SYSTEM | GAMEVAR_SHORTPTR | GAMEVAR_READONLY);
|
Gv_NewVar("numsectors",(intptr_t)&numsectors, GAMEVAR_SYSTEM | GAMEVAR_SHORTPTR | GAMEVAR_READONLY);
|
||||||
|
@ -1839,10 +1839,10 @@ void Gv_RefreshPointers(void)
|
||||||
aGameVars[Gv_GetVarIndex("looking_angSR1")].val.lValue = (intptr_t)&hudweap.lookhalfang;
|
aGameVars[Gv_GetVarIndex("looking_angSR1")].val.lValue = (intptr_t)&hudweap.lookhalfang;
|
||||||
aGameVars[Gv_GetVarIndex("xdim")].val.lValue = (intptr_t)&xdim;
|
aGameVars[Gv_GetVarIndex("xdim")].val.lValue = (intptr_t)&xdim;
|
||||||
aGameVars[Gv_GetVarIndex("ydim")].val.lValue = (intptr_t)&ydim;
|
aGameVars[Gv_GetVarIndex("ydim")].val.lValue = (intptr_t)&ydim;
|
||||||
aGameVars[Gv_GetVarIndex("windowx1")].val.lValue = (intptr_t)&windowx1;
|
aGameVars[Gv_GetVarIndex("windowx1")].val.lValue = (intptr_t)&windowxy1.x;
|
||||||
aGameVars[Gv_GetVarIndex("windowx2")].val.lValue = (intptr_t)&windowx2;
|
aGameVars[Gv_GetVarIndex("windowx2")].val.lValue = (intptr_t)&windowxy2.x;
|
||||||
aGameVars[Gv_GetVarIndex("windowy1")].val.lValue = (intptr_t)&windowy1;
|
aGameVars[Gv_GetVarIndex("windowy1")].val.lValue = (intptr_t)&windowxy1.y;
|
||||||
aGameVars[Gv_GetVarIndex("windowy2")].val.lValue = (intptr_t)&windowy2;
|
aGameVars[Gv_GetVarIndex("windowy2")].val.lValue = (intptr_t)&windowxy2.y;
|
||||||
aGameVars[Gv_GetVarIndex("totalclock")].val.lValue = (intptr_t)&totalclock;
|
aGameVars[Gv_GetVarIndex("totalclock")].val.lValue = (intptr_t)&totalclock;
|
||||||
aGameVars[Gv_GetVarIndex("lastvisinc")].val.lValue = (intptr_t)&lastvisinc;
|
aGameVars[Gv_GetVarIndex("lastvisinc")].val.lValue = (intptr_t)&lastvisinc;
|
||||||
aGameVars[Gv_GetVarIndex("numsectors")].val.lValue = (intptr_t)&numsectors;
|
aGameVars[Gv_GetVarIndex("numsectors")].val.lValue = (intptr_t)&numsectors;
|
||||||
|
|
|
@ -537,10 +537,10 @@ static void Gv_AddSystemVars(void)
|
||||||
|
|
||||||
Gv_NewVar("xdim",(intptr_t)&xdim, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("xdim",(intptr_t)&xdim, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("ydim",(intptr_t)&ydim, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("ydim",(intptr_t)&ydim, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("windowx1",(intptr_t)&windowx1, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("windowx1",(intptr_t)&windowxy1.x, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("windowx2",(intptr_t)&windowx2, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("windowx2",(intptr_t)&windowxy2.x, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("windowy1",(intptr_t)&windowy1, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("windowy1",(intptr_t)&windowxy1.y, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("windowy2",(intptr_t)&windowy2, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("windowy2",(intptr_t)&windowxy2.y, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
Gv_NewVar("totalclock",(intptr_t)&totalclock, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
Gv_NewVar("totalclock",(intptr_t)&totalclock, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
|
||||||
|
|
||||||
Gv_NewVar("viewingrange",(intptr_t)&viewingrange, GAMEVAR_SYSTEM | GAMEVAR_INTPTR | GAMEVAR_READONLY);
|
Gv_NewVar("viewingrange",(intptr_t)&viewingrange, GAMEVAR_SYSTEM | GAMEVAR_INTPTR | GAMEVAR_READONLY);
|
||||||
|
|
|
@ -1721,7 +1721,7 @@ static int32_t P_DisplayFist(int32_t gs)
|
||||||
int32_t looking_arc,fisti,fistpal;
|
int32_t looking_arc,fisti,fistpal;
|
||||||
int32_t fistzoom, fistz;
|
int32_t fistzoom, fistz;
|
||||||
|
|
||||||
int32_t wx[2] = { windowx1, windowx2 };
|
int32_t wx[2] = { windowxy1.x, windowxy2.x };
|
||||||
|
|
||||||
const DukePlayer_t *const ps = g_player[screenpeek].ps;
|
const DukePlayer_t *const ps = g_player[screenpeek].ps;
|
||||||
|
|
||||||
|
@ -1756,7 +1756,7 @@ static int32_t P_DisplayFist(int32_t gs)
|
||||||
(-fisti+222+(g_player[screenpeek].sync->avel>>5))<<16,
|
(-fisti+222+(g_player[screenpeek].sync->avel>>5))<<16,
|
||||||
(looking_arc+fistz)<<16,
|
(looking_arc+fistz)<<16,
|
||||||
fistzoom,0,FIST,gs,fistpal,2,
|
fistzoom,0,FIST,gs,fistpal,2,
|
||||||
wx[0],windowy1,wx[1],windowy2);
|
wx[0],windowxy1.y,wx[1],windowxy2.y);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -1771,8 +1771,8 @@ static void G_DrawTileScaled(int32_t x, int32_t y, int32_t tilenum, int32_t shad
|
||||||
int32_t ang = 0;
|
int32_t ang = 0;
|
||||||
int32_t xoff = 192;
|
int32_t xoff = 192;
|
||||||
|
|
||||||
int32_t wx[2] = { windowx1, windowx2 };
|
int32_t wx[2] = { windowxy1.x, windowxy2.x };
|
||||||
int32_t wy[2] = { windowy1, windowy2 };
|
int32_t wy[2] = { windowxy1.y, windowxy2.y };
|
||||||
int32_t yofs = 0;
|
int32_t yofs = 0;
|
||||||
|
|
||||||
switch (hudweap.cur)
|
switch (hudweap.cur)
|
||||||
|
@ -4576,7 +4576,7 @@ void P_ProcessInput(int32_t snum)
|
||||||
j = lz&(MAXSPRITES-1);
|
j = lz&(MAXSPRITES-1);
|
||||||
|
|
||||||
if ((sprite[j].cstat&33) == 33 || (sprite[j].cstat&17) == 17 ||
|
if ((sprite[j].cstat&33) == 33 || (sprite[j].cstat&17) == 17 ||
|
||||||
clipshape_idx_for_sprite(&sprite[j], -1) >= 0)
|
clipshape_idx_for_sprite((uspritetype *)&sprite[j], -1) >= 0)
|
||||||
{
|
{
|
||||||
// EDuke32 extension: xvel of 1 makes a sprite be never regarded as a bridge.
|
// EDuke32 extension: xvel of 1 makes a sprite be never regarded as a bridge.
|
||||||
if ((sprite[j].xvel&1) == 0)
|
if ((sprite[j].xvel&1) == 0)
|
||||||
|
|
|
@ -34,7 +34,7 @@ int32_t althud_shadows = 0;
|
||||||
int32_t althud_shadows = 1;
|
int32_t althud_shadows = 1;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int32_t sbarsc(int32_t sc)
|
inline int32_t sbarsc(int32_t sc)
|
||||||
{
|
{
|
||||||
return scale(sc, ud.statusbarscale, 100);
|
return scale(sc, ud.statusbarscale, 100);
|
||||||
}
|
}
|
||||||
|
@ -78,13 +78,13 @@ int32_t sbary16(int32_t y)
|
||||||
|
|
||||||
static void G_PatchStatusBar(int32_t x1, int32_t y1, int32_t x2, int32_t y2)
|
static void G_PatchStatusBar(int32_t x1, int32_t y1, int32_t x2, int32_t y2)
|
||||||
{
|
{
|
||||||
int32_t scl = sbarsc(65536);
|
int32_t const scl = sbarsc(65536);
|
||||||
int32_t tx = sbarx16((160<<16) - (tilesiz[BOTTOMSTATUSBAR].x<<15)); // centered
|
int32_t const tx = sbarx16((160<<16) - (tilesiz[BOTTOMSTATUSBAR].x<<15)); // centered
|
||||||
int32_t ty = sbary(200-tilesiz[BOTTOMSTATUSBAR].y);
|
int32_t const ty = sbary(200-tilesiz[BOTTOMSTATUSBAR].y);
|
||||||
|
|
||||||
int32_t clx1 = sbarsc(scale(x1, xdim, 320)), cly1 = sbarsc(scale(y1, ydim, 200));
|
int32_t const clx1 = sbarsc(scale(x1, xdim, 320)), cly1 = sbarsc(scale(y1, ydim, 200));
|
||||||
int32_t clx2 = sbarsc(scale(x2, xdim, 320)), cly2 = sbarsc(scale(y2, ydim, 200));
|
int32_t const clx2 = sbarsc(scale(x2, xdim, 320)), cly2 = sbarsc(scale(y2, ydim, 200));
|
||||||
int32_t clofx = (xdim - sbarsc(xdim)) >> 1, clofy = (ydim - sbarsc(ydim));
|
int32_t const clofx = (xdim - sbarsc(xdim)) >> 1, clofy = (ydim - sbarsc(ydim));
|
||||||
|
|
||||||
rotatesprite(tx, ty, scl, 0, BOTTOMSTATUSBAR, 4, 0, 10+16+64, clx1+clofx, cly1+clofy, clx2+clofx-1, cly2+clofy-1);
|
rotatesprite(tx, ty, scl, 0, BOTTOMSTATUSBAR, 4, 0, 10+16+64, clx1+clofx, cly1+clofy, clx2+clofx-1, cly2+clofy-1);
|
||||||
}
|
}
|
||||||
|
@ -1082,23 +1082,23 @@ void G_DrawBackground(void)
|
||||||
if (ud.screen_size > 8)
|
if (ud.screen_size > 8)
|
||||||
{
|
{
|
||||||
// across top
|
// across top
|
||||||
for (y=0; y<windowy1; y+=tilesiz[dapicnum].y)
|
for (y=0; y<windowxy1.y; y+=tilesiz[dapicnum].y)
|
||||||
for (x=0; x<xdim; x+=tilesiz[dapicnum].x)
|
for (x=0; x<xdim; x+=tilesiz[dapicnum].x)
|
||||||
rotatesprite(x<<16, y<<16, 65536L, 0, dapicnum, 8, 0, 8+16+64, 0, y1, xdim-1, windowy1-1);
|
rotatesprite(x<<16, y<<16, 65536L, 0, dapicnum, 8, 0, 8+16+64, 0, y1, xdim-1, windowxy1.y-1);
|
||||||
|
|
||||||
// sides
|
// sides
|
||||||
const int32_t rx = windowx2-windowx2%tilesiz[dapicnum].x;
|
const int32_t rx = windowxy2.x-windowxy2.x%tilesiz[dapicnum].x;
|
||||||
for (y=windowy1-windowy1%tilesiz[dapicnum].y; y<windowy2; y+=tilesiz[dapicnum].y)
|
for (y=windowxy1.y-windowxy1.y%tilesiz[dapicnum].y; y<windowxy2.y; y+=tilesiz[dapicnum].y)
|
||||||
for (x=0; x<windowx1 || x+rx<xdim; x+=tilesiz[dapicnum].x)
|
for (x=0; x<windowxy1.x || x+rx<xdim; x+=tilesiz[dapicnum].x)
|
||||||
{
|
{
|
||||||
rotatesprite(x<<16, y<<16, 65536L, 0, dapicnum, 8, 0, 8+16+64, 0, windowy1, windowx1-1, windowy2-1);
|
rotatesprite(x<<16, y<<16, 65536L, 0, dapicnum, 8, 0, 8+16+64, 0, windowxy1.y, windowxy1.x-1, windowxy2.y-1);
|
||||||
rotatesprite((x+rx)<<16, y<<16, 65536L, 0, dapicnum, 8, 0, 8+16+64, windowx2, windowy1, xdim-1, windowy2-1);
|
rotatesprite((x+rx)<<16, y<<16, 65536L, 0, dapicnum, 8, 0, 8+16+64, windowxy2.x, windowxy1.y, xdim-1, windowxy2.y-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
// along bottom
|
// along bottom
|
||||||
for (y=windowy2-(windowy2%tilesiz[dapicnum].y); y<y2; y+=tilesiz[dapicnum].y)
|
for (y=windowxy2.y-(windowxy2.y%tilesiz[dapicnum].y); y<y2; y+=tilesiz[dapicnum].y)
|
||||||
for (x=0; x<xdim; x+=tilesiz[dapicnum].x)
|
for (x=0; x<xdim; x+=tilesiz[dapicnum].x)
|
||||||
rotatesprite(x<<16, y<<16, 65536L, 0, dapicnum, 8, 0, 8+16+64, 0, windowy2, xdim-1, y2-1);
|
rotatesprite(x<<16, y<<16, 65536L, 0, dapicnum, 8, 0, 8+16+64, 0, windowxy2.y, xdim-1, y2-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
// draw in the bits to the left and right of the non-fullsize status bar
|
// draw in the bits to the left and right of the non-fullsize status bar
|
||||||
|
@ -1124,10 +1124,10 @@ void G_DrawBackground(void)
|
||||||
if (ud.multimode > 4) y += 8;
|
if (ud.multimode > 4) y += 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
x1 = max(windowx1-4, 0);
|
x1 = max(windowxy1.x-4, 0);
|
||||||
y1 = max(windowy1-4, y);
|
y1 = max(windowxy1.y-4, y);
|
||||||
x2 = min(windowx2+4, xdim-1);
|
x2 = min(windowxy2.x+4, xdim-1);
|
||||||
y2 = min(windowy2+4, scale(ydim, 200-sbarsc(tilesiz[BOTTOMSTATUSBAR].y), 200)-1);
|
y2 = min(windowxy2.y+4, scale(ydim, 200-sbarsc(tilesiz[BOTTOMSTATUSBAR].y), 200)-1);
|
||||||
|
|
||||||
for (y=y1+4; y<y2-4; y+=64)
|
for (y=y1+4; y<y2-4; y+=64)
|
||||||
{
|
{
|
||||||
|
|
|
@ -789,22 +789,22 @@ static void G_PrintFPS(void)
|
||||||
{
|
{
|
||||||
int32_t chars = Bsprintf(tempbuf, "%d ms (%3u fps)", howlong, LastCount);
|
int32_t chars = Bsprintf(tempbuf, "%d ms (%3u fps)", howlong, LastCount);
|
||||||
|
|
||||||
printext256(windowx2-(chars<<(3-x))+1, windowy1+2+FPS_YOFFSET, 0, -1, tempbuf, x);
|
printext256(windowxy2.x-(chars<<(3-x))+1, windowxy1.y+2+FPS_YOFFSET, 0, -1, tempbuf, x);
|
||||||
printext256(windowx2-(chars<<(3-x)), windowy1+1+FPS_YOFFSET,
|
printext256(windowxy2.x-(chars<<(3-x)), windowxy1.y+1+FPS_YOFFSET,
|
||||||
(LastCount < LOW_FPS) ? COLOR_RED : COLOR_WHITE, -1, tempbuf, x);
|
(LastCount < LOW_FPS) ? COLOR_RED : COLOR_WHITE, -1, tempbuf, x);
|
||||||
|
|
||||||
if (ud.tickrate > 1)
|
if (ud.tickrate > 1)
|
||||||
{
|
{
|
||||||
chars = Bsprintf(tempbuf, "max fps: %3u", MaxFrames);
|
chars = Bsprintf(tempbuf, "max fps: %3u", MaxFrames);
|
||||||
|
|
||||||
printext256(windowx2-(chars<<(3-x))+1, windowy1+10+2+FPS_YOFFSET, 0, -1, tempbuf, x);
|
printext256(windowxy2.x-(chars<<(3-x))+1, windowxy1.y+10+2+FPS_YOFFSET, 0, -1, tempbuf, x);
|
||||||
printext256(windowx2-(chars<<(3-x)), windowy1+10+FPS_YOFFSET,
|
printext256(windowxy2.x-(chars<<(3-x)), windowxy1.y+10+FPS_YOFFSET,
|
||||||
(MaxFrames < LOW_FPS) ? COLOR_RED : COLOR_WHITE, -1, tempbuf, x);
|
(MaxFrames < LOW_FPS) ? COLOR_RED : COLOR_WHITE, -1, tempbuf, x);
|
||||||
|
|
||||||
chars = Bsprintf(tempbuf, "min fps: %3u", MinFrames);
|
chars = Bsprintf(tempbuf, "min fps: %3u", MinFrames);
|
||||||
|
|
||||||
printext256(windowx2-(chars<<(3-x))+1, windowy1+20+2+FPS_YOFFSET, 0, -1, tempbuf, x);
|
printext256(windowxy2.x-(chars<<(3-x))+1, windowxy1.y+20+2+FPS_YOFFSET, 0, -1, tempbuf, x);
|
||||||
printext256(windowx2-(chars<<(3-x)), windowy1+20+FPS_YOFFSET,
|
printext256(windowxy2.x-(chars<<(3-x)), windowxy1.y+20+FPS_YOFFSET,
|
||||||
(MinFrames < LOW_FPS) ? COLOR_RED : COLOR_WHITE, -1, tempbuf, x);
|
(MinFrames < LOW_FPS) ? COLOR_RED : COLOR_WHITE, -1, tempbuf, x);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -814,8 +814,8 @@ static void G_PrintFPS(void)
|
||||||
chars = Bsprintf(tempbuf, "%d +- %d ms", (g_netClientPeer->lastRoundTripTime + g_netClientPeer->roundTripTime)/2,
|
chars = Bsprintf(tempbuf, "%d +- %d ms", (g_netClientPeer->lastRoundTripTime + g_netClientPeer->roundTripTime)/2,
|
||||||
(g_netClientPeer->lastRoundTripTimeVariance + g_netClientPeer->roundTripTimeVariance)/2);
|
(g_netClientPeer->lastRoundTripTimeVariance + g_netClientPeer->roundTripTimeVariance)/2);
|
||||||
|
|
||||||
printext256(windowx2-(chars<<(3-x))+1, windowy1+30+2+FPS_YOFFSET, 0, -1, tempbuf, x);
|
printext256(windowxy2.x-(chars<<(3-x))+1, windowxy1.y+30+2+FPS_YOFFSET, 0, -1, tempbuf, x);
|
||||||
printext256(windowx2-(chars<<(3-x)), windowy1+30+1+FPS_YOFFSET, g_netClientPeer->lastRoundTripTime > 200 ? COLOR_RED : COLOR_WHITE, -1, tempbuf, x);
|
printext256(windowxy2.x-(chars<<(3-x)), windowxy1.y+30+1+FPS_YOFFSET, g_netClientPeer->lastRoundTripTime > 200 ? COLOR_RED : COLOR_WHITE, -1, tempbuf, x);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue