- fixed brightmaps.

They are no longer run through the texture postprocessor and the shader now applies them correctly.
This commit is contained in:
Christoph Oelckers 2020-02-18 20:43:16 +01:00
parent de59841961
commit 6282062492
2 changed files with 11 additions and 18 deletions

View file

@ -96,7 +96,7 @@ FHardwareTexture* GLInstance::CreateTrueColorTexture(FTexture* tex, int palid, b
{
auto palette = palid < 0? nullptr : palmanager.GetPaletteData(palid);
if (palid >= 0 && palette == nullptr) return nullptr;
auto texbuffer = tex->CreateTexBuffer(palette, CTF_ProcessData);
auto texbuffer = tex->CreateTexBuffer(palette, checkfulltransparency? 0: CTF_ProcessData);
// Check if the texture is fully transparent. When creating a brightmap such textures can be discarded.
if (checkfulltransparency)
{

View file

@ -205,26 +205,19 @@ void main()
}
else
{
if (u_tintFlags != -1) color = convertColor(color);
color.rgb *= detailColor.rgb;
if (u_tintFlags != -1) color = convertColor(color);
if ((u_flags & RF_FogDisabled) == 0)
{
shade = clamp(shade * u_shadeDiv, 0.0, 1.0); // u_shadeDiv is really 1/shadeDiv.
vec3 lightcolor = v_color.rgb * (1.0 - shade);
vec3 lightcolor = v_color.rgb;
bool shadeIt = ((u_flags & RF_FogDisabled) == 0);
// The lighting model here does not really allow more than a simple on/off brightmap because anything more complex inteferes with the shade ramp... :(
if ((u_flags & RF_Brightmapping) != 0)
{
vec4 brightcolor = texture(s_brightmap, v_texCoord.xy);
if (grayscale(brightcolor) > 0.5)
{
shadeIt = false;
lightcolor = texture(s_brightmap, v_texCoord.xy).rgb;
}
}
if (shadeIt)
{
color.rgb *= lightcolor;
shade = clamp(shade * u_shadeDiv, 0.0, 1.0); // u_shadeDiv is really 1/shadeDiv.
// Apply the shade as a linear depth fade ramp.
color.rgb = mix(color.rgb, u_fogColor.rgb, shade);
color.rgb += u_fogColor.rgb * shade;
}
}
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.