mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
Polymer: Make ART mapping work with any number of shade offsets (eg. BLOOD pal)
git-svn-id: https://svn.eduke32.com/eduke32@3740 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
3d65b36ebe
commit
ce76b5a3b8
1 changed files with 15 additions and 15 deletions
|
@ -276,19 +276,19 @@ _prprogrambit prprogrambits[PR_BIT_COUNT] = {
|
||||||
// frag_def
|
// frag_def
|
||||||
"uniform sampler2D artMap;\n"
|
"uniform sampler2D artMap;\n"
|
||||||
"uniform sampler2D basePalMap;\n"
|
"uniform sampler2D basePalMap;\n"
|
||||||
"uniform sampler2D lookupMap;\n"
|
"uniform sampler2DRect lookupMap;\n"
|
||||||
"uniform float shadeOffset;\n"
|
"uniform float shadeOffset;\n"
|
||||||
"uniform float visibility;\n"
|
"uniform float visibility;\n"
|
||||||
"varying vec3 horizDistance;\n"
|
"varying vec3 horizDistance;\n"
|
||||||
"\n",
|
"\n",
|
||||||
// frag_prog
|
// frag_prog
|
||||||
" float shadeLookup = length(horizDistance) / 1.024 * visibility;\n"
|
" float shadeLookup = length(horizDistance) / 1.024 * visibility;\n"
|
||||||
" shadeLookup = clamp(shadeLookup + shadeOffset, 0.0, 32.0);\n"
|
" shadeLookup = shadeLookup + shadeOffset;\n"
|
||||||
"\n"
|
"\n"
|
||||||
" float colorIndex = texture2D(artMap, commonTexCoord.st).r;\n"
|
" float colorIndex = texture2D(artMap, commonTexCoord.st).r * 256.0;\n"
|
||||||
" float colorIndexNear = texture2D(lookupMap, vec2(colorIndex, floor(shadeLookup) / 32.0)).r;\n"
|
" float colorIndexNear = texture2DRect(lookupMap, vec2(colorIndex, floor(shadeLookup))).r;\n"
|
||||||
" float colorIndexFar = texture2D(lookupMap, vec2(colorIndex, min(floor(shadeLookup + 1.0), 32.0) / 32.0)).r;\n"
|
" float colorIndexFar = texture2DRect(lookupMap, vec2(colorIndex, floor(shadeLookup + 1.0))).r;\n"
|
||||||
" float colorIndexFullbright = texture2D(lookupMap, vec2(colorIndex, 0.0)).r;\n"
|
" float colorIndexFullbright = texture2DRect(lookupMap, vec2(colorIndex, 0.0)).r;\n"
|
||||||
"\n"
|
"\n"
|
||||||
" vec3 texelNear = texture2D(basePalMap, vec2(colorIndexNear, 0.5)).rgb;\n"
|
" vec3 texelNear = texture2D(basePalMap, vec2(colorIndexNear, 0.5)).rgb;\n"
|
||||||
" vec3 texelFar = texture2D(basePalMap, vec2(colorIndexFar, 0.5)).rgb;\n"
|
" vec3 texelFar = texture2D(basePalMap, vec2(colorIndexFar, 0.5)).rgb;\n"
|
||||||
|
@ -297,7 +297,7 @@ _prprogrambit prprogrambits[PR_BIT_COUNT] = {
|
||||||
" if (isLightingPass == 0) {\n"
|
" if (isLightingPass == 0) {\n"
|
||||||
" result.rgb = mix(texelNear, texelFar, fract(shadeLookup)) * 4.0;\n"
|
" result.rgb = mix(texelNear, texelFar, fract(shadeLookup)) * 4.0;\n"
|
||||||
" result.a = 1.0;\n"
|
" result.a = 1.0;\n"
|
||||||
" if (colorIndex == 1.0)\n"
|
" if (colorIndex == 256.0)\n"
|
||||||
" result.a = 0.0;\n"
|
" result.a = 0.0;\n"
|
||||||
" }\n"
|
" }\n"
|
||||||
"\n",
|
"\n",
|
||||||
|
@ -4626,8 +4626,8 @@ static void polymer_getbuildmaterial(_prmaterial* material, int16_t tile
|
||||||
|
|
||||||
if (!prlookups[pal]) {
|
if (!prlookups[pal]) {
|
||||||
bglGenTextures(1, &prlookups[pal]);
|
bglGenTextures(1, &prlookups[pal]);
|
||||||
bglBindTexture(GL_TEXTURE_2D, prlookups[pal]);
|
bglBindTexture(GL_TEXTURE_RECTANGLE, prlookups[pal]);
|
||||||
bglTexImage2D(GL_TEXTURE_2D,
|
bglTexImage2D(GL_TEXTURE_RECTANGLE,
|
||||||
0,
|
0,
|
||||||
GL_R8,
|
GL_R8,
|
||||||
256,
|
256,
|
||||||
|
@ -4636,11 +4636,11 @@ static void polymer_getbuildmaterial(_prmaterial* material, int16_t tile
|
||||||
GL_RED,
|
GL_RED,
|
||||||
GL_UNSIGNED_BYTE,
|
GL_UNSIGNED_BYTE,
|
||||||
palookup[pal]);
|
palookup[pal]);
|
||||||
bglTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
|
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
|
||||||
bglTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
|
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
|
||||||
bglTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, glinfo.clamptoedge?GL_CLAMP_TO_EDGE:GL_CLAMP);
|
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_WRAP_S, glinfo.clamptoedge?GL_CLAMP_TO_EDGE:GL_CLAMP);
|
||||||
bglTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, glinfo.clamptoedge?GL_CLAMP_TO_EDGE:GL_CLAMP);
|
bglTexParameteri(GL_TEXTURE_RECTANGLE, GL_TEXTURE_WRAP_T, glinfo.clamptoedge?GL_CLAMP_TO_EDGE:GL_CLAMP);
|
||||||
bglBindTexture(GL_TEXTURE_2D, 0);
|
bglBindTexture(GL_TEXTURE_RECTANGLE, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
material->artmap = prartmaps[tilenum];
|
material->artmap = prartmaps[tilenum];
|
||||||
|
@ -4941,7 +4941,7 @@ static int32_t polymer_bindmaterial(_prmaterial material, int16_t* lights,
|
||||||
texunit++;
|
texunit++;
|
||||||
|
|
||||||
bglActiveTextureARB(texunit + GL_TEXTURE0_ARB);
|
bglActiveTextureARB(texunit + GL_TEXTURE0_ARB);
|
||||||
bglBindTexture(GL_TEXTURE_2D, material.lookupmap);
|
bglBindTexture(GL_TEXTURE_RECTANGLE, material.lookupmap);
|
||||||
|
|
||||||
bglUniform1iARB(prprograms[programbits].uniform_lookupMap, texunit);
|
bglUniform1iARB(prprograms[programbits].uniform_lookupMap, texunit);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue