git-svn-id: https://svn.eduke32.com/eduke32@1336 1a8010ca-5511-0410-912e-c29ae57300e0

This commit is contained in:
terminx 2009-04-23 07:09:24 +00:00
parent e48c4c2c87
commit dba312e61b
12 changed files with 130 additions and 266 deletions

View file

@ -45,7 +45,7 @@ CC=cl
AS=ml AS=ml
RC=rc RC=rc
LINK=link /opt:nowin98 /opt:ref /nologo LINK=link /opt:nowin98 /opt:ref /nologo
CFLAGS=$(CFLAGS) /nologo /MD /J $(flags_cl) $(TARGETOPTS) /I$(INC) /I$(DXROOT)\include" /I$(MSSDKROOT)\include" /I$(PLATFORMSDK)\include" # /I$(ENETROOT)\include" CFLAGS=$(CFLAGS) /nologo /MD /J $(flags_cl) $(TARGETOPTS) /I$(INC) /I$(MSSDKROOT)\include" /I$(PLATFORMSDK)\include" /I$(DXROOT)\include" # /I$(ENETROOT)\include"
ASFLAGS=/nologo /coff /c ASFLAGS=/nologo /coff /c
EXESUFFIX=.exe EXESUFFIX=.exe
!ifdef DEBUG !ifdef DEBUG

View file

@ -1,7 +1,7 @@
// ISO C9x compliant stdint.h for Microsoft Visual Studio // ISO C9x compliant stdint.h for Microsoft Visual Studio
// Based on ISO/IEC 9899:TC2 Committee draft (May 6, 2005) WG14/N1124 // Based on ISO/IEC 9899:TC2 Committee draft (May 6, 2005) WG14/N1124
// //
// Copyright (c) 2006 Alexander Chemeris // Copyright (c) 2006-2008 Alexander Chemeris
// //
// Redistribution and use in source and binary forms, with or without // Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met: // modification, are permitted provided that the following conditions are met:
@ -53,6 +53,16 @@
} }
#endif #endif
// Define _W64 macros to mark types changing their size, like intptr_t.
#ifndef _W64
# if !defined(__midl) && (defined(_X86_) || defined(_M_IX86)) && _MSC_VER >= 1300
# define _W64 __w64
# else
# define _W64
# endif
#endif
// 7.18.1 Integer types // 7.18.1 Integer types
// 7.18.1.1 Exact-width integer types // 7.18.1.1 Exact-width integer types
@ -90,8 +100,8 @@ typedef uint64_t uint_fast64_t;
typedef __int64 intptr_t; typedef __int64 intptr_t;
typedef unsigned __int64 uintptr_t; typedef unsigned __int64 uintptr_t;
#else // _WIN64 ][ #else // _WIN64 ][
typedef int32_t intptr_t; typedef _W64 int intptr_t;
typedef uint32_t uintptr_t; typedef _W64 unsigned int uintptr_t;
#endif // _WIN64 ] #endif // _WIN64 ]
// 7.18.1.5 Greatest-width integer types // 7.18.1.5 Greatest-width integer types

View file

@ -78,9 +78,9 @@ struct cacheitem_t
typedef struct cacheitem_t texcacheindex; typedef struct cacheitem_t texcacheindex;
extern texcacheindex firstcacheindex; extern texcacheindex *firstcacheindex;
extern texcacheindex *curcacheindex; extern texcacheindex *curcacheindex;
extern texcacheindex *cacheptrs[MAXTILES<<2]; extern texcacheindex *cacheptrs[MAXTILES<<1];
extern int32_t numcacheentries; extern int32_t numcacheentries;
int32_t dxtfilter(int32_t fil, texcachepicture *pict, char *pic, void *midbuf, char *packbuf, uint32_t miplen); int32_t dxtfilter(int32_t fil, texcachepicture *pict, char *pic, void *midbuf, char *packbuf, uint32_t miplen);

View file

@ -7373,7 +7373,9 @@ int32_t loadmaphack(char *filename)
memset(spriteext, 0, sizeof(spriteext_t) * MAXSPRITES); memset(spriteext, 0, sizeof(spriteext_t) * MAXSPRITES);
memset(spritesmooth, 0, sizeof(spritesmooth_t) * (MAXSPRITES+MAXUNIQHUDID)); memset(spritesmooth, 0, sizeof(spritesmooth_t) * (MAXSPRITES+MAXUNIQHUDID));
#ifdef POLYMER
staticlightcount = 0; staticlightcount = 0;
#endif // POLYMER
while (1) while (1)
{ {
@ -7526,6 +7528,7 @@ int32_t loadmaphack(char *filename)
} }
spriteext[whichsprite].flags |= SPREXT_AWAY2; spriteext[whichsprite].flags |= SPREXT_AWAY2;
break; break;
#ifdef POLYMER
case T_LIGHT: // light sector x y z range r g b radius faderadius angle horiz minshade maxshade priority case T_LIGHT: // light sector x y z range r g b radius faderadius angle horiz minshade maxshade priority
{ {
int32_t value; int32_t value;
@ -7564,6 +7567,7 @@ int32_t loadmaphack(char *filename)
staticlightcount++; staticlightcount++;
break; break;
} }
#endif // POLYMER
default: default:
// unrecognised token // unrecognised token
@ -7766,7 +7770,11 @@ int32_t setgamemode(char davidoption, int32_t daxdim, int32_t daydim, int32_t da
if (nogl) dabpp = 8; if (nogl) dabpp = 8;
#endif #endif
if ((qsetmode == 200) && (videomodereset == 0) && if ((qsetmode == 200) && (videomodereset == 0) &&
(davidoption == fullscreen) && (xdim == daxdim) && (ydim == daydim) && (bpp == dabpp) && glrendmode != 4) (davidoption == fullscreen) && (xdim == daxdim) && (ydim == daydim) && (bpp == dabpp)
#ifdef POLYMER
&& glrendmode != 4
#endif // POLYMER
)
return(0); return(0);
strcpy(kensmessage,"!!!! BUILD engine&tools programmed by Ken Silverman of E.G. RI. (c) Copyright 1995 Ken Silverman. Summary: BUILD = Ken. !!!!"); strcpy(kensmessage,"!!!! BUILD engine&tools programmed by Ken Silverman of E.G. RI. (c) Copyright 1995 Ken Silverman. Summary: BUILD = Ken. !!!!");

View file

@ -152,21 +152,6 @@ static int32_t fullbrightloadingpass = 0;
static int32_t fullbrightdrawingpass = 0; static int32_t fullbrightdrawingpass = 0;
static int32_t shadeforfullbrightpass; static int32_t shadeforfullbrightpass;
/*
// Depth peeling control
int32_t r_depthpeeling = 0; // cvar toggling general depth peeling usage
int32_t r_peelscount = 5; // cvar controlling the number of peeling layers
int32_t r_curpeel = -1; // cvar controlling the display of independant peeling layers
int32_t peelcompiling = 0; // internal control var to disable blending when compiling the peeling display list
int32_t newpeelscount = 0; // temporary var for peels count changing during the game
// Depth peeling data
GLuint ztexture[3]; // secondary Z-buffers identifier
GLuint *peels; // peels identifiers
GLuint *peelfbos; // peels FBOs identifiers
GLuint peelprogram[2]; // ARBfp peeling fragment program
*/
float curpolygonoffset; // internal polygon offset stack for drawing flat sprites to avoid depth fighting float curpolygonoffset; // internal polygon offset stack for drawing flat sprites to avoid depth fighting
// Detail mapping cvar // Detail mapping cvar
@ -338,9 +323,9 @@ char TEXCACHEFILE[BMAX_PATH] = "textures";
int32_t mdtims, omdtims; int32_t mdtims, omdtims;
float alphahackarray[MAXTILES]; float alphahackarray[MAXTILES];
texcacheindex firstcacheindex; texcacheindex *firstcacheindex = NULL;
texcacheindex *curcacheindex = NULL; texcacheindex *curcacheindex = NULL;
texcacheindex *cacheptrs[MAXTILES<<2]; texcacheindex *cacheptrs[MAXTILES<<1];
int32_t numcacheentries = 0; int32_t numcacheentries = 0;
//-------------------------------------------------------------------------------------------------- //--------------------------------------------------------------------------------------------------
@ -680,21 +665,6 @@ void polymost_glreset()
memset(gltexcachead,0,sizeof(gltexcachead)); memset(gltexcachead,0,sizeof(gltexcachead));
glox1 = -1; glox1 = -1;
// Depth peeling cleanup
/*
if (peels)
{
bglDeleteProgramsARB(2, peelprogram);
bglDeleteFramebuffersEXT(r_peelscount + 1, peelfbos);
bglDeleteTextures(r_peelscount + 1, peels);
bglDeleteTextures(3, ztexture);
free(peels);
free(peelfbos);
peels = NULL;
}
*/
if (cachefilehandle != -1) if (cachefilehandle != -1)
{ {
Bclose(cachefilehandle); Bclose(cachefilehandle);
@ -706,18 +676,13 @@ void polymost_glreset()
Bfclose(cacheindexptr); Bfclose(cacheindexptr);
cacheindexptr = NULL; cacheindexptr = NULL;
} }
{
texcacheindex *index;
curcacheindex = firstcacheindex.next; for (i = 0; i < numcacheentries; i++)
while (curcacheindex) if (cacheptrs[i])
{ {
index = curcacheindex; Bfree(cacheptrs[i]);
curcacheindex = curcacheindex->next; cacheptrs[i] = NULL;
Bfree(index);
} }
firstcacheindex.next = NULL;
}
} }
// one-time initialization of OpenGL for polymost // one-time initialization of OpenGL for polymost
@ -725,35 +690,6 @@ void polymost_glinit()
{ {
GLfloat col[4]; GLfloat col[4];
int32_t i; int32_t i;
/*
char notpeeledprogramstring[] =
"!!ARBfp1.0\n"
"OPTION ARB_fog_exp2;\n"
"OPTION ARB_fragment_program_shadow;\n"
"TEMP texsample;\n"
"TEMP depthresult;\n"
"TEX depthresult, fragment.position, texture[1], SHADOWRECT;\n"
"ADD depthresult.a, depthresult.a, -0.5;\n"
"KIL depthresult.a;\n"
"TEX texsample, fragment.texcoord[0], texture[0], 2D;\n"
"MUL result.color, fragment.color, texsample;\n"
"END\n";
char peeledprogramstring[] =
"!!ARBfp1.0\n"
"OPTION ARB_fog_exp2;\n"
"OPTION ARB_fragment_program_shadow;\n"
"TEMP texsample;\n"
"TEMP depthresult;\n"
"TEX depthresult, fragment.position, texture[2], SHADOWRECT;\n"
"ADD depthresult.a, depthresult.a, -0.5;\n"
"KIL depthresult.a;\n"
"TEX depthresult, fragment.position, texture[1], SHADOWRECT;\n"
"ADD depthresult.a, depthresult.a, -0.5;\n"
"KIL depthresult.a;\n"
"TEX texsample, fragment.texcoord[0], texture[0], 2D;\n"
"MUL result.color, fragment.color, texsample;\n"
"END\n";
*/
if (!Bstrcmp(glinfo.vendor, "NVIDIA Corporation")) if (!Bstrcmp(glinfo.vendor, "NVIDIA Corporation"))
{ {
@ -783,14 +719,6 @@ void polymost_glinit()
bglEnable(GL_MULTISAMPLE_ARB); bglEnable(GL_MULTISAMPLE_ARB);
} }
/*
if (r_depthpeeling && (!glinfo.arbfp || !glinfo.depthtex || !glinfo.shadow || !glinfo.fbos || !glinfo.rect || !glinfo.multitex))
{
OSD_Printf("Your OpenGL implementation doesn't support depth peeling. Disabling...\n");
r_depthpeeling = 0;
}
*/
if (r_detailmapping && (!glinfo.multitex || !glinfo.envcombine)) if (r_detailmapping && (!glinfo.multitex || !glinfo.envcombine))
{ {
OSD_Printf("Your OpenGL implementation doesn't support detail mapping. Disabling...\n"); OSD_Printf("Your OpenGL implementation doesn't support detail mapping. Disabling...\n");
@ -809,80 +737,6 @@ void polymost_glinit()
r_vbos = 0; r_vbos = 0;
} }
//depth peeling initialization
/*
if (r_depthpeeling)
{
if (newpeelscount)
{
r_peelscount = newpeelscount;
newpeelscount = 0;
}
// create the secondary Z-buffers and the Z-backbuffer
bglGenTextures(3, ztexture);
i = 0;
while (i < 3)
{
bglBindTexture(GL_TEXTURE_RECTANGLE, ztexture[i]);
bglCopyTexImage2D(GL_TEXTURE_RECTANGLE, 0, GL_DEPTH_COMPONENT, 0, 0, xdim, ydim, 0);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_WRAP_S, GL_CLAMP);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_WRAP_T, GL_CLAMP);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_COMPARE_MODE_ARB, GL_COMPARE_R_TO_TEXTURE_ARB);
if (i < 2)
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_COMPARE_FUNC_ARB, GL_GREATER);
else
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_COMPARE_FUNC_ARB, GL_LESS);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_DEPTH_TEXTURE_MODE_ARB, GL_ALPHA);
i++;
}
// create the various peeling layers as well as the FBOs to render to them
peels = malloc((r_peelscount + 1) * sizeof(GLuint));
bglGenTextures(r_peelscount + 1, peels);
peelfbos = malloc((r_peelscount + 1) * sizeof(GLuint));
bglGenFramebuffersEXT(r_peelscount + 1, peelfbos);
i = 0;
while (i <= r_peelscount)
{
bglBindTexture(GL_TEXTURE_RECTANGLE, peels[i]);
bglCopyTexImage2D(GL_TEXTURE_RECTANGLE, 0, GL_RGBA, 0, 0, xdim, ydim, 0);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_WRAP_S, GL_CLAMP);
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_WRAP_T, GL_CLAMP);
bglBindFramebufferEXT(GL_FRAMEBUFFER_EXT, peelfbos[i]);
bglFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT, GL_COLOR_ATTACHMENT0_EXT, GL_TEXTURE_RECTANGLE, peels[i], 0);
if (i == r_peelscount) // bakcbuffer
bglFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT, GL_DEPTH_ATTACHMENT_EXT, GL_TEXTURE_RECTANGLE, ztexture[2], 0);
else if (i < (r_peelscount - 1))
bglFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT, GL_DEPTH_ATTACHMENT_EXT, GL_TEXTURE_RECTANGLE, ztexture[i % 2], 0);
if (bglCheckFramebufferStatusEXT(GL_FRAMEBUFFER_EXT) != GL_FRAMEBUFFER_COMPLETE_EXT)
{
OSD_Printf("FBO #%d initialization failed.\n", i);
}
bglBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0);
i++;
}
// create the peeling fragment programs
bglGenProgramsARB(2, peelprogram);
bglBindProgramARB(GL_FRAGMENT_PROGRAM_ARB, peelprogram[0]);
bglProgramStringARB(GL_FRAGMENT_PROGRAM_ARB, GL_PROGRAM_FORMAT_ASCII_ARB, strlen(notpeeledprogramstring), notpeeledprogramstring);
bglBindProgramARB(GL_FRAGMENT_PROGRAM_ARB, peelprogram[1]);
bglProgramStringARB(GL_FRAGMENT_PROGRAM_ARB, GL_PROGRAM_FORMAT_ASCII_ARB, strlen(peeledprogramstring), peeledprogramstring);
}
*/
bglEnableClientState(GL_VERTEX_ARRAY); bglEnableClientState(GL_VERTEX_ARRAY);
bglEnableClientState(GL_TEXTURE_COORD_ARRAY); bglEnableClientState(GL_TEXTURE_COORD_ARRAY);
@ -898,16 +752,25 @@ void polymost_glinit()
cacheindexptr = NULL; cacheindexptr = NULL;
} }
curcacheindex = &firstcacheindex; for (i = 0; i < numcacheentries; i++)
if (cacheptrs[i])
{
Bfree(cacheptrs[i]);
cacheptrs[i] = NULL;
}
curcacheindex = firstcacheindex = Bcalloc(1, sizeof(texcacheindex));
numcacheentries = 0; numcacheentries = 0;
Bmemset(&firstcacheindex, 0, sizeof(texcacheindex));
Bmemset(&cacheptrs[0], 0, sizeof(cacheptrs)); // Bmemset(&firstcacheindex, 0, sizeof(texcacheindex));
// Bmemset(&cacheptrs[0], 0, sizeof(cacheptrs));
hash_init(&cacheH); hash_init(&cacheH);
LoadCacheOffsets(); LoadCacheOffsets();
Bstrcpy(ptempbuf,TEXCACHEFILE); Bstrcpy(ptempbuf,TEXCACHEFILE);
Bstrcat(ptempbuf,".cache"); Bstrcat(ptempbuf,".cache");
cacheindexptr = Bfopen(ptempbuf, "at"); cacheindexptr = Bfopen(ptempbuf, "at+");
if (!cacheindexptr) if (!cacheindexptr)
{ {
glusetexcache = 0; glusetexcache = 0;
@ -934,20 +797,22 @@ void polymost_glinit()
i = 0; i = 0;
curcacheindex = &firstcacheindex; curcacheindex = firstcacheindex;
while (curcacheindex->next) while (curcacheindex->next)
{ {
i += curcacheindex->len; i += curcacheindex->len;
curcacheindex = curcacheindex->next; curcacheindex = curcacheindex->next;
} }
curcacheindex = &firstcacheindex; curcacheindex = firstcacheindex;
initprintf("Cache contains %d bytes of garbage data\n",Blseek(cachefilehandle, 0, BSEEK_END)-i); initprintf("Cache contains %d bytes of garbage data\n",Blseek(cachefilehandle, 0, BSEEK_END)-i);
// Blseek(cachefilehandle, 0, BSEEK_SET); // Blseek(cachefilehandle, 0, BSEEK_SET);
} }
void invalidatecache(void) void invalidatecache(void)
{ {
int32_t i;
polymost_glreset(); polymost_glreset();
if (cachefilehandle != -1) if (cachefilehandle != -1)
{ {
@ -960,22 +825,20 @@ void invalidatecache(void)
Bfclose(cacheindexptr); Bfclose(cacheindexptr);
cacheindexptr = NULL; cacheindexptr = NULL;
} }
{
texcacheindex *index;
curcacheindex = firstcacheindex.next; for (i = 0; i < numcacheentries; i++)
while (curcacheindex) if (cacheptrs[i])
{ {
index = curcacheindex; Bfree(cacheptrs[i]);
curcacheindex = curcacheindex->next; cacheptrs[i] = NULL;
Bfree(index);
} }
}
curcacheindex = &firstcacheindex; curcacheindex = firstcacheindex = Bcalloc(1, sizeof(texcacheindex));
numcacheentries = 0; numcacheentries = 0;
Bmemset(&firstcacheindex, 0, sizeof(texcacheindex));
Bmemset(&cacheptrs[0], 0, sizeof(cacheptrs)); // Bmemset(&firstcacheindex, 0, sizeof(texcacheindex));
// Bmemset(&cacheptrs[0], 0, sizeof(cacheptrs));
hash_init(&cacheH); hash_init(&cacheH);
// LoadCacheOffsets(); // LoadCacheOffsets();
@ -983,7 +846,7 @@ void invalidatecache(void)
unlink(ptempbuf); unlink(ptempbuf);
Bstrcat(ptempbuf,".cache"); Bstrcat(ptempbuf,".cache");
unlink(ptempbuf); unlink(ptempbuf);
cacheindexptr = Bfopen(ptempbuf, "at"); cacheindexptr = Bfopen(ptempbuf, "at+");
if (!cacheindexptr) if (!cacheindexptr)
{ {
glusetexcache = 0; glusetexcache = 0;
@ -1770,7 +1633,7 @@ int32_t gloadtile_hi(int32_t dapic,int32_t dapalnum, int32_t facen, hicreplctyp
if ((filh = kopen4load(fn, 0)) < 0) return -1; if ((filh = kopen4load(fn, 0)) < 0) return -1;
picfil = (char *)malloc(picfillen); if (!picfil) { kclose(filh); return 1; } picfil = (char *)malloc(picfillen+1); if (!picfil) { kclose(filh); return 1; }
kread(filh, picfil, picfillen); kread(filh, picfil, picfillen);
kclose(filh); kclose(filh);
@ -1860,6 +1723,9 @@ int32_t gloadtile_hi(int32_t dapic,int32_t dapalnum, int32_t facen, hicreplctyp
else texfmt = GL_BGRA; else texfmt = GL_BGRA;
free(picfil); picfil = 0; free(picfil); picfil = 0;
if (tsizx>>r_downsize <= tilesizx[dapic] || tsizy>>r_downsize <= tilesizy[dapic])
hicr->flags |= 17;
if (glinfo.texcompr && glusetexcompr && !(hicr->flags & 1)) if (glinfo.texcompr && glusetexcompr && !(hicr->flags & 1))
intexfmt = (hasalpha == 255) ? GL_COMPRESSED_RGBA_S3TC_DXT3_EXT : GL_COMPRESSED_RGBA_S3TC_DXT5_EXT; intexfmt = (hasalpha == 255) ? GL_COMPRESSED_RGBA_S3TC_DXT3_EXT : GL_COMPRESSED_RGBA_S3TC_DXT5_EXT;
else if (hasalpha == 255) intexfmt = GL_RGB; else if (hasalpha == 255) intexfmt = GL_RGB;
@ -1908,6 +1774,9 @@ int32_t gloadtile_hi(int32_t dapic,int32_t dapalnum, int32_t facen, hicreplctyp
if (pic) free(pic); if (pic) free(pic);
if (tsizx>>r_downsize <= tilesizx[dapic] || tsizy>>r_downsize <= tilesizy[dapic])
hicr->flags |= 17;
pth->picnum = dapic; pth->picnum = dapic;
pth->effects = effect; pth->effects = effect;
pth->flags = ((dameth&4)>>2) + 2 + ((facen>0)<<2); if (hasalpha != 255) pth->flags |= 8; pth->flags = ((dameth&4)>>2) + 2 + ((facen>0)<<2); if (hasalpha != 255) pth->flags |= 8;
@ -2071,7 +1940,7 @@ void drawpoly(double *dpx, double *dpy, int32_t n, int32_t method)
// detail texture // detail texture
detailpth = NULL; detailpth = NULL;
if (r_detailmapping && usehightile /*&& !r_depthpeeling*/ && !drawingskybox && if (r_detailmapping && usehightile && !drawingskybox &&
hicfindsubst(globalpicnum, DETAILPAL, 0)) hicfindsubst(globalpicnum, DETAILPAL, 0))
detailpth = gltexcache(globalpicnum, DETAILPAL, method&(~3)); detailpth = gltexcache(globalpicnum, DETAILPAL, method&(~3));
@ -2117,7 +1986,7 @@ void drawpoly(double *dpx, double *dpy, int32_t n, int32_t method)
// glow texture // glow texture
glowpth = NULL; glowpth = NULL;
if (r_glowmapping && usehightile /*&& !r_depthpeeling*/ && !drawingskybox && if (r_glowmapping && usehightile && !drawingskybox &&
hicfindsubst(globalpicnum, GLOWPAL, 0)) hicfindsubst(globalpicnum, GLOWPAL, 0))
glowpth = gltexcache(globalpicnum, GLOWPAL, method&(~3)); glowpth = gltexcache(globalpicnum, GLOWPAL, method&(~3));
@ -2171,7 +2040,6 @@ void drawpoly(double *dpx, double *dpy, int32_t n, int32_t method)
if ((!(method&3)) && (!fullbrightdrawingpass)) if ((!(method&3)) && (!fullbrightdrawingpass))
{ {
bglDisable(GL_BLEND); bglDisable(GL_BLEND);
/* if (!peelcompiling)*/
bglDisable(GL_ALPHA_TEST); bglDisable(GL_ALPHA_TEST);
} }
else else
@ -2181,7 +2049,6 @@ void drawpoly(double *dpx, double *dpy, int32_t n, int32_t method)
if (alphahackarray[globalpicnum]) if (alphahackarray[globalpicnum])
al=alphahackarray[globalpicnum]; al=alphahackarray[globalpicnum];
if (!waloff[globalpicnum]) al = 0.0; // invalid textures ignore the alpha cutoff settings if (!waloff[globalpicnum]) al = 0.0; // invalid textures ignore the alpha cutoff settings
/* if (!peelcompiling)*/
bglEnable(GL_BLEND); bglEnable(GL_BLEND);
bglEnable(GL_ALPHA_TEST); bglEnable(GL_ALPHA_TEST);
bglAlphaFunc(GL_GREATER,al); bglAlphaFunc(GL_GREATER,al);
@ -4279,15 +4146,6 @@ void polymost_drawrooms()
globalposy += cosglobalang/1024; globalposy += cosglobalang/1024;
} }
} }
/*
if (r_depthpeeling)
{
bglBindFramebufferEXT(GL_FRAMEBUFFER_EXT, peelfbos[r_peelscount]);
bglPushAttrib(GL_VIEWPORT_BIT);
bglViewport(0, 0, xdim, ydim);
//bglClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);
}
*/
} }
#endif #endif
@ -4525,18 +4383,6 @@ void polymost_drawmaskwall(int32_t damaskwallcnt)
globalpal = (int32_t)((uint8_t)wal->pal); globalpal = (int32_t)((uint8_t)wal->pal);
globalorientation = (int32_t)wal->cstat; globalorientation = (int32_t)wal->cstat;
/*
#ifdef USE_OPENGL
if (r_depthpeeling)
{
if ((((wal->cstat&128) || (gltexmayhavealpha(globalpicnum,globalpal)))) && !peelcompiling)
return; // discard translucent sprite if drawing the backbuffer when doing depth peeling
if (!(((wal->cstat&128) || (gltexmayhavealpha(globalpicnum,globalpal)))) && peelcompiling)
return; // discard opaque sprite when composing the depth peels
}
#endif
*/
sx0 = (float)(wal->x-globalposx); sx1 = (float)(wal2->x-globalposx); sx0 = (float)(wal->x-globalposx); sx1 = (float)(wal2->x-globalposx);
sy0 = (float)(wal->y-globalposy); sy1 = (float)(wal2->y-globalposy); sy0 = (float)(wal->y-globalposy); sy1 = (float)(wal2->y-globalposy);
yp0 = sx0*gcosang2 + sy0*gsinang2; yp0 = sx0*gcosang2 + sy0*gsinang2;
@ -4776,15 +4622,6 @@ void polymost_drawsprite(int32_t snum)
if (tspr->cstat&2) { if (!(tspr->cstat&512)) method = 2+4; else method = 3+4; } if (tspr->cstat&2) { if (!(tspr->cstat&512)) method = 2+4; else method = 3+4; }
#ifdef USE_OPENGL #ifdef USE_OPENGL
/*
if (r_depthpeeling)
{
if ((((tspr->cstat&2) || (gltexmayhavealpha(globalpicnum,tspr->pal)))) && !peelcompiling)
return; // discard translucent sprite if drawing the backbuffer when doing depth peeling
if (!(((tspr->cstat&2) || (gltexmayhavealpha(globalpicnum,tspr->pal)))) && peelcompiling)
return; // discard opaque sprite when composing the depth peels
}
*/
if (!nofog && rendmode >= 3) if (!nofog && rendmode >= 3)
{ {
@ -6094,46 +5931,6 @@ static int32_t osdcmd_polymostvars(const osdfuncparm_t *parm)
else gltexmiplevel = val; else gltexmiplevel = val;
return OSDCMD_OK; return OSDCMD_OK;
} }
/*
else if (!Bstrcasecmp(parm->name, "r_depthpeeling"))
{
if (showval) { OSD_Printf("r_depthpeeling is %d\n", r_depthpeeling); }
else
{
if (!glinfo.arbfp || !glinfo.depthtex || !glinfo.shadow || !glinfo.fbos || !glinfo.rect)
{
OSD_Printf("r_depthpeeling: Your OpenGL implementation doesn't support depth peeling.\n");
r_depthpeeling = 0;
return OSDCMD_OK;
}
r_depthpeeling = (val != 0);
resetvideomode();
if (setgamemode(fullscreen,xdim,ydim,bpp))
OSD_Printf("restartvid: Reset failed...\n");
}
return OSDCMD_OK;
}
else if (!Bstrcasecmp(parm->name, "r_peelscount"))
{
if (showval) { OSD_Printf("r_peelscount is %d\n", r_peelscount); }
else if (val < 1) { OSD_Printf("Value out of range.\n"); }
else
{
newpeelscount = val;
resetvideomode();
if (setgamemode(fullscreen,xdim,ydim,bpp))
OSD_Printf("restartvid: Reset failed...\n");
}
return OSDCMD_OK;
}
else if (!Bstrcasecmp(parm->name, "r_curpeel"))
{
if (showval) { OSD_Printf("r_curpeel is %d\n", r_curpeel); }
else if ((val < -1) || (val >= r_peelscount)) { OSD_Printf("Value out of range.\n"); }
else r_curpeel = val;
return OSDCMD_OK;
}
*/
else if (!Bstrcasecmp(parm->name, "r_detailmapping")) else if (!Bstrcasecmp(parm->name, "r_detailmapping"))
{ {
if (showval) { OSD_Printf("r_detailmapping is %d\n", r_detailmapping); } if (showval) { OSD_Printf("r_detailmapping is %d\n", r_detailmapping); }
@ -6322,10 +6119,6 @@ void polymost_initosdfuncs(void)
#ifdef USE_OPENGL #ifdef USE_OPENGL
OSD_RegisterFunction("r_animsmoothing","r_animsmoothing: enable/disable model animation smoothing",osdcmd_polymostvars); OSD_RegisterFunction("r_animsmoothing","r_animsmoothing: enable/disable model animation smoothing",osdcmd_polymostvars);
OSD_RegisterFunction("r_modelocclusionchecking","r_modelocclusionchecking: enable/disable hack to cull \"obstructed\" models",osdcmd_polymostvars); OSD_RegisterFunction("r_modelocclusionchecking","r_modelocclusionchecking: enable/disable hack to cull \"obstructed\" models",osdcmd_polymostvars);
/*
OSD_RegisterFunction("r_curpeel","r_curpeel: allows to display one depth layer at a time (for development purposes)",osdcmd_polymostvars);
OSD_RegisterFunction("r_depthpeeling","r_depthpeeling: enable/disable order-independant transparency",osdcmd_polymostvars);
*/
OSD_RegisterFunction("r_detailmapping","r_detailmapping: enable/disable detail mapping",osdcmd_polymostvars); OSD_RegisterFunction("r_detailmapping","r_detailmapping: enable/disable detail mapping",osdcmd_polymostvars);
OSD_RegisterFunction("r_downsize","r_downsize: controls downsizing factor for hires textures",osdcmd_polymostvars); OSD_RegisterFunction("r_downsize","r_downsize: controls downsizing factor for hires textures",osdcmd_polymostvars);
OSD_RegisterFunction("r_fullbrights","r_fullbrights: enable/disable fullbright textures",osdcmd_polymostvars); OSD_RegisterFunction("r_fullbrights","r_fullbrights: enable/disable fullbright textures",osdcmd_polymostvars);
@ -6334,7 +6127,6 @@ void polymost_initosdfuncs(void)
OSD_RegisterFunction("r_nvmultisamplehint","r_nvmultisamplehint: enable/disable Nvidia multisampling hinting",osdcmd_polymostvars); OSD_RegisterFunction("r_nvmultisamplehint","r_nvmultisamplehint: enable/disable Nvidia multisampling hinting",osdcmd_polymostvars);
OSD_RegisterFunction("r_parallaxskyclamping","r_parallaxskyclamping: enable/disable parallaxed floor/ceiling sky texture clamping",osdcmd_polymostvars); OSD_RegisterFunction("r_parallaxskyclamping","r_parallaxskyclamping: enable/disable parallaxed floor/ceiling sky texture clamping",osdcmd_polymostvars);
OSD_RegisterFunction("r_parallaxskypanning","r_parallaxskypanning: enable/disable parallaxed floor/ceiling panning when drawing a parallaxed sky",osdcmd_polymostvars); OSD_RegisterFunction("r_parallaxskypanning","r_parallaxskypanning: enable/disable parallaxed floor/ceiling panning when drawing a parallaxed sky",osdcmd_polymostvars);
/* OSD_RegisterFunction("r_peelscount","r_peelscount: sets the number of depth layers for depth peeling",osdcmd_polymostvars);*/
OSD_RegisterFunction("r_polygonmode","r_polygonmode: debugging feature",osdcmd_polymostvars); //FUK OSD_RegisterFunction("r_polygonmode","r_polygonmode: debugging feature",osdcmd_polymostvars); //FUK
OSD_RegisterFunction("r_redbluemode","r_redbluemode: enable/disable experimental OpenGL red-blue glasses mode",osdcmd_polymostvars); OSD_RegisterFunction("r_redbluemode","r_redbluemode: enable/disable experimental OpenGL red-blue glasses mode",osdcmd_polymostvars);
OSD_RegisterFunction("r_shadescale","r_shadescale: multiplier for lighting",osdcmd_polymostvars); OSD_RegisterFunction("r_shadescale","r_shadescale: multiplier for lighting",osdcmd_polymostvars);

View file

@ -592,6 +592,7 @@ static void G_MoveZombieActors(void)
{ {
if (x < 30000) if (x < 30000)
{ {
#ifdef POLYMER
switch (DynamicTileMap[s->picnum]) switch (DynamicTileMap[s->picnum])
{ {
case FLOORFLAME__STATIC: case FLOORFLAME__STATIC:
@ -633,6 +634,7 @@ static void G_MoveZombieActors(void)
break; break;
} }
#endif // POLYMER
ActorExtra[i].timetosleep++; ActorExtra[i].timetosleep++;
if (ActorExtra[i].timetosleep >= (x>>8)) if (ActorExtra[i].timetosleep >= (x>>8))
@ -685,6 +687,8 @@ static void G_MoveZombieActors(void)
ActorExtra[i].timetosleep = 0; ActorExtra[i].timetosleep = 0;
changespritestat(i,6); changespritestat(i,6);
break; break;
case RECON__STATIC:
CS |= 257;
default: default:
ActorExtra[i].timetosleep = 0; ActorExtra[i].timetosleep = 0;
A_PlayAlertSound(i); A_PlayAlertSound(i);
@ -3644,6 +3648,7 @@ static void G_MoveActors(void)
if (s->z < sector[sect].ceilingz+(32<<8)) if (s->z < sector[sect].ceilingz+(32<<8))
s->z = sector[sect].ceilingz+(32<<8); s->z = sector[sect].ceilingz+(32<<8);
#ifdef POLYMER
gamelights[gamelightcount&(PR_MAXLIGHTS-1)].sector = s->sectnum; gamelights[gamelightcount&(PR_MAXLIGHTS-1)].sector = s->sectnum;
gamelights[gamelightcount&(PR_MAXLIGHTS-1)].x = s->x; gamelights[gamelightcount&(PR_MAXLIGHTS-1)].x = s->x;
gamelights[gamelightcount&(PR_MAXLIGHTS-1)].y = s->y; gamelights[gamelightcount&(PR_MAXLIGHTS-1)].y = s->y;
@ -3663,6 +3668,7 @@ static void G_MoveActors(void)
if (gamelightcount < PR_MAXLIGHTS) if (gamelightcount < PR_MAXLIGHTS)
gamelightcount++; gamelightcount++;
#endif // POLYMER
if (ud.multimode < 2) if (ud.multimode < 2)
{ {

View file

@ -278,6 +278,7 @@ static inline int32_t G_GetTeamPalette(int32_t team)
static inline void G_AddGameLight(int32_t radius, int32_t sector, int32_t x, int32_t y, int32_t z, int32_t range, int32_t color, int32_t priority) static inline void G_AddGameLight(int32_t radius, int32_t sector, int32_t x, int32_t y, int32_t z, int32_t range, int32_t color, int32_t priority)
{ {
#ifdef POLYMER
gamelights[gamelightcount&(PR_MAXLIGHTS-1)].radius = radius; gamelights[gamelightcount&(PR_MAXLIGHTS-1)].radius = radius;
gamelights[gamelightcount&(PR_MAXLIGHTS-1)].sector = sector; gamelights[gamelightcount&(PR_MAXLIGHTS-1)].sector = sector;
@ -296,6 +297,16 @@ static inline void G_AddGameLight(int32_t radius, int32_t sector, int32_t x, int
if (gamelightcount < PR_MAXLIGHTS) if (gamelightcount < PR_MAXLIGHTS)
gamelightcount++; gamelightcount++;
#else
UNREFERENCED_PARAMETER(radius);
UNREFERENCED_PARAMETER(sector);
UNREFERENCED_PARAMETER(x);
UNREFERENCED_PARAMETER(y);
UNREFERENCED_PARAMETER(z);
UNREFERENCED_PARAMETER(range);
UNREFERENCED_PARAMETER(color);
UNREFERENCED_PARAMETER(priority);
#endif
} }
extern void se40code(int32_t x,int32_t y,int32_t z,int32_t a,int32_t h, int32_t smoothratio); extern void se40code(int32_t x,int32_t y,int32_t z,int32_t a,int32_t h, int32_t smoothratio);

View file

@ -5938,13 +5938,12 @@ int32_t A_Spawn(int32_t j, int32_t pn)
break; break;
} }
sp->extra = 130; sp->extra = 130;
} CS |= 256; // Make it hitable
} else CS |= 257;
if (sp->picnum == REACTOR || sp->picnum == REACTOR2) if (sp->picnum == REACTOR || sp->picnum == REACTOR2)
sp->extra = g_impactDamage; sp->extra = g_impactDamage;
CS |= 257; // Make it hitable
if (ud.multimode < 2 && sp->pal != 0) if (ud.multimode < 2 && sp->pal != 0)
{ {
sp->xrepeat = sp->yrepeat = 0; sp->xrepeat = sp->yrepeat = 0;
@ -7352,6 +7351,7 @@ PALONLY:
} }
} }
#ifdef POLYMER
switch (DynamicTileMap[s->picnum-1]) switch (DynamicTileMap[s->picnum-1])
{ {
case DIPSWITCH__STATIC: case DIPSWITCH__STATIC:
@ -7391,9 +7391,10 @@ PALONLY:
break; break;
} }
#endif
switch (DynamicTileMap[s->picnum]) switch (DynamicTileMap[s->picnum])
{ {
#ifdef POLYMER
case DIPSWITCH__STATIC: case DIPSWITCH__STATIC:
case DIPSWITCH2__STATIC: case DIPSWITCH2__STATIC:
case DIPSWITCH3__STATIC: case DIPSWITCH3__STATIC:
@ -7430,7 +7431,7 @@ PALONLY:
framelightcount++; framelightcount++;
break; break;
#endif
case LASERLINE__STATIC: case LASERLINE__STATIC:
if (sector[t->sectnum].lotag == 2) t->pal = 8; if (sector[t->sectnum].lotag == 2) t->pal = 8;
t->z = sprite[s->owner].z-(3<<8); t->z = sprite[s->owner].z-(3<<8);
@ -12812,8 +12813,10 @@ static int32_t G_DoMoveThings(void)
if (ud.recstat == 1) G_DemoRecord(); if (ud.recstat == 1) G_DemoRecord();
#ifdef POLYMER
if (ud.pause_on == 0) if (ud.pause_on == 0)
gamelightcount = 0; gamelightcount = 0;
#endif
if (ud.pause_on == 0) if (ud.pause_on == 0)
{ {

View file

@ -5108,7 +5108,10 @@ repeatcase:
struct stat st; struct stat st;
int32_t fullscreen = ud.config.ScreenMode; int32_t fullscreen = ud.config.ScreenMode;
int32_t xdim = ud.config.ScreenWidth, ydim = ud.config.ScreenHeight, bpp = ud.config.ScreenBPP; int32_t xdim = ud.config.ScreenWidth, ydim = ud.config.ScreenHeight, bpp = ud.config.ScreenBPP;
int32_t usemouse = ud.config.UseMouse, usejoy = ud.config.UseJoystick, glrm = glrendmode; int32_t usemouse = ud.config.UseMouse, usejoy = ud.config.UseJoystick;
#ifdef POLYMOST
int32_t glrm = glrendmode;
#endif
if (stat(mod_dir, &st) < 0) if (stat(mod_dir, &st) < 0)
{ {
@ -5150,7 +5153,10 @@ repeatcase:
ud.config.ScreenBPP = bpp; ud.config.ScreenBPP = bpp;
ud.config.UseMouse = usemouse; ud.config.UseMouse = usemouse;
ud.config.UseJoystick = usejoy; ud.config.UseJoystick = usejoy;
#ifdef POLYMOST
glrendmode = glrm; glrendmode = glrm;
#endif // POLYMOST
} }
} }
return 0; return 0;

View file

@ -3327,7 +3327,14 @@ cheat_for_port_credits:
nydim = (newvidmode==validmodecnt)?ydim:validmode[newvidmode].ydim; nydim = (newvidmode==validmodecnt)?ydim:validmode[newvidmode].ydim;
nfs = newfullscreen; nfs = newfullscreen;
nbpp = (newvidmode==validmodecnt)?bpp:validmode[newvidmode].bpp; nbpp = (newvidmode==validmodecnt)?bpp:validmode[newvidmode].bpp;
nrend = (vidsets[newvidset] & 0x20000) ? (nbpp==8?2:glrendmode) : 0; nrend = (vidsets[newvidset] & 0x20000) ? (nbpp==8?2:
#ifdef POLYMOST
glrendmode
#else
0
#endif // POLYMOST
) : 0;
if (setgamemode(nfs, nxdim, nydim, nbpp) < 0) if (setgamemode(nfs, nxdim, nydim, nbpp) < 0)
{ {

View file

@ -345,6 +345,7 @@ int32_t A_Shoot(int32_t i,int32_t atwith)
} }
} }
#ifdef POLYMER
switch (DynamicTileMap[atwith]) switch (DynamicTileMap[atwith])
{ {
case FIRELASER__STATIC: case FIRELASER__STATIC:
@ -378,12 +379,14 @@ int32_t A_Shoot(int32_t i,int32_t atwith)
gamelightcount++; gamelightcount++;
break; break;
} }
#endif // POLYMER
} }
if (A_CheckSpriteTileFlags(atwith,SPRITE_PROJECTILE)) if (A_CheckSpriteTileFlags(atwith,SPRITE_PROJECTILE))
{ {
/* Custom projectiles. This is a big hack. */ /* Custom projectiles. This is a big hack. */
#ifdef POLYMER
if (ProjectileData[atwith].flashcolor) if (ProjectileData[atwith].flashcolor)
{ {
G_AddGameLight(0, s->sectnum, s->x+((sintable[(s->ang+512)&2047])>>7), G_AddGameLight(0, s->sectnum, s->x+((sintable[(s->ang+512)&2047])>>7),
@ -409,6 +412,7 @@ int32_t A_Shoot(int32_t i,int32_t atwith)
if (gamelightcount < PR_MAXLIGHTS) if (gamelightcount < PR_MAXLIGHTS)
gamelightcount++; gamelightcount++;
} }
#endif // POLYMER
if (ProjectileData[atwith].offset == 0) ProjectileData[atwith].offset = 1; if (ProjectileData[atwith].offset == 0) ProjectileData[atwith].offset = 1;
@ -2171,11 +2175,15 @@ void P_FireWeapon(DukePlayer_t *p)
if (!(aplWeaponFlags[p->curr_weapon][snum] & WEAPON_NOVISIBLE)) if (!(aplWeaponFlags[p->curr_weapon][snum] & WEAPON_NOVISIBLE))
{ {
#ifdef POLYMER
spritetype *s = &sprite[p->i]; spritetype *s = &sprite[p->i];
#endif // POLYMER
lastvisinc = totalclock+32; lastvisinc = totalclock+32;
p->visibility = 0; p->visibility = 0;
#ifdef POLYMER
G_AddGameLight(0, s->sectnum, s->x+((sintable[(p->ang+512)&2047])>>7), s->y+((sintable[(p->ang)&2047])>>7), G_AddGameLight(0, s->sectnum, s->x+((sintable[(p->ang+512)&2047])>>7), s->y+((sintable[(p->ang)&2047])>>7),
s->z-PHEIGHT, 4096, aplWeaponFlashColor[p->curr_weapon][snum],1); s->z-PHEIGHT, 4096, aplWeaponFlashColor[p->curr_weapon][snum],1);
@ -2199,6 +2207,7 @@ void P_FireWeapon(DukePlayer_t *p)
if (gamelightcount < PR_MAXLIGHTS) if (gamelightcount < PR_MAXLIGHTS)
gamelightcount++; gamelightcount++;
#endif // POLYMER
} }
/* if( //!(aplWeaponFlags[p->curr_weapon][snum] & WEAPON_CHECKATRELOAD) && /* if( //!(aplWeaponFlags[p->curr_weapon][snum] & WEAPON_CHECKATRELOAD) &&

View file

@ -240,8 +240,13 @@ int32_t G_LoadPlayer(int32_t spot)
if (kdfread(&sector[0],sizeof(sectortype),MAXSECTORS,fil) != MAXSECTORS) goto corrupt; if (kdfread(&sector[0],sizeof(sectortype),MAXSECTORS,fil) != MAXSECTORS) goto corrupt;
if (kdfread(&sprite[0],sizeof(spritetype),MAXSPRITES,fil) != MAXSPRITES) goto corrupt; if (kdfread(&sprite[0],sizeof(spritetype),MAXSPRITES,fil) != MAXSPRITES) goto corrupt;
if (kdfread(&spriteext[0],sizeof(spriteext_t),MAXSPRITES,fil) != MAXSPRITES) goto corrupt; if (kdfread(&spriteext[0],sizeof(spriteext_t),MAXSPRITES,fil) != MAXSPRITES) goto corrupt;
#ifdef POLYMER
if (kdfread(&staticlightcount,sizeof(int32_t),1,fil) != 1) goto corrupt; if (kdfread(&staticlightcount,sizeof(int32_t),1,fil) != 1) goto corrupt;
if (kdfread(&staticlights[0],sizeof(_prlight),PR_MAXLIGHTS,fil) != PR_MAXLIGHTS) goto corrupt; if (kdfread(&staticlights[0],sizeof(_prlight),staticlightcount,fil) != staticlightcount) goto corrupt;
#else
if (kdfread(&i,sizeof(int32_t),1,fil) != 1) goto corrupt;
#endif // POLYMER
#if defined(POLYMOST) && defined(USE_OPENGL) #if defined(POLYMOST) && defined(USE_OPENGL)
for (i=0; i<MAXSPRITES; i++) for (i=0; i<MAXSPRITES; i++)
@ -681,8 +686,15 @@ int32_t G_SavePlayer(int32_t spot)
} }
#endif #endif
dfwrite(&spriteext[0],sizeof(spriteext_t),MAXSPRITES,fil); dfwrite(&spriteext[0],sizeof(spriteext_t),MAXSPRITES,fil);
#ifdef POLYMER
dfwrite(&staticlightcount,sizeof(int32_t),1,fil); dfwrite(&staticlightcount,sizeof(int32_t),1,fil);
dfwrite(&staticlights[0],sizeof(_prlight),PR_MAXLIGHTS,fil); dfwrite(&staticlights[0],sizeof(_prlight),staticlightcount,fil);
#else
i = 0;
dfwrite(&i,sizeof(int32_t),1,fil);
#endif // POLYMER
#if defined(POLYMOST) && defined(USE_OPENGL) #if defined(POLYMOST) && defined(USE_OPENGL)
for (i=0; i<MAXSPRITES; i++)if (spriteext[i].mdanimtims)spriteext[i].mdanimtims+=mdtims; for (i=0; i<MAXSPRITES; i++)if (spriteext[i].mdanimtims)spriteext[i].mdanimtims+=mdtims;
#endif #endif