mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
- fixed use of brightmaps.
Due to the blending they are essentially inactive on translucent content and Duke Nukem heavily abuses this.
This commit is contained in:
parent
3e0075a34d
commit
dc60c7f72e
7 changed files with 44 additions and 6 deletions
|
@ -546,14 +546,14 @@ bool ReadStatistics()
|
||||||
sjson_node* root = sjson_decode(ctx, (const char*)text.Data());
|
sjson_node* root = sjson_decode(ctx, (const char*)text.Data());
|
||||||
|
|
||||||
LevelName = sjson_get_string(root, "levelname", "");
|
LevelName = sjson_get_string(root, "levelname", "");
|
||||||
StartEpisode = sjson_get_int(root, "episode", -1);
|
StartEpisode = sjson_get_string(root, "episode", "");
|
||||||
StartSkill = sjson_get_int(root, "skill", -1);
|
StartSkill = sjson_get_int(root, "skill", -1);
|
||||||
sjson_node* levels = sjson_find_member(root, "levels");
|
sjson_node* levels = sjson_find_member(root, "levels");
|
||||||
|
|
||||||
if (LevelName.Len() == 0 || StartEpisode == -1 || StartSkill == -1 || levels == nullptr)
|
if (LevelName.Len() == 0 || StartEpisode.Len() == 0 || StartSkill == -1 || levels == nullptr)
|
||||||
{
|
{
|
||||||
sjson_destroy_context(ctx);
|
sjson_destroy_context(ctx);
|
||||||
return false;
|
return true; // do not error out on this.
|
||||||
}
|
}
|
||||||
|
|
||||||
int numlevels = sjson_child_count(levels);
|
int numlevels = sjson_child_count(levels);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
struct PalEntry
|
struct PalEntry
|
||||||
|
@ -34,6 +35,11 @@ struct PalEntry
|
||||||
return (r * 77 + g * 143 + b * 37) >> 8;
|
return (r * 77 + g * 143 + b * 37) >> 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int Amplitude() const
|
||||||
|
{
|
||||||
|
return std::max(r, std::max(g, b));
|
||||||
|
}
|
||||||
|
|
||||||
void Decolorize() // this for 'nocoloredspritelighting' and not the same as desaturation. The normal formula results in a value that's too dark.
|
void Decolorize() // this for 'nocoloredspritelighting' and not the same as desaturation. The normal formula results in a value that's too dark.
|
||||||
{
|
{
|
||||||
int v = (r + g + b);
|
int v = (r + g + b);
|
||||||
|
|
|
@ -145,6 +145,25 @@ unsigned PaletteManager::FindPalswap(const uint8_t* paldata, palette_t &fadecolo
|
||||||
pd.lookup = paldata;
|
pd.lookup = paldata;
|
||||||
pd.crc32 = crc32;
|
pd.crc32 = crc32;
|
||||||
pd.swaptexture = nullptr;
|
pd.swaptexture = nullptr;
|
||||||
|
memset(pd.brightcolors, 0, 256);
|
||||||
|
pd.isbright = false;
|
||||||
|
|
||||||
|
for (int i = 0; i < 255; i++)
|
||||||
|
{
|
||||||
|
int firstmap = paldata[i];
|
||||||
|
int lastmap = paldata[i + 256 * (numshades - 2)];
|
||||||
|
|
||||||
|
PalEntry color1 = palettes[palettemap[0]].colors[firstmap];
|
||||||
|
PalEntry color2 = palettes[palettemap[0]].colors[lastmap];
|
||||||
|
int lum1 = color1.Amplitude();
|
||||||
|
int lum2 = color2.Amplitude();
|
||||||
|
if (lum1 > 40 && lum2 * 10 >= lum1 * 9)
|
||||||
|
{
|
||||||
|
pd.brightcolors[i] = 255;
|
||||||
|
pd.isbright = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if (fadecolor.f == 0)
|
if (fadecolor.f == 0)
|
||||||
{
|
{
|
||||||
|
@ -288,13 +307,18 @@ int PaletteManager::LookupPalette(int palette, int palswap, bool brightmap)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
if (!swapdata->isbright)
|
||||||
|
{
|
||||||
|
swappedpalmap.Insert(combined, -1);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
bool found = false;
|
bool found = false;
|
||||||
memset(swappedpalette, 0, sizeof(swappedpalette));
|
memset(swappedpalette, 0, sizeof(swappedpalette));
|
||||||
for (int i = 0; i < 255; i++)
|
for (int i = 0; i < 255; i++)
|
||||||
{
|
{
|
||||||
int swapi = swapdata->lookup[i];
|
int swapi = swapdata->brightcolors[i];
|
||||||
auto swapc = paldata->colors[swapi];
|
if (swapi)
|
||||||
if (swapc.a)
|
|
||||||
{
|
{
|
||||||
found = true;
|
found = true;
|
||||||
swappedpalette[i] = 0xffffffff;
|
swappedpalette[i] = 0xffffffff;
|
||||||
|
|
|
@ -258,6 +258,7 @@ bool GLInstance::SetTextureInternal(int picnum, FTexture* tex, int palette, int
|
||||||
BindTexture(4, htex, SamplerRepeat);
|
BindTexture(4, htex, SamplerRepeat);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#if 1
|
||||||
if (!(tex->PicAnim.sf & PICANM_NOFULLBRIGHT_BIT) && !(globalflags & GLOBAL_NO_GL_FULLBRIGHT) && !tex->NoBrightmapFlag[usepalswap])
|
if (!(tex->PicAnim.sf & PICANM_NOFULLBRIGHT_BIT) && !(globalflags & GLOBAL_NO_GL_FULLBRIGHT) && !tex->NoBrightmapFlag[usepalswap])
|
||||||
{
|
{
|
||||||
if (TextureType == TT_HICREPLACE)
|
if (TextureType == TT_HICREPLACE)
|
||||||
|
@ -293,6 +294,7 @@ bool GLInstance::SetTextureInternal(int picnum, FTexture* tex, int palette, int
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else return false;
|
else return false;
|
||||||
|
|
||||||
|
|
|
@ -226,6 +226,7 @@ void GLInstance::Draw(EDrawType type, size_t start, size_t count)
|
||||||
|
|
||||||
if (activeShader == polymostShader)
|
if (activeShader == polymostShader)
|
||||||
{
|
{
|
||||||
|
if (istrans) renderState.Flags &= ~RF_Brightmapping; // The way the colormaps are set up means that brightmaps cannot be used on translucent content at all.
|
||||||
renderState.Apply(polymostShader);
|
renderState.Apply(polymostShader);
|
||||||
if (renderState.VertexBuffer != LastVertexBuffer || LastVB_Offset[0] != renderState.VB_Offset[0] || LastVB_Offset[1] != renderState.VB_Offset[1])
|
if (renderState.VertexBuffer != LastVertexBuffer || LastVB_Offset[0] != renderState.VB_Offset[0] || LastVB_Offset[1] != renderState.VB_Offset[1])
|
||||||
{
|
{
|
||||||
|
@ -400,6 +401,7 @@ void GLInstance::SetCull(int type, int winding)
|
||||||
void GLInstance::SetColor(float r, float g, float b, float a)
|
void GLInstance::SetColor(float r, float g, float b, float a)
|
||||||
{
|
{
|
||||||
glVertexAttrib4f(2, r, g, b, a);
|
glVertexAttrib4f(2, r, g, b, a);
|
||||||
|
istrans = (a != 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GLInstance::SetDepthFunc(int func)
|
void GLInstance::SetDepthFunc(int func)
|
||||||
|
|
|
@ -37,9 +37,11 @@ struct PalShade
|
||||||
struct PalswapData
|
struct PalswapData
|
||||||
{
|
{
|
||||||
int32_t crc32;
|
int32_t crc32;
|
||||||
|
bool isbright;
|
||||||
const uint8_t *lookup; // points to the original data. This is static so no need to copy
|
const uint8_t *lookup; // points to the original data. This is static so no need to copy
|
||||||
FHardwareTexture* swaptexture;
|
FHardwareTexture* swaptexture;
|
||||||
PalEntry fadeColor;
|
PalEntry fadeColor;
|
||||||
|
uint8_t brightcolors[255];
|
||||||
};
|
};
|
||||||
|
|
||||||
enum
|
enum
|
||||||
|
@ -198,6 +200,7 @@ class GLInstance
|
||||||
FTexture* currentTexture = nullptr;
|
FTexture* currentTexture = nullptr;
|
||||||
int TextureType;
|
int TextureType;
|
||||||
int MatrixChange = 0;
|
int MatrixChange = 0;
|
||||||
|
bool istrans = false;
|
||||||
|
|
||||||
IVertexBuffer* LastVertexBuffer = nullptr;
|
IVertexBuffer* LastVertexBuffer = nullptr;
|
||||||
int LastVB_Offset[2] = {};
|
int LastVB_Offset[2] = {};
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// Windows layer-independent code
|
// Windows layer-independent code
|
||||||
|
|
||||||
|
#define NOMINMAX
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
#include "build.h"
|
#include "build.h"
|
||||||
|
|
Loading…
Reference in a new issue