mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-13 21:31:32 +00:00
Backport from SRB2: Replace NextTexAvail with glGenTextures
This commit is contained in:
parent
ee0bba26f4
commit
f3bdcb4ec3
1 changed files with 14 additions and 19 deletions
|
@ -44,7 +44,6 @@ static const GLubyte white[4] = { 255, 255, 255, 255 };
|
||||||
|
|
||||||
// With OpenGL 1.1+, the first texture should be 1
|
// With OpenGL 1.1+, the first texture should be 1
|
||||||
#define NOTEXTURE_NUM 0
|
#define NOTEXTURE_NUM 0
|
||||||
#define FIRST_TEX_AVAIL (NOTEXTURE_NUM + 1)
|
|
||||||
|
|
||||||
#define N_PI_DEMI (M_PIl/2.0f) //(1.5707963268f)
|
#define N_PI_DEMI (M_PIl/2.0f) //(1.5707963268f)
|
||||||
|
|
||||||
|
@ -57,7 +56,6 @@ static float NEAR_CLIPPING_PLANE = NZCLIP_PLANE;
|
||||||
// **************************************************************************
|
// **************************************************************************
|
||||||
|
|
||||||
|
|
||||||
static GLuint NextTexAvail = FIRST_TEX_AVAIL;
|
|
||||||
static GLuint tex_downloaded = 0;
|
static GLuint tex_downloaded = 0;
|
||||||
static GLfloat fov = 90.0f;
|
static GLfloat fov = 90.0f;
|
||||||
static FBITFIELD CurrentPolyFlags;
|
static FBITFIELD CurrentPolyFlags;
|
||||||
|
@ -91,16 +89,10 @@ static GLint viewport[4];
|
||||||
GLubyte palette_tex[256*3];
|
GLubyte palette_tex[256*3];
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Yay for arbitrary numbers! NextTexAvail is buggy for some reason.
|
|
||||||
// Sryder: NextTexAvail is broken for these because palette changes or changes to the texture filter or antialiasing
|
// Sryder: NextTexAvail is broken for these because palette changes or changes to the texture filter or antialiasing
|
||||||
// flush all of the stored textures, leaving them unavailable at times such as between levels
|
// flush all of the stored textures, leaving them unavailable at times such as between levels
|
||||||
// These need to start at 0 and be set to their number, and be reset to 0 when deleted so that Intel GPUs
|
// These need to start at 0 and be set to their number, and be reset to 0 when deleted so that Intel GPUs
|
||||||
// can know when the textures aren't there, as textures are always considered resident in their virtual memory
|
// can know when the textures aren't there, as textures are always considered resident in their virtual memory
|
||||||
// TODO: Store them in a more normal way
|
|
||||||
#define SCRTEX_SCREENTEXTURE 4294967295U
|
|
||||||
#define SCRTEX_STARTSCREENWIPE 4294967294U
|
|
||||||
#define SCRTEX_ENDSCREENWIPE 4294967293U
|
|
||||||
#define SCRTEX_FINALSCREENTEXTURE 4294967292U
|
|
||||||
static GLuint screentexture = 0;
|
static GLuint screentexture = 0;
|
||||||
static GLuint startScreenWipe = 0;
|
static GLuint startScreenWipe = 0;
|
||||||
static GLuint endScreenWipe = 0;
|
static GLuint endScreenWipe = 0;
|
||||||
|
@ -1014,7 +1006,7 @@ void SetStates(void)
|
||||||
CurrentPolyFlags = 0xffffffff;
|
CurrentPolyFlags = 0xffffffff;
|
||||||
SetBlend(0);
|
SetBlend(0);
|
||||||
|
|
||||||
tex_downloaded = (GLuint)-1;
|
//tex_downloaded = (GLuint)-1;
|
||||||
SetNoTexture();
|
SetNoTexture();
|
||||||
|
|
||||||
pglPolygonOffset(-1.0f, -1.0f);
|
pglPolygonOffset(-1.0f, -1.0f);
|
||||||
|
@ -1037,12 +1029,12 @@ void Flush(void)
|
||||||
{
|
{
|
||||||
// ceci n'est pas du tout necessaire vu que tu les a charger normalement et
|
// ceci n'est pas du tout necessaire vu que tu les a charger normalement et
|
||||||
// donc il sont dans ta liste !
|
// donc il sont dans ta liste !
|
||||||
pglDeleteTextures(1, (GLuint *)&gr_cachehead->downloaded);
|
if (gr_cachehead->downloaded)
|
||||||
|
pglDeleteTextures(1, (GLuint *)&gr_cachehead->downloaded);
|
||||||
gr_cachehead->downloaded = 0;
|
gr_cachehead->downloaded = 0;
|
||||||
gr_cachehead = gr_cachehead->nextmipmap;
|
gr_cachehead = gr_cachehead->nextmipmap;
|
||||||
}
|
}
|
||||||
gr_cachetail = gr_cachehead = NULL; //Hurdler: well, gr_cachehead is already NULL
|
gr_cachetail = gr_cachehead = NULL; //Hurdler: well, gr_cachehead is already NULL
|
||||||
NextTexAvail = FIRST_TEX_AVAIL;
|
|
||||||
|
|
||||||
tex_downloaded = 0;
|
tex_downloaded = 0;
|
||||||
}
|
}
|
||||||
|
@ -1415,8 +1407,10 @@ EXPORT void HWRAPI(SetTexture) (FTextureInfo *pTexInfo)
|
||||||
static RGBA_t tex[2048*2048];
|
static RGBA_t tex[2048*2048];
|
||||||
const GLvoid *ptex = tex;
|
const GLvoid *ptex = tex;
|
||||||
INT32 w, h;
|
INT32 w, h;
|
||||||
|
GLuint texnum = 0;
|
||||||
|
|
||||||
//GL_DBG_Printf("DownloadMipmap %d\n", NextTexAvail, pTexInfo->grInfo.data);
|
pglGenTextures(1, &texnum);
|
||||||
|
//GL_DBG_Printf("DownloadMipmap %d\n", (INT32)texnum, pTexInfo->grInfo.data);
|
||||||
|
|
||||||
w = pTexInfo->width;
|
w = pTexInfo->width;
|
||||||
h = pTexInfo->height;
|
h = pTexInfo->height;
|
||||||
|
@ -1515,9 +1509,10 @@ EXPORT void HWRAPI(SetTexture) (FTextureInfo *pTexInfo)
|
||||||
else
|
else
|
||||||
GL_DBG_Printf("SetTexture(bad format) %ld\n", pTexInfo->grInfo.format);
|
GL_DBG_Printf("SetTexture(bad format) %ld\n", pTexInfo->grInfo.format);
|
||||||
|
|
||||||
pTexInfo->downloaded = NextTexAvail++;
|
// the texture number was already generated by pglGenTextures
|
||||||
tex_downloaded = pTexInfo->downloaded;
|
pglBindTexture(GL_TEXTURE_2D, texnum);
|
||||||
pglBindTexture(GL_TEXTURE_2D, pTexInfo->downloaded);
|
pTexInfo->downloaded = texnum;
|
||||||
|
tex_downloaded = texnum;
|
||||||
|
|
||||||
// disable texture filtering on any texture that has holes so there's no dumb borders or blending issues
|
// disable texture filtering on any texture that has holes so there's no dumb borders or blending issues
|
||||||
if (pTexInfo->flags & TF_TRANSPARENT)
|
if (pTexInfo->flags & TF_TRANSPARENT)
|
||||||
|
@ -2914,7 +2909,7 @@ EXPORT void HWRAPI(StartScreenWipe) (void)
|
||||||
|
|
||||||
// Create screen texture
|
// Create screen texture
|
||||||
if (firstTime)
|
if (firstTime)
|
||||||
startScreenWipe = SCRTEX_STARTSCREENWIPE;
|
pglGenTextures(1, &startScreenWipe);
|
||||||
pglBindTexture(GL_TEXTURE_2D, startScreenWipe);
|
pglBindTexture(GL_TEXTURE_2D, startScreenWipe);
|
||||||
|
|
||||||
if (firstTime)
|
if (firstTime)
|
||||||
|
@ -2945,7 +2940,7 @@ EXPORT void HWRAPI(EndScreenWipe)(void)
|
||||||
|
|
||||||
// Create screen texture
|
// Create screen texture
|
||||||
if (firstTime)
|
if (firstTime)
|
||||||
endScreenWipe = SCRTEX_ENDSCREENWIPE;
|
pglGenTextures(1, &endScreenWipe);
|
||||||
pglBindTexture(GL_TEXTURE_2D, endScreenWipe);
|
pglBindTexture(GL_TEXTURE_2D, endScreenWipe);
|
||||||
|
|
||||||
if (firstTime)
|
if (firstTime)
|
||||||
|
@ -3105,7 +3100,7 @@ EXPORT void HWRAPI(MakeScreenTexture) (void)
|
||||||
|
|
||||||
// Create screen texture
|
// Create screen texture
|
||||||
if (firstTime)
|
if (firstTime)
|
||||||
screentexture = SCRTEX_SCREENTEXTURE;
|
pglGenTextures(1, &screentexture);
|
||||||
pglBindTexture(GL_TEXTURE_2D, screentexture);
|
pglBindTexture(GL_TEXTURE_2D, screentexture);
|
||||||
|
|
||||||
if (firstTime)
|
if (firstTime)
|
||||||
|
@ -3135,7 +3130,7 @@ EXPORT void HWRAPI(MakeScreenFinalTexture) (void)
|
||||||
|
|
||||||
// Create screen texture
|
// Create screen texture
|
||||||
if (firstTime)
|
if (firstTime)
|
||||||
finalScreenTexture = SCRTEX_FINALSCREENTEXTURE;
|
pglGenTextures(1, &finalScreenTexture);
|
||||||
pglBindTexture(GL_TEXTURE_2D, finalScreenTexture);
|
pglBindTexture(GL_TEXTURE_2D, finalScreenTexture);
|
||||||
|
|
||||||
if (firstTime)
|
if (firstTime)
|
||||||
|
|
Loading…
Reference in a new issue