mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-14 20:00:49 +00:00
- migration of texture tinting to GZDoom's version.
- start of visibility migration - removing unused globvis variable.
This commit is contained in:
parent
f3ed580b82
commit
9dfd3ddd02
9 changed files with 167 additions and 143 deletions
|
@ -1101,7 +1101,7 @@ fix16_t qglobalang;
|
||||||
int32_t globalpal, cosglobalang, singlobalang;
|
int32_t globalpal, cosglobalang, singlobalang;
|
||||||
int32_t cosviewingrangeglobalang, sinviewingrangeglobalang;
|
int32_t cosviewingrangeglobalang, sinviewingrangeglobalang;
|
||||||
static int32_t globaluclip, globaldclip;
|
static int32_t globaluclip, globaldclip;
|
||||||
int32_t globvis, globalvisibility;
|
int32_t globalvisibility;
|
||||||
int32_t globalhisibility, globalpisibility, globalcisibility;
|
int32_t globalhisibility, globalpisibility, globalcisibility;
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
int32_t globvis2, globalvisibility2, globalhisibility2, globalpisibility2, globalcisibility2;
|
int32_t globvis2, globalvisibility2, globalhisibility2, globalpisibility2, globalcisibility2;
|
||||||
|
@ -3265,8 +3265,6 @@ void renderDrawMapView(int32_t dax, int32_t day, int32_t zoome, int16_t ang)
|
||||||
if ((tilesiz[globalpicnum].x <= 0) || (tilesiz[globalpicnum].y <= 0)) continue;
|
if ((tilesiz[globalpicnum].x <= 0) || (tilesiz[globalpicnum].y <= 0)) continue;
|
||||||
|
|
||||||
globalshade = max(min<int>(sec->floorshade, numshades - 1), 0);
|
globalshade = max(min<int>(sec->floorshade, numshades - 1), 0);
|
||||||
globvis = globalhisibility;
|
|
||||||
if (sec->visibility != 0) globvis = mulscale4(globvis, (uint8_t)(sec->visibility+16));
|
|
||||||
if ((globalorientation&64) == 0)
|
if ((globalorientation&64) == 0)
|
||||||
{
|
{
|
||||||
set_globalpos(dax, day, globalposz);
|
set_globalpos(dax, day, globalposz);
|
||||||
|
@ -3384,8 +3382,6 @@ void renderDrawMapView(int32_t dax, int32_t day, int32_t zoome, int16_t ang)
|
||||||
else
|
else
|
||||||
globalshade = ((int32_t)sector[spr->sectnum].floorshade);
|
globalshade = ((int32_t)sector[spr->sectnum].floorshade);
|
||||||
globalshade = max(min(globalshade+spr->shade+6,numshades-1),0);
|
globalshade = max(min(globalshade+spr->shade+6,numshades-1),0);
|
||||||
globvis = globalhisibility;
|
|
||||||
if (sec->visibility != 0) globvis = mulscale4(globvis, (uint8_t)(sec->visibility+16));
|
|
||||||
|
|
||||||
//relative alignment stuff
|
//relative alignment stuff
|
||||||
ox = v2.x-v1.x; oy = v2.y-v1.y;
|
ox = v2.x-v1.x; oy = v2.y-v1.y;
|
||||||
|
|
|
@ -98,7 +98,7 @@ extern int32_t globalhisibility, globalpisibility, globalcisibility;
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
extern int32_t globvis2, globalvisibility2, globalhisibility2, globalpisibility2, globalcisibility2;
|
extern int32_t globvis2, globalvisibility2, globalhisibility2, globalpisibility2, globalcisibility2;
|
||||||
#endif
|
#endif
|
||||||
extern int32_t globvis, globalvisibility;
|
extern int32_t globalvisibility;
|
||||||
extern int32_t xyaspect;
|
extern int32_t xyaspect;
|
||||||
extern int32_t globalshade;
|
extern int32_t globalshade;
|
||||||
extern int16_t globalpicnum;
|
extern int16_t globalpicnum;
|
||||||
|
|
|
@ -38,6 +38,12 @@ CUSTOM_CVARD(Bool, hw_useindexedcolortextures, false, CVAR_ARCHIVE | CVAR_GLOBAL
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void PrintVis(int sectvis, char type)
|
||||||
|
{
|
||||||
|
Printf("%c: g_vis = %d, gv = %d, gv2 = %d, gc = %d, gc2 = %d, gh2 = %d, globvis2 = %d, fviewingrange = %f, sectvis = %d, result = %f\n",
|
||||||
|
type, g_visibility, globalvisibility, globalvisibility2, globalcisibility, globalcisibility2, globalhisibility2, globvis2, fviewingrange, sectvis, GLInterface.renderState.VisFactor);
|
||||||
|
}
|
||||||
|
|
||||||
//{ "r_yshearing", "enable/disable y-shearing", (void*)&r_yshearing, CVAR_BOOL, 0, 1 }, disabled because not fully functional
|
//{ "r_yshearing", "enable/disable y-shearing", (void*)&r_yshearing, CVAR_BOOL, 0, 1 }, disabled because not fully functional
|
||||||
|
|
||||||
// For testing - will be removed later.
|
// For testing - will be removed later.
|
||||||
|
@ -2084,12 +2090,10 @@ static void polymost_drawalls(int32_t const bunch)
|
||||||
globalshade = sec->floorshade;
|
globalshade = sec->floorshade;
|
||||||
globalpal = sec->floorpal;
|
globalpal = sec->floorpal;
|
||||||
globalorientation = sec->floorstat;
|
globalorientation = sec->floorstat;
|
||||||
globvis = (sector[sectnum].visibility != 0) ?
|
|
||||||
mulscale4(globalcisibility, (uint8_t)(sector[sectnum].visibility + 16)) :
|
|
||||||
globalcisibility;
|
|
||||||
globvis2 = (sector[sectnum].visibility != 0) ?
|
globvis2 = (sector[sectnum].visibility != 0) ?
|
||||||
mulscale4(globalcisibility2, (uint8_t)(sector[sectnum].visibility + 16)) :
|
mulscale4(globalcisibility2, (uint8_t)(sector[sectnum].visibility + 16)) :
|
||||||
globalcisibility2;
|
globalcisibility2;
|
||||||
|
PrintVis(sector[sectnum].visibility, 'c');
|
||||||
GLInterface.SetVisibility(globvis2, fviewingrange);
|
GLInterface.SetVisibility(globvis2, fviewingrange);
|
||||||
|
|
||||||
tileUpdatePicnum(&globalpicnum, sectnum);
|
tileUpdatePicnum(&globalpicnum, sectnum);
|
||||||
|
@ -2342,12 +2346,10 @@ static void polymost_drawalls(int32_t const bunch)
|
||||||
globalshade = sec->ceilingshade;
|
globalshade = sec->ceilingshade;
|
||||||
globalpal = sec->ceilingpal;
|
globalpal = sec->ceilingpal;
|
||||||
globalorientation = sec->ceilingstat;
|
globalorientation = sec->ceilingstat;
|
||||||
globvis = (sector[sectnum].visibility != 0) ?
|
|
||||||
mulscale4(globalcisibility, (uint8_t)(sector[sectnum].visibility + 16)) :
|
|
||||||
globalcisibility;
|
|
||||||
globvis2 = (sector[sectnum].visibility != 0) ?
|
globvis2 = (sector[sectnum].visibility != 0) ?
|
||||||
mulscale4(globalcisibility2, (uint8_t)(sector[sectnum].visibility + 16)) :
|
mulscale4(globalcisibility2, (uint8_t)(sector[sectnum].visibility + 16)) :
|
||||||
globalcisibility2;
|
globalcisibility2;
|
||||||
|
PrintVis(sector[sectnum].visibility, 'c');
|
||||||
GLInterface.SetVisibility(globvis2, fviewingrange);
|
GLInterface.SetVisibility(globvis2, fviewingrange);
|
||||||
|
|
||||||
tileUpdatePicnum(&globalpicnum, sectnum);
|
tileUpdatePicnum(&globalpicnum, sectnum);
|
||||||
|
@ -2668,10 +2670,9 @@ static void polymost_drawalls(int32_t const bunch)
|
||||||
if (((cy0 < ocy0) || (cy1 < ocy1)) && (!((sec->ceilingstat§or[nextsectnum].ceilingstat)&1)))
|
if (((cy0 < ocy0) || (cy1 < ocy1)) && (!((sec->ceilingstat§or[nextsectnum].ceilingstat)&1)))
|
||||||
{
|
{
|
||||||
globalpicnum = wal->picnum; globalshade = wal->shade; globalpal = (int32_t)((uint8_t)wal->pal);
|
globalpicnum = wal->picnum; globalshade = wal->shade; globalpal = (int32_t)((uint8_t)wal->pal);
|
||||||
globvis = globalvisibility;
|
|
||||||
if (sector[sectnum].visibility != 0) globvis = mulscale4(globvis, (uint8_t)(sector[sectnum].visibility+16));
|
|
||||||
globvis2 = globalvisibility2;
|
globvis2 = globalvisibility2;
|
||||||
if (sector[sectnum].visibility != 0) globvis2 = mulscale4(globvis2, (uint8_t)(sector[sectnum].visibility+16));
|
if (sector[sectnum].visibility != 0) globvis2 = mulscale4(globvis2, (uint8_t)(sector[sectnum].visibility+16));
|
||||||
|
PrintVis(sector[sectnum].visibility, 'v');
|
||||||
GLInterface.SetVisibility(globvis2, fviewingrange);
|
GLInterface.SetVisibility(globvis2, fviewingrange);
|
||||||
globalorientation = wal->cstat;
|
globalorientation = wal->cstat;
|
||||||
tileUpdatePicnum(&globalpicnum, wallnum+16384);
|
tileUpdatePicnum(&globalpicnum, wallnum+16384);
|
||||||
|
@ -2710,10 +2711,9 @@ static void polymost_drawalls(int32_t const bunch)
|
||||||
ytex.u += (float)(nwal->xpanning - wal->xpanning) * ytex.d;
|
ytex.u += (float)(nwal->xpanning - wal->xpanning) * ytex.d;
|
||||||
}
|
}
|
||||||
globalpicnum = nwal->picnum; globalshade = nwal->shade; globalpal = (int32_t)((uint8_t)nwal->pal);
|
globalpicnum = nwal->picnum; globalshade = nwal->shade; globalpal = (int32_t)((uint8_t)nwal->pal);
|
||||||
globvis = globalvisibility;
|
|
||||||
if (sector[sectnum].visibility != 0) globvis = mulscale4(globvis, (uint8_t)(sector[sectnum].visibility+16));
|
|
||||||
globvis2 = globalvisibility2;
|
globvis2 = globalvisibility2;
|
||||||
if (sector[sectnum].visibility != 0) globvis2 = mulscale4(globvis2, (uint8_t)(sector[sectnum].visibility+16));
|
if (sector[sectnum].visibility != 0) globvis2 = mulscale4(globvis2, (uint8_t)(sector[sectnum].visibility+16));
|
||||||
|
PrintVis(sector[sectnum].visibility, 'v');
|
||||||
GLInterface.SetVisibility(globvis2, fviewingrange);
|
GLInterface.SetVisibility(globvis2, fviewingrange);
|
||||||
globalorientation = nwal->cstat;
|
globalorientation = nwal->cstat;
|
||||||
tileUpdatePicnum(&globalpicnum, wallnum+16384);
|
tileUpdatePicnum(&globalpicnum, wallnum+16384);
|
||||||
|
@ -2758,12 +2758,10 @@ static void polymost_drawalls(int32_t const bunch)
|
||||||
|
|
||||||
globalshade = wal->shade;
|
globalshade = wal->shade;
|
||||||
globalpal = wal->pal;
|
globalpal = wal->pal;
|
||||||
globvis = (sector[sectnum].visibility != 0) ?
|
|
||||||
mulscale4(globalvisibility, (uint8_t)(sector[sectnum].visibility + 16)) :
|
|
||||||
globalvisibility;
|
|
||||||
globvis2 = (sector[sectnum].visibility != 0) ?
|
globvis2 = (sector[sectnum].visibility != 0) ?
|
||||||
mulscale4(globalvisibility2, (uint8_t)(sector[sectnum].visibility + 16)) :
|
mulscale4(globalvisibility2, (uint8_t)(sector[sectnum].visibility + 16)) :
|
||||||
globalvisibility2;
|
globalvisibility2;
|
||||||
|
PrintVis(sector[sectnum].visibility, 'v');
|
||||||
GLInterface.SetVisibility(globvis2, fviewingrange);
|
GLInterface.SetVisibility(globvis2, fviewingrange);
|
||||||
globalorientation = wal->cstat;
|
globalorientation = wal->cstat;
|
||||||
tileUpdatePicnum(&globalpicnum, wallnum+16384);
|
tileUpdatePicnum(&globalpicnum, wallnum+16384);
|
||||||
|
@ -3356,11 +3354,9 @@ static void polymost_drawmaskwallinternal(int32_t wallIndex)
|
||||||
globalorientation = (int32_t)wal->cstat;
|
globalorientation = (int32_t)wal->cstat;
|
||||||
tileUpdatePicnum(&globalpicnum, (int16_t)wallIndex+16384);
|
tileUpdatePicnum(&globalpicnum, (int16_t)wallIndex+16384);
|
||||||
|
|
||||||
globvis = globalvisibility;
|
|
||||||
globvis = (sector[sectnum].visibility != 0) ? mulscale4(globvis, (uint8_t)(sector[sectnum].visibility + 16)) : globalvisibility;
|
|
||||||
|
|
||||||
globvis2 = globalvisibility2;
|
globvis2 = globalvisibility2;
|
||||||
globvis2 = (sector[sectnum].visibility != 0) ? mulscale4(globvis2, (uint8_t)(sector[sectnum].visibility + 16)) : globalvisibility2;
|
globvis2 = (sector[sectnum].visibility != 0) ? mulscale4(globvis2, (uint8_t)(sector[sectnum].visibility + 16)) : globalvisibility2;
|
||||||
|
PrintVis(sector[sectnum].visibility, 'v');
|
||||||
GLInterface.SetVisibility(globvis2, fviewingrange);
|
GLInterface.SetVisibility(globvis2, fviewingrange);
|
||||||
|
|
||||||
globalshade = (int32_t)wal->shade;
|
globalshade = (int32_t)wal->shade;
|
||||||
|
@ -3733,14 +3729,11 @@ void polymost_drawsprite(int32_t snum)
|
||||||
globalshade = tspr->shade;
|
globalshade = tspr->shade;
|
||||||
globalpal = tspr->pal;
|
globalpal = tspr->pal;
|
||||||
globalorientation = tspr->cstat;
|
globalorientation = tspr->cstat;
|
||||||
globvis = globalvisibility;
|
|
||||||
|
|
||||||
if (sector[tspr->sectnum].visibility != 0)
|
|
||||||
globvis = mulscale4(globvis, (uint8_t)(sector[tspr->sectnum].visibility + 16));
|
|
||||||
|
|
||||||
globvis2 = globalvisibility2;
|
globvis2 = globalvisibility2;
|
||||||
if (sector[tspr->sectnum].visibility != 0)
|
if (sector[tspr->sectnum].visibility != 0)
|
||||||
globvis2 = mulscale4(globvis2, (uint8_t)(sector[tspr->sectnum].visibility + 16));
|
globvis2 = mulscale4(globvis2, (uint8_t)(sector[tspr->sectnum].visibility + 16));
|
||||||
|
PrintVis(sector[tspr->sectnum].visibility, 'v');
|
||||||
GLInterface.SetVisibility(globvis2, fviewingrange);
|
GLInterface.SetVisibility(globvis2, fviewingrange);
|
||||||
|
|
||||||
vec2_t off = { 0, 0 };
|
vec2_t off = { 0, 0 };
|
||||||
|
@ -4154,6 +4147,7 @@ void polymost_drawsprite(int32_t snum)
|
||||||
globvis2 = globalhisibility2;
|
globvis2 = globalhisibility2;
|
||||||
if (sector[tspr->sectnum].visibility != 0)
|
if (sector[tspr->sectnum].visibility != 0)
|
||||||
globvis2 = mulscale4(globvis2, (uint8_t)(sector[tspr->sectnum].visibility + 16));
|
globvis2 = mulscale4(globvis2, (uint8_t)(sector[tspr->sectnum].visibility + 16));
|
||||||
|
PrintVis(sector[tspr->sectnum].visibility, 'h');
|
||||||
GLInterface.SetVisibility(globvis2, fviewingrange);
|
GLInterface.SetVisibility(globvis2, fviewingrange);
|
||||||
|
|
||||||
if ((globalorientation & 64) != 0 && (globalposz > pos.z) == (!(globalorientation & 8)))
|
if ((globalorientation & 64) != 0 && (globalposz > pos.z) == (!(globalorientation & 8)))
|
||||||
|
|
|
@ -66,10 +66,6 @@ bool FShader::Load(const char * name, const char * vert_prog, const char * frag_
|
||||||
glAttachShader(hShader, hVertProg);
|
glAttachShader(hShader, hVertProg);
|
||||||
glAttachShader(hShader, hFragProg);
|
glAttachShader(hShader, hFragProg);
|
||||||
|
|
||||||
glBindAttribLocation(hShader, 0, "i_vertPos");
|
|
||||||
glBindAttribLocation(hShader, 1, "i_texCoord");
|
|
||||||
glBindAttribLocation(hShader, 2, "i_color");
|
|
||||||
|
|
||||||
glLinkProgram(hShader);
|
glLinkProgram(hShader);
|
||||||
|
|
||||||
glGetShaderInfoLog(hVertProg, 10000, NULL, buffer);
|
glGetShaderInfoLog(hVertProg, 10000, NULL, buffer);
|
||||||
|
@ -146,15 +142,14 @@ bool PolymostShader::Load(const char * name, const char * vert_prog, const char
|
||||||
NPOTEmulationXOffset.Init(hShader, "u_npotEmulationXOffset");
|
NPOTEmulationXOffset.Init(hShader, "u_npotEmulationXOffset");
|
||||||
Brightness.Init(hShader, "u_brightness");
|
Brightness.Init(hShader, "u_brightness");
|
||||||
FogColor.Init(hShader, "u_fogColor");
|
FogColor.Init(hShader, "u_fogColor");
|
||||||
AlphaThreshold.Init(hShader, "u_alphaThreshold");
|
|
||||||
FullscreenTint.Init(hShader, "u_fullscreenTint");
|
|
||||||
TintModulate.Init(hShader, "u_tintModulate");
|
|
||||||
TintOverlay.Init(hShader, "u_tintOverlay");
|
|
||||||
TintFlags.Init(hShader, "u_tintFlags");
|
|
||||||
|
|
||||||
|
AlphaThreshold.Init(hShader, "uAlphaThreshold");
|
||||||
DetailParms.Init(hShader, "uDetailParms");
|
DetailParms.Init(hShader, "uDetailParms");
|
||||||
ModelMatrix.Init(hShader, "ModelMatrix");
|
ModelMatrix.Init(hShader, "ModelMatrix");
|
||||||
TextureMatrix.Init(hShader, "TextureMatrix");
|
TextureMatrix.Init(hShader, "TextureMatrix");
|
||||||
|
muTextureAddColor.Init(hShader, "uTextureAddColor");
|
||||||
|
muTextureModulateColor.Init(hShader, "uTextureModulateColor");
|
||||||
|
muTextureBlendColor.Init(hShader, "uTextureBlendColor");
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -13,15 +13,6 @@ class FShader
|
||||||
protected:
|
protected:
|
||||||
unsigned int hShader = 0;
|
unsigned int hShader = 0;
|
||||||
|
|
||||||
#if 0
|
|
||||||
FName mName;
|
|
||||||
int projectionmatrix_index;
|
|
||||||
int viewmatrix_index;
|
|
||||||
int modelmatrix_index;
|
|
||||||
int texturematrix_index;
|
|
||||||
bool currentTextureMatrixState = false;
|
|
||||||
bool currentModelMatrixState = false;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
FShader() = default;
|
FShader() = default;
|
||||||
|
@ -44,15 +35,14 @@ public:
|
||||||
FBufferedUniform1f Brightness;
|
FBufferedUniform1f Brightness;
|
||||||
FBufferedUniform1f AlphaThreshold;
|
FBufferedUniform1f AlphaThreshold;
|
||||||
FBufferedUniformPalEntry FogColor;
|
FBufferedUniformPalEntry FogColor;
|
||||||
FBufferedUniformPalEntry FullscreenTint;
|
|
||||||
FBufferedUniformPalEntry TintModulate;
|
|
||||||
FBufferedUniformPalEntry TintOverlay;
|
|
||||||
FBufferedUniform1i TintFlags;
|
|
||||||
FBufferedUniform4f DetailParms;
|
FBufferedUniform4f DetailParms;
|
||||||
|
|
||||||
|
|
||||||
FUniformMatrix4f ModelMatrix;
|
FUniformMatrix4f ModelMatrix;
|
||||||
FUniformMatrix4f TextureMatrix;
|
FUniformMatrix4f TextureMatrix;
|
||||||
|
FBufferedUniform4f muTextureBlendColor;
|
||||||
|
FBufferedUniform4f muTextureModulateColor;
|
||||||
|
FBufferedUniform4f muTextureAddColor;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
|
|
@ -100,7 +100,7 @@ void GLInstance::Init(int ydim)
|
||||||
LoadPolymostShader();
|
LoadPolymostShader();
|
||||||
}
|
}
|
||||||
|
|
||||||
FString i_data = R"(
|
auto i_data = R"(
|
||||||
#version 330
|
#version 330
|
||||||
// This must match the HWViewpointUniforms struct
|
// This must match the HWViewpointUniforms struct
|
||||||
layout(std140) uniform ViewpointUBO {
|
layout(std140) uniform ViewpointUBO {
|
||||||
|
@ -122,6 +122,13 @@ FString i_data = R"(
|
||||||
uniform mat4 NormalModelMatrix;
|
uniform mat4 NormalModelMatrix;
|
||||||
uniform mat4 TextureMatrix;
|
uniform mat4 TextureMatrix;
|
||||||
uniform vec4 uDetailParms;
|
uniform vec4 uDetailParms;
|
||||||
|
|
||||||
|
uniform vec4 uTextureBlendColor;
|
||||||
|
uniform vec4 uTextureModulateColor;
|
||||||
|
uniform vec4 uTextureAddColor;
|
||||||
|
|
||||||
|
uniform float uAlphaThreshold;
|
||||||
|
|
||||||
)";
|
)";
|
||||||
|
|
||||||
void GLInstance::LoadPolymostShader()
|
void GLInstance::LoadPolymostShader()
|
||||||
|
@ -523,10 +530,34 @@ void PolymostRenderState::Apply(PolymostShader* shader, GLState &oldState)
|
||||||
shader->AlphaThreshold.Set(AlphaTest ? AlphaThreshold : -1.f);
|
shader->AlphaThreshold.Set(AlphaTest ? AlphaThreshold : -1.f);
|
||||||
shader->Brightness.Set(Brightness);
|
shader->Brightness.Set(Brightness);
|
||||||
shader->FogColor.Set(FogColor);
|
shader->FogColor.Set(FogColor);
|
||||||
shader->TintFlags.Set(hictint_flags);
|
FVector4 addcol(0, 0, 0, 0);
|
||||||
shader->TintModulate.Set(hictint);
|
FVector4 modcol(fullscreenTint.r / 255.f, fullscreenTint.g / 255.f, fullscreenTint.b / 255.f, 0);
|
||||||
shader->TintOverlay.Set(hictint_overlay);
|
FVector4 blendcol(0, 0, 0, 0);
|
||||||
shader->FullscreenTint.Set(fullscreenTint);
|
int flags = 0;
|
||||||
|
if (fullscreenTint != 0xffffff) flags |= 16;
|
||||||
|
if (hictint_flags != -1)
|
||||||
|
{
|
||||||
|
flags |= 16;
|
||||||
|
if (hictint_flags & TINTF_COLORIZE)
|
||||||
|
{
|
||||||
|
modcol.X *= hictint.r / 64.f;
|
||||||
|
modcol.Y *= hictint.g / 64.f;
|
||||||
|
modcol.Z *= hictint.b / 64.f;
|
||||||
|
}
|
||||||
|
if (hictint_flags & TINTF_GRAYSCALE)
|
||||||
|
modcol.W = 1.f;
|
||||||
|
|
||||||
|
if (hictint_flags & TINTF_INVERT)
|
||||||
|
flags |= 8;
|
||||||
|
|
||||||
|
if (hictint_flags & TINTF_BLENDMASK)
|
||||||
|
flags |= ((hictint_flags & TINTF_BLENDMASK) >> 6) + 1;
|
||||||
|
|
||||||
|
addcol.W = flags;
|
||||||
|
}
|
||||||
|
shader->muTextureAddColor.Set(&addcol[0]);
|
||||||
|
shader->muTextureModulateColor.Set(&modcol[0]);
|
||||||
|
shader->muTextureBlendColor.Set(&blendcol[0]);
|
||||||
if (matrixIndex[Matrix_Model] != -1)
|
if (matrixIndex[Matrix_Model] != -1)
|
||||||
shader->ModelMatrix.Set(matrixArray[matrixIndex[Matrix_Model]].get());
|
shader->ModelMatrix.Set(matrixArray[matrixIndex[Matrix_Model]].get());
|
||||||
|
|
||||||
|
|
|
@ -106,6 +106,7 @@ struct GLState
|
||||||
|
|
||||||
class GLInstance
|
class GLInstance
|
||||||
{
|
{
|
||||||
|
public:
|
||||||
TArray<PolymostRenderState> rendercommands;
|
TArray<PolymostRenderState> rendercommands;
|
||||||
int maxTextureSize;
|
int maxTextureSize;
|
||||||
PaletteManager palmanager;
|
PaletteManager palmanager;
|
||||||
|
|
|
@ -8,15 +8,6 @@ const int RF_ShadeInterpolate = 64;
|
||||||
const int RF_FogDisabled = 128;
|
const int RF_FogDisabled = 128;
|
||||||
const int RF_MapFog = 256;
|
const int RF_MapFog = 256;
|
||||||
|
|
||||||
const int RF_TINT_Grayscale = 0x1;
|
|
||||||
const int RF_TINT_Invert = 0x2;
|
|
||||||
const int RF_TINT_Colorize = 0x4;
|
|
||||||
const int RF_TINT_BLEND_Screen = 64;
|
|
||||||
const int RF_TINT_BLEND_Overlay = 128;
|
|
||||||
const int RF_TINT_BLEND_Hardlight = 192;
|
|
||||||
const int RF_TINT_BLENDMASK = RF_TINT_BLEND_Screen | RF_TINT_BLEND_Overlay | RF_TINT_BLEND_Hardlight;
|
|
||||||
|
|
||||||
|
|
||||||
//s_texture points to an indexed color texture
|
//s_texture points to an indexed color texture
|
||||||
uniform sampler2D s_texture;
|
uniform sampler2D s_texture;
|
||||||
//s_palswap is the palette swap texture where u is the color index and v is the shade
|
//s_palswap is the palette swap texture where u is the color index and v is the shade
|
||||||
|
@ -29,22 +20,14 @@ uniform sampler2D s_glow;
|
||||||
uniform sampler2D s_brightmap;
|
uniform sampler2D s_brightmap;
|
||||||
|
|
||||||
uniform float u_shade;
|
uniform float u_shade;
|
||||||
uniform float u_numShades;
|
|
||||||
uniform float u_shadeDiv;
|
uniform float u_shadeDiv;
|
||||||
uniform float u_visFactor;
|
uniform float u_visFactor;
|
||||||
uniform int u_flags;
|
uniform int u_flags;
|
||||||
uniform float u_alphaThreshold;
|
|
||||||
|
|
||||||
uniform vec4 u_tintOverlay, u_tintModulate;
|
|
||||||
uniform int u_tintFlags;
|
|
||||||
uniform vec4 u_fullscreenTint;
|
|
||||||
|
|
||||||
uniform float u_npotEmulationFactor;
|
uniform float u_npotEmulationFactor;
|
||||||
uniform float u_npotEmulationXOffset;
|
uniform float u_npotEmulationXOffset;
|
||||||
uniform float u_brightness;
|
uniform float u_brightness;
|
||||||
uniform vec4 u_fogColor;
|
uniform vec4 u_fogColor;
|
||||||
uniform vec3 u_tintcolor;
|
|
||||||
uniform vec3 u_tintmodulate;
|
|
||||||
|
|
||||||
in vec4 v_color;
|
in vec4 v_color;
|
||||||
in float v_distance;
|
in float v_distance;
|
||||||
|
@ -52,15 +35,7 @@ in vec4 v_texCoord;
|
||||||
in vec4 v_detailCoord;
|
in vec4 v_detailCoord;
|
||||||
in float v_fogCoord;
|
in float v_fogCoord;
|
||||||
in vec4 v_eyeCoordPosition;
|
in vec4 v_eyeCoordPosition;
|
||||||
|
in vec4 v_worldPosition;
|
||||||
const float c_basepalScale = 255.0/256.0;
|
|
||||||
const float c_basepalOffset = 0.5/256.0;
|
|
||||||
|
|
||||||
const float c_zero = 0.0;
|
|
||||||
const float c_one = 1.0;
|
|
||||||
const float c_two = 2.0;
|
|
||||||
const vec4 c_vec4_one = vec4(c_one);
|
|
||||||
const float c_wrapThreshold = 0.9;
|
|
||||||
|
|
||||||
layout(location=0) out vec4 fragColor;
|
layout(location=0) out vec4 fragColor;
|
||||||
layout(location=1) out vec4 fragFog;
|
layout(location=1) out vec4 fragFog;
|
||||||
|
@ -79,64 +54,90 @@ float grayscale(vec4 color)
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
//
|
//
|
||||||
// Hightile tinting code. (hictinting[dapalnum]) This can be done inside the shader
|
// Desaturate a color
|
||||||
// to avoid costly texture duplication (but needs a more modern GLSL than 1.10.)
|
|
||||||
//
|
//
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
|
||||||
vec4 convertColor(vec4 color)
|
vec4 dodesaturate(vec4 texel, float factor)
|
||||||
{
|
{
|
||||||
int effect = u_tintFlags;
|
if (factor != 0.0)
|
||||||
if ((effect & RF_TINT_Grayscale) != 0)
|
|
||||||
{
|
{
|
||||||
float g = grayscale(color);
|
float gray = grayscale(texel);
|
||||||
color = vec4(g, g, g, color.a);
|
return mix (texel, vec4(gray,gray,gray,texel.a), factor);
|
||||||
}
|
|
||||||
|
|
||||||
if ((effect & RF_TINT_Invert) != 0)
|
|
||||||
{
|
|
||||||
color = vec4(1.0 - color.r, 1.0 - color.g, 1.0 - color.b, color.a);
|
|
||||||
}
|
|
||||||
|
|
||||||
vec3 tcol = color.rgb * 255.0; // * 255.0 to make it easier to reuse the integer math.
|
|
||||||
|
|
||||||
// Much of this looks quite broken by design. Why is this effectively multplied by 4 if the flag is set...? :(
|
|
||||||
if ((effect & RF_TINT_Colorize) != 0)
|
|
||||||
{
|
|
||||||
tcol.r = min(((tcol.b) * u_tintModulate.r)* 4, 255.0);
|
|
||||||
tcol.g = min(((tcol.g) * u_tintModulate.g)* 4, 255.0);
|
|
||||||
tcol.b = min(((tcol.r) * u_tintModulate.b)* 4, 255.0);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
tcol.r = min(((tcol.b) * u_tintModulate.r), 255.0);
|
return texel;
|
||||||
tcol.g = min(((tcol.g) * u_tintModulate.g), 255.0);
|
}
|
||||||
tcol.b = min(((tcol.r) * u_tintModulate.b), 255.0);
|
}
|
||||||
|
|
||||||
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// Texture tinting code originally from JFDuke but with a few more options
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
|
const int Tex_Blend_Alpha = 1;
|
||||||
|
const int Tex_Blend_Screen = 2;
|
||||||
|
const int Tex_Blend_Overlay = 3;
|
||||||
|
const int Tex_Blend_Hardlight = 4;
|
||||||
|
|
||||||
|
vec4 ApplyTextureManipulation(vec4 texel, int blendflags)
|
||||||
|
{
|
||||||
|
// Step 1: desaturate according to the material's desaturation factor.
|
||||||
|
texel = dodesaturate(texel, uTextureModulateColor.a);
|
||||||
|
|
||||||
|
// Step 2: Invert if requested
|
||||||
|
if ((blendflags & 8) != 0)
|
||||||
|
{
|
||||||
|
texel.rgb = vec3(1.0 - texel.r, 1.0 - texel.g, 1.0 - texel.b);
|
||||||
}
|
}
|
||||||
|
|
||||||
vec4 ov = u_tintOverlay * 255.0;
|
// Step 3: Apply additive color
|
||||||
switch (effect & RF_TINT_BLENDMASK)
|
texel.rgb += uTextureAddColor.rgb;
|
||||||
|
|
||||||
|
// Step 4: Colorization, including gradient if set.
|
||||||
|
texel.rgb *= uTextureModulateColor.rgb;
|
||||||
|
|
||||||
|
// Before applying the blend the value needs to be clamped to [0..1] range.
|
||||||
|
texel.rgb = clamp(texel.rgb, 0.0, 1.0);
|
||||||
|
|
||||||
|
// Step 5: Apply a blend. This may just be a translucent overlay or one of the blend modes present in current Build engines.
|
||||||
|
if ((blendflags & 7) != 0)
|
||||||
{
|
{
|
||||||
case RF_TINT_BLEND_Screen:
|
vec3 tcol = texel.rgb * 255.0; // * 255.0 to make it easier to reuse the integer math.
|
||||||
tcol.r = 255.0 - (((255.0 - tcol.r) * (255.0 - ov.r)) / 256.0);
|
vec4 tint = uTextureBlendColor * 255.0;
|
||||||
tcol.g = 255.0 - (((255.0 - tcol.g) * (255.0 - ov.g)) / 256.0);
|
|
||||||
tcol.b = 255.0 - (((255.0 - tcol.b) * (255.0 - ov.b)) / 256.0);
|
switch (blendflags & 7)
|
||||||
|
{
|
||||||
|
default:
|
||||||
|
tcol.b = tcol.b * (1.0 - uTextureBlendColor.a) + tint.b * uTextureBlendColor.a;
|
||||||
|
tcol.g = tcol.g * (1.0 - uTextureBlendColor.a) + tint.g * uTextureBlendColor.a;
|
||||||
|
tcol.r = tcol.r * (1.0 - uTextureBlendColor.a) + tint.r * uTextureBlendColor.a;
|
||||||
break;
|
break;
|
||||||
case RF_TINT_BLEND_Overlay:
|
// The following 3 are taken 1:1 from the Build engine
|
||||||
tcol.r = tcol.b < 128.0? (tcol.r * ov.r) / 128.0 : 255.0 - (((255.0 - tcol.r) * (255.0 - ov.r)) / 128.0);
|
case Tex_Blend_Screen:
|
||||||
tcol.g = tcol.g < 128.0? (tcol.g * ov.g) / 128.0 : 255.0 - (((255.0 - tcol.g) * (255.0 - ov.g)) / 128.0);
|
tcol.b = 255.0 - (((255.0 - tcol.b) * (255.0 - tint.r)) / 256.0);
|
||||||
tcol.b = tcol.r < 128.0? (tcol.b * ov.b) / 128.0 : 255.0 - (((255.0 - tcol.b) * (255.0 - ov.b)) / 128.0);
|
tcol.g = 255.0 - (((255.0 - tcol.g) * (255.0 - tint.g)) / 256.0);
|
||||||
|
tcol.r = 255.0 - (((255.0 - tcol.r) * (255.0 - tint.b)) / 256.0);
|
||||||
break;
|
break;
|
||||||
case RF_TINT_BLEND_Hardlight:
|
case Tex_Blend_Overlay:
|
||||||
tcol.r = ov.r < 128.0 ? (tcol.r * ov.r) / 128.0 : 255.0 - (((255.0 - tcol.r) * (255.0 - ov.r)) / 128.0);
|
tcol.b = tcol.b < 128.0? (tcol.b * tint.b) / 128.0 : 255.0 - (((255.0 - tcol.b) * (255.0 - tint.b)) / 128.0);
|
||||||
tcol.g = ov.g < 128.0 ? (tcol.g * ov.g) / 128.0 : 255.0 - (((255.0 - tcol.g) * (255.0 - ov.g)) / 128.0);
|
tcol.g = tcol.g < 128.0? (tcol.g * tint.g) / 128.0 : 255.0 - (((255.0 - tcol.g) * (255.0 - tint.g)) / 128.0);
|
||||||
tcol.b = ov.b < 128.0 ? (tcol.b * ov.b) / 128.0 : 255.0 - (((255.0 - tcol.b) * (255.0 - ov.b)) / 128.0);
|
tcol.r = tcol.r < 128.0? (tcol.r * tint.r) / 128.0 : 255.0 - (((255.0 - tcol.r) * (255.0 - tint.r)) / 128.0);
|
||||||
|
break;
|
||||||
|
case Tex_Blend_Hardlight:
|
||||||
|
tcol.b = tint.b < 128.0 ? (tcol.b * tint.b) / 128.0 : 255.0 - (((255.0 - tcol.b) * (255.0 - tint.b)) / 128.0);
|
||||||
|
tcol.g = tint.g < 128.0 ? (tcol.g * tint.g) / 128.0 : 255.0 - (((255.0 - tcol.g) * (255.0 - tint.g)) / 128.0);
|
||||||
|
tcol.r = tint.r < 128.0 ? (tcol.r * tint.r) / 128.0 : 255.0 - (((255.0 - tcol.r) * (255.0 - tint.r)) / 128.0);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
color.rgb = tcol / 255.0;
|
texel.rgb = tcol / 255.0;
|
||||||
return color;
|
}
|
||||||
|
return texel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
|
@ -197,7 +198,7 @@ void main()
|
||||||
palettedColor.rgb = mix(palettedColor.rgb, palettedColorNext.rgb, shadeFrac);
|
palettedColor.rgb = mix(palettedColor.rgb, palettedColorNext.rgb, shadeFrac);
|
||||||
}
|
}
|
||||||
|
|
||||||
palettedColor.a = color.r == 0.0? 0.0 : 1.0;// c_one-floor(color.r);
|
palettedColor.a = color.r == 0.0? 0.0 : 1.0;// 1.0-floor(color.r);
|
||||||
color = palettedColor;
|
color = palettedColor;
|
||||||
color.rgb *= detailColor.rgb; // with all this palettizing, this can only be applied afterward, even though it is wrong to do it this way.
|
color.rgb *= detailColor.rgb; // with all this palettizing, this can only be applied afterward, even though it is wrong to do it this way.
|
||||||
color.rgb *= v_color.rgb; // Well, this is dead wrong but unavoidable. For colored fog it applies the light to the fog as well...
|
color.rgb *= v_color.rgb; // Well, this is dead wrong but unavoidable. For colored fog it applies the light to the fog as well...
|
||||||
|
@ -205,7 +206,15 @@ void main()
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
color.rgb *= detailColor.rgb;
|
color.rgb *= detailColor.rgb;
|
||||||
if (u_tintFlags != -1) color = convertColor(color);
|
|
||||||
|
// Apply the texture modification colors.
|
||||||
|
int blendflags = int(uTextureAddColor.a); // this alpha is unused otherwise
|
||||||
|
if (blendflags != 0)
|
||||||
|
{
|
||||||
|
// only apply the texture manipulation if it contains something.
|
||||||
|
color = ApplyTextureManipulation(color, blendflags);
|
||||||
|
}
|
||||||
|
|
||||||
if ((u_flags & RF_FogDisabled) == 0)
|
if ((u_flags & RF_FogDisabled) == 0)
|
||||||
{
|
{
|
||||||
shade = clamp(shade * u_shadeDiv, 0.0, 1.0); // u_shadeDiv is really 1/shadeDiv.
|
shade = clamp(shade * u_shadeDiv, 0.0, 1.0); // u_shadeDiv is really 1/shadeDiv.
|
||||||
|
@ -225,7 +234,7 @@ void main()
|
||||||
float fogfactor = 0.55 + 0.3 * exp2 (-5.0*v_fogCoord);
|
float fogfactor = 0.55 + 0.3 * exp2 (-5.0*v_fogCoord);
|
||||||
color.rgb = vec3(0.6*(1.0-fogfactor)) + color.rgb * fogfactor;// mix(vec3(0.6), color.rgb, fogfactor);
|
color.rgb = vec3(0.6*(1.0-fogfactor)) + color.rgb * fogfactor;// mix(vec3(0.6), color.rgb, fogfactor);
|
||||||
}
|
}
|
||||||
if (color.a < u_alphaThreshold) discard; // it's only here that we have the alpha value available to be able to perform the alpha test.
|
if (color.a < uAlphaThreshold) discard; // it's only here that we have the alpha value available to be able to perform the alpha test.
|
||||||
|
|
||||||
color.a *= v_color.a;
|
color.a *= v_color.a;
|
||||||
}
|
}
|
||||||
|
@ -241,8 +250,16 @@ void main()
|
||||||
color.rgb = mix(color.rgb, glowColor.rgb, glowColor.a);
|
color.rgb = mix(color.rgb, glowColor.rgb, glowColor.a);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
int ix = int (v_worldPosition.x);
|
||||||
|
int iy = int (v_worldPosition.z);
|
||||||
|
int iz = int (v_worldPosition.y);
|
||||||
|
if ((ix & 64) == 1) color.r = 0;
|
||||||
|
if ((iy & 64) == 1) color.g = 0;
|
||||||
|
if ((iz & 64) == 1) color.b = 0;
|
||||||
|
*/
|
||||||
|
|
||||||
color.rgb = pow(color.rgb, vec3(u_brightness));
|
color.rgb = pow(color.rgb, vec3(u_brightness));
|
||||||
color.rgb *= u_fullscreenTint.rgb; // must be the last thing to be done.
|
|
||||||
fragColor = color;
|
fragColor = color;
|
||||||
fragFog = vec4(0.0, 0.0, 0.0, 1.0); // Does build have colored fog?
|
fragFog = vec4(0.0, 0.0, 0.0, 1.0); // Does build have colored fog?
|
||||||
vec3 normal = normalize(cross(dFdx(v_eyeCoordPosition.xyz), dFdy(v_eyeCoordPosition.xyz)));
|
vec3 normal = normalize(cross(dFdx(v_eyeCoordPosition.xyz), dFdy(v_eyeCoordPosition.xyz)));
|
||||||
|
|
|
@ -3,12 +3,11 @@ out float v_distance;
|
||||||
out vec4 v_texCoord;
|
out vec4 v_texCoord;
|
||||||
out float v_fogCoord;
|
out float v_fogCoord;
|
||||||
out vec4 v_eyeCoordPosition;
|
out vec4 v_eyeCoordPosition;
|
||||||
|
out vec4 v_worldPosition;
|
||||||
|
|
||||||
uniform float u_usePalette;
|
layout(location = 0) in vec4 i_vertPos;
|
||||||
|
layout(location = 1) in vec4 i_texCoord;
|
||||||
in vec4 i_vertPos;
|
layout(location = 2) in vec4 i_color;
|
||||||
in vec4 i_texCoord;
|
|
||||||
in vec4 i_color;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -27,4 +26,5 @@ void main()
|
||||||
|
|
||||||
v_color = i_color;
|
v_color = i_color;
|
||||||
v_distance = eyeCoordPosition.z;
|
v_distance = eyeCoordPosition.z;
|
||||||
|
v_worldPosition = vertex;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue