return;
}
- poly = Hunk_Alloc (sizeof(glpoly_t) + (numverts-4) * VERTEXSIZE*sizeof(float));
+ poly = Hunk_AllocName (sizeof(glpoly_t) + (numverts-4) * VERTEXSIZE*sizeof(float), "surfaces");
poly->next = warpface->polys;
warpface->polys = poly;
poly->numverts = numverts;
-extern qboolean lighthalf;
-
-#define SKY_TEX 4000
+int skyboxside[6];
char skyname[256];
// LordHavoc: moved LoadTGA and LoadPCX to gl_draw.c
-extern int image_width, image_height;
-
-byte* loadimagepixels (char* filename, qboolean complain, int matchwidth, int matchheight);
/*
==================
R_LoadSkyBox
void R_LoadSkyBox (void)
{
int i;
- char name[64];
+ char name[1024];
byte* image_rgba;
+ if (strlen(skyname) >= 1000)
+ {
+ Con_Printf ("sky name too long (%i, max is 1000)\n", strlen(skyname));
+ return;
+ }
for (i=0 ; i<6 ; i++)
{
- glBindTexture(GL_TEXTURE_2D, SKY_TEX + i);
sprintf (name, "env/%s%s", skyname, suf[i]);
if (!(image_rgba = loadimagepixels(name, FALSE, 0, 0)))
{
continue;
}
}
- glTexImage2D (GL_TEXTURE_2D, 0, gl_solid_format, image_width, image_height, 0, GL_RGBA, GL_UNSIGNED_BYTE, image_rgba);
- free (image_rgba);
- glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
- glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
+ skyboxside[i] = GL_LoadTexture(va("skyboxside%d", i), image_width, image_height, image_rgba, false, false, 4);
+ qfree(image_rgba);
}
}
}
}
-extern cvar_t r_skyboxsize;
+extern cvar_t r_farclip;
#define R_SkyBoxPolyVec(s,t,x,y,z) \
glTexCoord2f((s) * (254.0f/256.0f) + (1.0f/256.0f), (t) * (254.0f/256.0f) + (1.0f/256.0f));\
glColor3f(0.5,0.5,0.5);
else
glColor3f(1,1,1);
- glBindTexture(GL_TEXTURE_2D, SKY_TEX + 3); // front
+ glBindTexture(GL_TEXTURE_2D, skyboxside[3]); // front
glBegin(GL_QUADS);
R_SkyBoxPolyVec(1, 0, 1, -1, 1);
R_SkyBoxPolyVec(1, 1, 1, -1, -1);
R_SkyBoxPolyVec(0, 1, 1, 1, -1);
R_SkyBoxPolyVec(0, 0, 1, 1, 1);
glEnd();
- glBindTexture(GL_TEXTURE_2D, SKY_TEX + 1); // back
+ glBindTexture(GL_TEXTURE_2D, skyboxside[1]); // back
glBegin(GL_QUADS);
R_SkyBoxPolyVec(1, 0, -1, 1, 1);
R_SkyBoxPolyVec(1, 1, -1, 1, -1);
R_SkyBoxPolyVec(0, 1, -1, -1, -1);
R_SkyBoxPolyVec(0, 0, -1, -1, 1);
glEnd();
- glBindTexture(GL_TEXTURE_2D, SKY_TEX + 0); // right
+ glBindTexture(GL_TEXTURE_2D, skyboxside[0]); // right
glBegin(GL_QUADS);
R_SkyBoxPolyVec(1, 0, 1, 1, 1);
R_SkyBoxPolyVec(1, 1, 1, 1, -1);
R_SkyBoxPolyVec(0, 1, -1, 1, -1);
R_SkyBoxPolyVec(0, 0, -1, 1, 1);
glEnd();
- glBindTexture(GL_TEXTURE_2D, SKY_TEX + 2); // left
+ glBindTexture(GL_TEXTURE_2D, skyboxside[2]); // left
glBegin(GL_QUADS);
R_SkyBoxPolyVec(1, 0, -1, -1, 1);
R_SkyBoxPolyVec(1, 1, -1, -1, -1);
R_SkyBoxPolyVec(0, 1, 1, -1, -1);
R_SkyBoxPolyVec(0, 0, 1, -1, 1);
glEnd();
- glBindTexture(GL_TEXTURE_2D, SKY_TEX + 4); // up
+ glBindTexture(GL_TEXTURE_2D, skyboxside[4]); // up
glBegin(GL_QUADS);
R_SkyBoxPolyVec(1, 0, 1, -1, 1);
R_SkyBoxPolyVec(1, 1, 1, 1, 1);
R_SkyBoxPolyVec(0, 1, -1, 1, 1);
R_SkyBoxPolyVec(0, 0, -1, -1, 1);
glEnd();
- glBindTexture(GL_TEXTURE_2D, SKY_TEX + 5); // down
+ glBindTexture(GL_TEXTURE_2D, skyboxside[5]); // down
glBegin(GL_QUADS);
R_SkyBoxPolyVec(1, 0, 1, 1, -1);
R_SkyBoxPolyVec(1, 1, 1, -1, -1);
skydomecalc(skydomeouter, 1024, 1024, 256);
skydomecalc(skydomeinner, 512, 512, 128);
}
- speedscale = realtime*8.0/256.0;
+ speedscale = cl.time*8.0/256.0;
speedscale -= (int)speedscale;
skydome(skydomeouter, speedscale, 1.0 / 256.0);
glEnable (GL_BLEND);
glBindTexture(GL_TEXTURE_2D, alphaskytexture); // lower clouds
- speedscale = realtime*8.0/128.0;
+ speedscale = cl.time*8.0/128.0;
speedscale -= (int)speedscale;
skydome(skydomeinner, speedscale, 1.0 / 128.0);
glDisable (GL_BLEND);
void R_Sky()
{
+ if (!r_render.value)
+ return;
if (!skyname[0])
return;
glDisable(GL_DEPTH_TEST);
A sky texture is 256*128, with the right side being a masked overlay
==============
*/
-// LordHavoc: changed this for GLQuake
-void R_InitSky (byte *src, int bytesperpixel) //texture_t *mt)
+void R_InitSky (byte *src, int bytesperpixel)
{
int i, j, p;
-// byte *src;
unsigned trans[128*128];
unsigned transpix;
int r, g, b;
unsigned *rgba;
- extern int skytexturenum;
-
-// src = (byte *)mt + mt->offsets[0];
if (bytesperpixel == 4)
{
((byte *)&transpix)[3] = 0;
}
- if (!solidskytexture)
- solidskytexture = texture_extension_number++;
- if (!isDedicated)
- {
- glBindTexture(GL_TEXTURE_2D, solidskytexture );
- glTexImage2D (GL_TEXTURE_2D, 0, gl_solid_format, 128, 128, 0, GL_RGBA, GL_UNSIGNED_BYTE, trans);
- glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
- glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
- }
-
+ solidskytexture = GL_LoadTexture ("sky_solidtexture", 128, 128, (byte *) trans, false, false, 4);
if (bytesperpixel == 4)
{
}
}
- if (!alphaskytexture)
- alphaskytexture = texture_extension_number++;
- if (!isDedicated)
- {
- glBindTexture(GL_TEXTURE_2D, alphaskytexture);
- glTexImage2D (GL_TEXTURE_2D, 0, gl_alpha_format, 128, 128, 0, GL_RGBA, GL_UNSIGNED_BYTE, trans);
- glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
- glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
- }
+ alphaskytexture = GL_LoadTexture ("sky_alphatexture", 128, 128, (byte *) trans, false, true, 4);
}