mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
- fixed alpha threshold.
Not only is this a deprecated feature - it also does not work right when complex lighting is at play, it must be done in the shader to get proper results.
This commit is contained in:
parent
7e70c217fe
commit
cae710bd59
14 changed files with 221 additions and 28 deletions
|
@ -811,6 +811,7 @@ set (PCH_SOURCES
|
||||||
common/utility/m_png.cpp
|
common/utility/m_png.cpp
|
||||||
common/utility/memarena.cpp
|
common/utility/memarena.cpp
|
||||||
common/utility/sc_man.cpp
|
common/utility/sc_man.cpp
|
||||||
|
common/utility/stats.cpp
|
||||||
|
|
||||||
common/filesystem/filesystem.cpp
|
common/filesystem/filesystem.cpp
|
||||||
common/filesystem/ancientzip.cpp
|
common/filesystem/ancientzip.cpp
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include "c_console.h"
|
#include "c_console.h"
|
||||||
#include "v_2ddrawer.h"
|
#include "v_2ddrawer.h"
|
||||||
#include "imgui.h"
|
#include "imgui.h"
|
||||||
|
#include "stats.h"
|
||||||
|
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
# include "glsurface.h"
|
# include "glsurface.h"
|
||||||
|
@ -10238,6 +10239,7 @@ void videoNextPage(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Draw the console plus debug output on top of everything else.
|
// Draw the console plus debug output on top of everything else.
|
||||||
|
FStat::PrintStat();
|
||||||
C_DrawConsole();
|
C_DrawConsole();
|
||||||
GLInterface.Draw2D(&twod);
|
GLInterface.Draw2D(&twod);
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "drawparms.h"
|
#include "drawparms.h"
|
||||||
|
#include "c_cvars.h"
|
||||||
|
// Undo Windows's forced #defines
|
||||||
#ifdef DrawText
|
#ifdef DrawText
|
||||||
#undef DrawText
|
#undef DrawText
|
||||||
#endif
|
#endif
|
||||||
|
@ -17,6 +18,7 @@ extern ScreenDummy* screen;
|
||||||
int GetUIScale(int altval);
|
int GetUIScale(int altval);
|
||||||
int GetConScale(int altval);
|
int GetConScale(int altval);
|
||||||
|
|
||||||
|
|
||||||
// [RH] Stretch values to make a 320x200 image best fit the screen
|
// [RH] Stretch values to make a 320x200 image best fit the screen
|
||||||
// without using fractional steppings
|
// without using fractional steppings
|
||||||
extern int CleanXfac, CleanYfac;
|
extern int CleanXfac, CleanYfac;
|
||||||
|
@ -45,3 +47,17 @@ void DrawTexture(F2DDrawer *drawer, FTexture* img, double x, double y, int tags_
|
||||||
void DrawChar (F2DDrawer* drawer, FFont *font, int normalcolor, double x, double y, int character, int tag_first, ...);
|
void DrawChar (F2DDrawer* drawer, FFont *font, int normalcolor, double x, double y, int character, int tag_first, ...);
|
||||||
void DrawText(F2DDrawer* drawer, FFont *font, int normalcolor, double x, double y, const char *string, int tag_first, ...);
|
void DrawText(F2DDrawer* drawer, FFont *font, int normalcolor, double x, double y, const char *string, int tag_first, ...);
|
||||||
void DrawText(F2DDrawer* drawer, FFont *font, int normalcolor, double x, double y, const char32_t *string, int tag_first, ...);
|
void DrawText(F2DDrawer* drawer, FFont *font, int normalcolor, double x, double y, const char32_t *string, int tag_first, ...);
|
||||||
|
|
||||||
|
EXTERN_CVAR(Int, con_scaletext) // Scale notify text at high resolutions?
|
||||||
|
EXTERN_CVAR(Int, con_scale)
|
||||||
|
|
||||||
|
inline int active_con_scaletext(bool newconfont = false)
|
||||||
|
{
|
||||||
|
return newconfont ? GetConScale(con_scaletext) : GetUIScale(con_scaletext);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline int active_con_scale()
|
||||||
|
{
|
||||||
|
return GetConScale(con_scale);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -155,16 +155,6 @@ CVAR(Int, developer, 0, CVAR_ARCHIVE | CVAR_GLOBALCONFIG)
|
||||||
EXTERN_CVAR(Int, uiscale);
|
EXTERN_CVAR(Int, uiscale);
|
||||||
|
|
||||||
|
|
||||||
inline int active_con_scaletext(bool newconfont = false)
|
|
||||||
{
|
|
||||||
return newconfont ? GetConScale(con_scaletext) : GetUIScale(con_scaletext);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline int active_con_scale()
|
|
||||||
{
|
|
||||||
return GetConScale(con_scale);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool generic_ui = true;
|
bool generic_ui = true;
|
||||||
|
|
||||||
|
|
||||||
|
|
143
source/common/utility/stats.cpp
Normal file
143
source/common/utility/stats.cpp
Normal file
|
@ -0,0 +1,143 @@
|
||||||
|
/*
|
||||||
|
** stats.cpp
|
||||||
|
** Performance-monitoring statistics
|
||||||
|
**
|
||||||
|
**---------------------------------------------------------------------------
|
||||||
|
** Copyright 1998-2006 Randy Heit
|
||||||
|
** All rights reserved.
|
||||||
|
**
|
||||||
|
** Redistribution and use in source and binary forms, with or without
|
||||||
|
** modification, are permitted provided that the following conditions
|
||||||
|
** are met:
|
||||||
|
**
|
||||||
|
** 1. Redistributions of source code must retain the above copyright
|
||||||
|
** notice, this list of conditions and the following disclaimer.
|
||||||
|
** 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
** notice, this list of conditions and the following disclaimer in the
|
||||||
|
** documentation and/or other materials provided with the distribution.
|
||||||
|
** 3. The name of the author may not be used to endorse or promote products
|
||||||
|
** derived from this software without specific prior written permission.
|
||||||
|
**
|
||||||
|
** THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
||||||
|
** IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||||||
|
** OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||||||
|
** IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
|
** INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||||||
|
** NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
||||||
|
** THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
**---------------------------------------------------------------------------
|
||||||
|
**
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "stats.h"
|
||||||
|
#include "v_draw.h"
|
||||||
|
#include "v_text.h"
|
||||||
|
#include "v_font.h"
|
||||||
|
#include "c_console.h"
|
||||||
|
#include "c_dispatch.h"
|
||||||
|
#include "printf.h"
|
||||||
|
|
||||||
|
FStat *FStat::FirstStat;
|
||||||
|
|
||||||
|
FStat::FStat (const char *name)
|
||||||
|
{
|
||||||
|
m_Name = name;
|
||||||
|
m_Active = false;
|
||||||
|
m_Next = FirstStat;
|
||||||
|
FirstStat = this;
|
||||||
|
}
|
||||||
|
|
||||||
|
FStat::~FStat ()
|
||||||
|
{
|
||||||
|
FStat **prev = &FirstStat;
|
||||||
|
|
||||||
|
while (*prev && *prev != this)
|
||||||
|
prev = &((*prev)->m_Next)->m_Next;
|
||||||
|
|
||||||
|
if (*prev == this)
|
||||||
|
*prev = m_Next;
|
||||||
|
}
|
||||||
|
|
||||||
|
FStat *FStat::FindStat (const char *name)
|
||||||
|
{
|
||||||
|
FStat *stat = FirstStat;
|
||||||
|
|
||||||
|
while (stat && stricmp (name, stat->m_Name))
|
||||||
|
stat = stat->m_Next;
|
||||||
|
|
||||||
|
return stat;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FStat::ToggleStat (const char *name)
|
||||||
|
{
|
||||||
|
FStat *stat = FindStat (name);
|
||||||
|
if (stat)
|
||||||
|
stat->ToggleStat ();
|
||||||
|
else
|
||||||
|
Printf ("Unknown stat: %s\n", name);
|
||||||
|
}
|
||||||
|
|
||||||
|
void FStat::ToggleStat ()
|
||||||
|
{
|
||||||
|
m_Active = !m_Active;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FStat::PrintStat ()
|
||||||
|
{
|
||||||
|
int textScale = active_con_scale();
|
||||||
|
|
||||||
|
int fontheight = NewConsoleFont->GetHeight() + 1;
|
||||||
|
int y = screen->GetHeight() / textScale;
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
|
for (FStat *stat = FirstStat; stat != NULL; stat = stat->m_Next)
|
||||||
|
{
|
||||||
|
if (stat->m_Active)
|
||||||
|
{
|
||||||
|
FString stattext(stat->GetStats());
|
||||||
|
|
||||||
|
if (stattext.Len() > 0)
|
||||||
|
{
|
||||||
|
y -= fontheight; // there's at least one line of text
|
||||||
|
for (unsigned i = 0; i < stattext.Len()-1; i++)
|
||||||
|
{
|
||||||
|
// Count number of linefeeds but ignore terminating ones.
|
||||||
|
if (stattext[i] == '\n') y -= fontheight;
|
||||||
|
}
|
||||||
|
DrawText(&twod, NewConsoleFont, CR_GREEN, 5 / textScale, y, stattext,
|
||||||
|
DTA_VirtualWidth, screen->GetWidth() / textScale,
|
||||||
|
DTA_VirtualHeight, screen->GetHeight() / textScale,
|
||||||
|
DTA_KeepRatio, true, TAG_DONE);
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void FStat::DumpRegisteredStats ()
|
||||||
|
{
|
||||||
|
FStat *stat = FirstStat;
|
||||||
|
|
||||||
|
Printf ("Available stats:\n");
|
||||||
|
while (stat)
|
||||||
|
{
|
||||||
|
Printf (" %c%s\n", stat->m_Active ? '*' : ' ', stat->m_Name);
|
||||||
|
stat = stat->m_Next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CCMD (stat)
|
||||||
|
{
|
||||||
|
if (argv.argc() != 2)
|
||||||
|
{
|
||||||
|
Printf ("Usage: stat <statistics>\n");
|
||||||
|
FStat::DumpRegisteredStats ();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FStat::ToggleStat (argv[1]);
|
||||||
|
}
|
||||||
|
}
|
|
@ -34,6 +34,8 @@
|
||||||
#ifndef __STATS_H__
|
#ifndef __STATS_H__
|
||||||
#define __STATS_H__
|
#define __STATS_H__
|
||||||
|
|
||||||
|
#include "zstring.h"
|
||||||
|
|
||||||
#if !defined _WIN32 && !defined __APPLE__
|
#if !defined _WIN32 && !defined __APPLE__
|
||||||
|
|
||||||
#ifdef NO_CLOCK_GETTIME
|
#ifdef NO_CLOCK_GETTIME
|
||||||
|
@ -206,4 +208,39 @@ private:
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class FStat
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
FStat (const char *name);
|
||||||
|
virtual ~FStat ();
|
||||||
|
|
||||||
|
virtual FString GetStats () = 0;
|
||||||
|
|
||||||
|
void ToggleStat ();
|
||||||
|
bool isActive() const
|
||||||
|
{
|
||||||
|
return m_Active;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PrintStat ();
|
||||||
|
static FStat *FindStat (const char *name);
|
||||||
|
static void ToggleStat (const char *name);
|
||||||
|
static void DumpRegisteredStats ();
|
||||||
|
|
||||||
|
private:
|
||||||
|
FStat *m_Next;
|
||||||
|
const char *m_Name;
|
||||||
|
bool m_Active;
|
||||||
|
|
||||||
|
static FStat *FirstStat;
|
||||||
|
};
|
||||||
|
|
||||||
|
#define ADD_STAT(n) \
|
||||||
|
static class Stat_##n : public FStat { \
|
||||||
|
public: \
|
||||||
|
Stat_##n () : FStat (#n) {} \
|
||||||
|
FString GetStats (); } Istaticstat##n; \
|
||||||
|
FString Stat_##n::GetStats ()
|
||||||
|
|
||||||
#endif //__STATS_H__
|
#endif //__STATS_H__
|
|
@ -34,6 +34,9 @@ struct PolymostRenderState
|
||||||
float NPOTEmulationFactor = 1.f;
|
float NPOTEmulationFactor = 1.f;
|
||||||
float NPOTEmulationXOffset;
|
float NPOTEmulationXOffset;
|
||||||
float Brightness = 1.f;
|
float Brightness = 1.f;
|
||||||
|
float AlphaThreshold = 0.5f;
|
||||||
|
bool AlphaTest = true;
|
||||||
|
|
||||||
PalEntry FogColor;
|
PalEntry FogColor;
|
||||||
|
|
||||||
IVertexBuffer* VertexBuffer = nullptr;
|
IVertexBuffer* VertexBuffer = nullptr;
|
||||||
|
|
|
@ -143,6 +143,7 @@ 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");
|
||||||
|
|
||||||
RotMatrix.Init(hShader, "u_rotMatrix");
|
RotMatrix.Init(hShader, "u_rotMatrix");
|
||||||
ModelMatrix.Init(hShader, "u_modelMatrix");
|
ModelMatrix.Init(hShader, "u_modelMatrix");
|
||||||
|
|
|
@ -43,6 +43,7 @@ public:
|
||||||
FBufferedUniform1f NPOTEmulationFactor;
|
FBufferedUniform1f NPOTEmulationFactor;
|
||||||
FBufferedUniform1f NPOTEmulationXOffset;
|
FBufferedUniform1f NPOTEmulationXOffset;
|
||||||
FBufferedUniform1f Brightness;
|
FBufferedUniform1f Brightness;
|
||||||
|
FBufferedUniform1f AlphaThreshold;
|
||||||
FBufferedUniformPalEntry FogColor;
|
FBufferedUniformPalEntry FogColor;
|
||||||
|
|
||||||
FUniformMatrix4f RotMatrix;
|
FUniformMatrix4f RotMatrix;
|
||||||
|
|
|
@ -281,7 +281,7 @@ bool GLInstance::SetTextureInternal(int picnum, FTexture* tex, int palette, int
|
||||||
if (TextureType == TT_HICREPLACE)
|
if (TextureType == TT_HICREPLACE)
|
||||||
{
|
{
|
||||||
al = ((unsigned)picnum < MAXTILES && alphahackarray[picnum] != 0) ? alphahackarray[picnum] * (1.f / 255.f) :
|
al = ((unsigned)picnum < MAXTILES && alphahackarray[picnum] != 0) ? alphahackarray[picnum] * (1.f / 255.f) :
|
||||||
(tex->alphaThreshold >= 0.f ? tex->alphaThreshold : 0.f);
|
(tex->alphaThreshold >= 0 ? tex->alphaThreshold * (1.f / 255.f) : 0.f);
|
||||||
}
|
}
|
||||||
GLInterface.SetAlphaThreshold(al);
|
GLInterface.SetAlphaThreshold(al);
|
||||||
return true;
|
return true;
|
||||||
|
@ -302,6 +302,7 @@ bool GLInstance::SetNamedTexture(FTexture* tex, int palette, int sampler)
|
||||||
|
|
||||||
renderState.Flags &= ~RF_UsePalette;
|
renderState.Flags &= ~RF_UsePalette;
|
||||||
BindTexture(0, mtex, sampler);
|
BindTexture(0, mtex, sampler);
|
||||||
|
GLInterface.SetAlphaThreshold(tex->isTranslucent()? 0.f : 0.5f);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -315,12 +315,6 @@ void GLInstance::EnableBlend(bool on)
|
||||||
else glDisable (GL_BLEND);
|
else glDisable (GL_BLEND);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GLInstance::EnableAlphaTest(bool on)
|
|
||||||
{
|
|
||||||
if (on) glEnable (GL_ALPHA_TEST);
|
|
||||||
else glDisable (GL_ALPHA_TEST);
|
|
||||||
}
|
|
||||||
|
|
||||||
void GLInstance::EnableDepthTest(bool on)
|
void GLInstance::EnableDepthTest(bool on)
|
||||||
{
|
{
|
||||||
if (on) glEnable (GL_DEPTH_TEST);
|
if (on) glEnable (GL_DEPTH_TEST);
|
||||||
|
@ -449,11 +443,6 @@ void GLInstance::ClearDepth()
|
||||||
glClear(GL_DEPTH_BUFFER_BIT);
|
glClear(GL_DEPTH_BUFFER_BIT);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GLInstance::SetAlphaThreshold(float al)
|
|
||||||
{
|
|
||||||
glAlphaFunc(GL_GREATER, al);
|
|
||||||
}
|
|
||||||
|
|
||||||
void GLInstance::SetViewport(int x, int y, int w, int h)
|
void GLInstance::SetViewport(int x, int y, int w, int h)
|
||||||
{
|
{
|
||||||
glViewport(x, y, w, h);
|
glViewport(x, y, w, h);
|
||||||
|
@ -524,6 +513,7 @@ void PolymostRenderState::Apply(PolymostShader* shader)
|
||||||
shader->Flags.Set(Flags);
|
shader->Flags.Set(Flags);
|
||||||
shader->NPOTEmulationFactor.Set(NPOTEmulationFactor);
|
shader->NPOTEmulationFactor.Set(NPOTEmulationFactor);
|
||||||
shader->NPOTEmulationXOffset.Set(NPOTEmulationXOffset);
|
shader->NPOTEmulationXOffset.Set(NPOTEmulationXOffset);
|
||||||
|
shader->AlphaThreshold.Set(AlphaTest ? AlphaThreshold : -1.f);
|
||||||
shader->Brightness.Set(Brightness);
|
shader->Brightness.Set(Brightness);
|
||||||
shader->FogColor.Set(FogColor);
|
shader->FogColor.Set(FogColor);
|
||||||
|
|
||||||
|
|
|
@ -240,7 +240,6 @@ public:
|
||||||
void UnbindTexture(int texunit);
|
void UnbindTexture(int texunit);
|
||||||
void UnbindAllTextures();
|
void UnbindAllTextures();
|
||||||
void EnableBlend(bool on);
|
void EnableBlend(bool on);
|
||||||
void EnableAlphaTest(bool on);
|
|
||||||
void EnableDepthTest(bool on);
|
void EnableDepthTest(bool on);
|
||||||
void EnableMultisampling(bool on);
|
void EnableMultisampling(bool on);
|
||||||
void SetVertexBuffer(IVertexBuffer* vb, int offset1, int offset2)
|
void SetVertexBuffer(IVertexBuffer* vb, int offset1, int offset2)
|
||||||
|
@ -281,7 +280,6 @@ public:
|
||||||
void ClearScreen(float r, float g, float b, bool depth);
|
void ClearScreen(float r, float g, float b, bool depth);
|
||||||
void ClearDepth();
|
void ClearDepth();
|
||||||
void SetViewport(int x, int y, int w, int h);
|
void SetViewport(int x, int y, int w, int h);
|
||||||
void SetAlphaThreshold(float al);
|
|
||||||
void SetWireframe(bool on);
|
void SetWireframe(bool on);
|
||||||
void SetPolymostShader();
|
void SetPolymostShader();
|
||||||
void SetSurfaceShader();
|
void SetSurfaceShader();
|
||||||
|
@ -404,6 +402,17 @@ public:
|
||||||
return palmanager.FindPalette((uint8_t*)palette);
|
return palmanager.FindPalette((uint8_t*)palette);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void EnableAlphaTest(bool on)
|
||||||
|
{
|
||||||
|
renderState.AlphaTest = on;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetAlphaThreshold(float al)
|
||||||
|
{
|
||||||
|
renderState.AlphaThreshold = al;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
FHardwareTexture* CreateIndexedTexture(FTexture* tex);
|
FHardwareTexture* CreateIndexedTexture(FTexture* tex);
|
||||||
FHardwareTexture* CreateTrueColorTexture(FTexture* tex, int palid, bool checkfulltransparency = false, bool rgb8bit = false);
|
FHardwareTexture* CreateTrueColorTexture(FTexture* tex, int palid, bool checkfulltransparency = false, bool rgb8bit = false);
|
||||||
FHardwareTexture *LoadTexture(FTexture* tex, int texturetype, int palid);
|
FHardwareTexture *LoadTexture(FTexture* tex, int texturetype, int palid);
|
||||||
|
|
|
@ -146,8 +146,6 @@ void GLInstance::Draw2D(F2DDrawer *drawer)
|
||||||
SetColor(1, 1, 1);
|
SetColor(1, 1, 1);
|
||||||
//state.SetColor(1, 1, 1, 1, cmd.mDesaturate);
|
//state.SetColor(1, 1, 1, 1, cmd.mDesaturate);
|
||||||
|
|
||||||
SetAlphaThreshold(0.0f);
|
|
||||||
|
|
||||||
if (cmd.mTexture != nullptr)
|
if (cmd.mTexture != nullptr)
|
||||||
{
|
{
|
||||||
auto tex = cmd.mTexture;
|
auto tex = cmd.mTexture;
|
||||||
|
|
|
@ -33,6 +33,7 @@ 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 float u_npotEmulationFactor;
|
uniform float u_npotEmulationFactor;
|
||||||
uniform float u_npotEmulationXOffset;
|
uniform float u_npotEmulationXOffset;
|
||||||
|
@ -198,9 +199,9 @@ void main()
|
||||||
color.rgb = mix(color.rgb, u_fogColor.rgb, shade);
|
color.rgb = mix(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.
|
||||||
if (fullbright == 0.0) color.rgb *= v_color.rgb;
|
if (fullbright == 0.0) color.rgb *= v_color.rgb;
|
||||||
color.a *= v_color.a;
|
color.a *= v_color.a;
|
||||||
color.rgb *= detailColor.rgb;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue