mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Moved sprite flipping in the material code and implemented polymost texture scaling.
git-svn-id: https://svn.eduke32.com/eduke32@1164 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
e884cef8df
commit
b60ee26a25
2 changed files with 20 additions and 11 deletions
|
@ -45,6 +45,7 @@ extern int glerror;
|
||||||
// MATERIAL
|
// MATERIAL
|
||||||
typedef struct s_prmaterial {
|
typedef struct s_prmaterial {
|
||||||
GLuint diffusemap;
|
GLuint diffusemap;
|
||||||
|
GLfloat diffusescalex, diffusescaley;
|
||||||
GLfloat diffusemodulation[4];
|
GLfloat diffusemodulation[4];
|
||||||
GLuint glowmap;
|
GLuint glowmap;
|
||||||
} _prmaterial;
|
} _prmaterial;
|
||||||
|
|
|
@ -129,7 +129,7 @@ _prprogrambit prprogrambits[PR_BIT_COUNT] = {
|
||||||
// vert_def
|
// vert_def
|
||||||
"",
|
"",
|
||||||
// vert_prog
|
// vert_prog
|
||||||
"gl_TexCoord[0] = gl_MultiTexCoord0;\n"
|
"gl_TexCoord[0] = gl_TextureMatrix[0] * gl_MultiTexCoord0;\n"
|
||||||
"\n",
|
"\n",
|
||||||
// frag_def
|
// frag_def
|
||||||
"uniform sampler2D diffuseMap;\n"
|
"uniform sampler2D diffuseMap;\n"
|
||||||
|
@ -621,23 +621,20 @@ void polymer_drawsprite(int snum)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
bglMatrixMode(GL_TEXTURE);
|
|
||||||
bglLoadIdentity();
|
|
||||||
|
|
||||||
if ((tspr->cstat & 4) || (((tspr->cstat>>4) & 3) == 2))
|
if ((tspr->cstat & 4) || (((tspr->cstat>>4) & 3) == 2))
|
||||||
bglScalef(-1.0f, 1.0f, 1.0f);
|
spriteplane.material.diffusescalex = -spriteplane.material.diffusescalex;
|
||||||
|
|
||||||
if (tspr->cstat & 8)
|
if (tspr->cstat & 8)
|
||||||
bglScalef(1.0f, -1.0f, 1.0f);
|
spriteplane.material.diffusescaley = -spriteplane.material.diffusescaley;
|
||||||
|
|
||||||
if ((tspr->cstat & 64) && (((tspr->cstat>>4) & 3) == 1))
|
if ((tspr->cstat & 64) && (((tspr->cstat>>4) & 3) == 1))
|
||||||
bglEnable(GL_CULL_FACE);
|
bglEnable(GL_CULL_FACE);
|
||||||
|
|
||||||
bglEnable(GL_POLYGON_OFFSET_FILL);
|
// bglEnable(GL_POLYGON_OFFSET_FILL);
|
||||||
|
|
||||||
polymer_drawplane(-1, -3, &spriteplane, 0);
|
polymer_drawplane(-1, -3, &spriteplane, 0);
|
||||||
|
|
||||||
bglDisable(GL_POLYGON_OFFSET_FILL);
|
// bglDisable(GL_POLYGON_OFFSET_FILL);
|
||||||
|
|
||||||
if ((tspr->cstat & 64) && (((tspr->cstat>>4) & 3) == 1))
|
if ((tspr->cstat & 64) && (((tspr->cstat>>4) & 3) == 1))
|
||||||
bglDisable(GL_CULL_FACE);
|
bglDisable(GL_CULL_FACE);
|
||||||
|
@ -1529,7 +1526,6 @@ static void polymer_updatewall(short wallnum)
|
||||||
sectortype *sec, *nsec;
|
sectortype *sec, *nsec;
|
||||||
_prwall *w;
|
_prwall *w;
|
||||||
_prsector *s, *ns;
|
_prsector *s, *ns;
|
||||||
pthtyp* pth;
|
|
||||||
int xref, yref;
|
int xref, yref;
|
||||||
float ypancoef, dist;
|
float ypancoef, dist;
|
||||||
int i;
|
int i;
|
||||||
|
@ -2451,6 +2447,15 @@ static void polymer_getmaterial(_prmaterial* material, short tilenum, ch
|
||||||
|
|
||||||
pth = gltexcache(tilenum, pal, 0);
|
pth = gltexcache(tilenum, pal, 0);
|
||||||
|
|
||||||
|
material->diffusemap = (pth) ? pth->glpic : 0;
|
||||||
|
|
||||||
|
if (pth->hicr)
|
||||||
|
{
|
||||||
|
material->diffusescalex = pth->hicr->xscale;
|
||||||
|
material->diffusescaley = pth->hicr->yscale;
|
||||||
|
} else
|
||||||
|
material->diffusescalex = material->diffusescaley = 1.0f;
|
||||||
|
|
||||||
material->diffusemodulation[0] =
|
material->diffusemodulation[0] =
|
||||||
material->diffusemodulation[1] =
|
material->diffusemodulation[1] =
|
||||||
material->diffusemodulation[2] =
|
material->diffusemodulation[2] =
|
||||||
|
@ -2463,8 +2468,6 @@ static void polymer_getmaterial(_prmaterial* material, short tilenum, ch
|
||||||
material->diffusemodulation[1] *= (float)hictinting[pal].g / 255.0;
|
material->diffusemodulation[1] *= (float)hictinting[pal].g / 255.0;
|
||||||
material->diffusemodulation[2] *= (float)hictinting[pal].b / 255.0;
|
material->diffusemodulation[2] *= (float)hictinting[pal].b / 255.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
material->diffusemap = (pth) ? pth->glpic : 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void polymer_bindmaterial(_prmaterial material)
|
static void polymer_bindmaterial(_prmaterial material)
|
||||||
|
@ -2494,6 +2497,11 @@ static void polymer_bindmaterial(_prmaterial material)
|
||||||
if (programbits & prprogrambits[PR_BIT_DIFFUSE_MAP].bit)
|
if (programbits & prprogrambits[PR_BIT_DIFFUSE_MAP].bit)
|
||||||
{
|
{
|
||||||
bglBindTexture(GL_TEXTURE_2D, material.diffusemap);
|
bglBindTexture(GL_TEXTURE_2D, material.diffusemap);
|
||||||
|
|
||||||
|
bglMatrixMode(GL_TEXTURE);
|
||||||
|
bglLoadIdentity();
|
||||||
|
bglScalef(material.diffusescalex, material.diffusescaley, 1.0f);
|
||||||
|
bglMatrixMode(GL_MODELVIEW);
|
||||||
}
|
}
|
||||||
|
|
||||||
// PR_BIT_DIFFUSE_MODULATION
|
// PR_BIT_DIFFUSE_MODULATION
|
||||||
|
|
Loading…
Reference in a new issue