mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-28 09:50:42 +00:00
- fixed most issues with palette emulation.
Brightness is now correct - I have no idea why this factor of 1/0.85 is needed - something must reduce the brightness of the entire scene but I have no idea what.
This commit is contained in:
parent
7b879f6fe7
commit
29a10cabcb
3 changed files with 10 additions and 11 deletions
|
@ -119,8 +119,16 @@ IHardwareTexture* PaletteManager::GetLookup(int index)
|
||||||
{
|
{
|
||||||
auto p = screen->CreateHardwareTexture(1);
|
auto p = screen->CreateHardwareTexture(1);
|
||||||
|
|
||||||
|
// Perform a 0<->255 index swap. The lookup tables are still the original data.
|
||||||
TArray<uint8_t> lookup(numshades * 256, true);
|
TArray<uint8_t> lookup(numshades * 256, true);
|
||||||
memcpy(lookup.Data(), lookups.getTable(index), lookup.Size());
|
memcpy(lookup.Data(), lookups.getTable(index), lookup.Size());
|
||||||
|
for (int i = 0; i < numshades; i++)
|
||||||
|
{
|
||||||
|
auto p = &lookup[i * 256];
|
||||||
|
p[255] = p[0];
|
||||||
|
p[0] = 0;
|
||||||
|
for (int v = 1; v <= 255; v++) if (p[v] == 0) p[v] = 255;
|
||||||
|
}
|
||||||
p->CreateTexture(lookup.Data(), 256, numshades, 15, false, "PaletteLookup");
|
p->CreateTexture(lookup.Data(), 256, numshades, 15, false, "PaletteLookup");
|
||||||
lookuptextures[index] = p;
|
lookuptextures[index] = p;
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,15 +17,7 @@ vec4 ProcessTexel()
|
||||||
vec2 newCoord;
|
vec2 newCoord;
|
||||||
|
|
||||||
// z is the depth in view space, positive going into the screen
|
// z is the depth in view space, positive going into the screen
|
||||||
float z;
|
float z = abs(pixelpos.w);
|
||||||
if (((uPalLightLevels >> 8) & 0xff) == 2)
|
|
||||||
{
|
|
||||||
z = distance(pixelpos.xyz, uCameraPos.xyz)*0.7;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
z = pixelpos.w;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Coordinate adjustment for NPOT textures. It is somehow fitting that Build games exploited this texture wrapping quirk of the software rendering engine...
|
// Coordinate adjustment for NPOT textures. It is somehow fitting that Build games exploited this texture wrapping quirk of the software rendering engine...
|
||||||
if (uNpotEmulation.y != 0.0)
|
if (uNpotEmulation.y != 0.0)
|
||||||
|
@ -68,5 +60,5 @@ vec4 ProcessTexel()
|
||||||
color.rgb = uFogColor.rgb * (1.0-fogfactor) + color.rgb * fogfactor;// mix(vec3(0.6), color.rgb, fogfactor);
|
color.rgb = uFogColor.rgb * (1.0-fogfactor) + color.rgb * fogfactor;// mix(vec3(0.6), color.rgb, fogfactor);
|
||||||
}
|
}
|
||||||
if (color.a < uAlphaThreshold) 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.
|
||||||
return color;
|
return vec4(color.rgb / 0.85, vColor.a);
|
||||||
}
|
}
|
||||||
|
|
|
@ -161,7 +161,6 @@ const int Tex_Blend_Hardlight = 4;
|
||||||
vec4 getTexel(vec2 st)
|
vec4 getTexel(vec2 st)
|
||||||
{
|
{
|
||||||
vec4 texel = texture(tex, st);
|
vec4 texel = texture(tex, st);
|
||||||
|
|
||||||
//
|
//
|
||||||
// Apply texture modes
|
// Apply texture modes
|
||||||
//
|
//
|
||||||
|
|
Loading…
Reference in a new issue