- route all glColor calls through render state.

- add sector links to dynamic lights.
This commit is contained in:
Christoph Oelckers 2014-05-11 22:57:42 +02:00
parent 978ace241c
commit c47c7421a3
19 changed files with 160 additions and 175 deletions

View file

@ -33,7 +33,7 @@ EXTERN_CVAR(Int, gl_weaponlight);
inline int getExtraLight() inline int getExtraLight()
{ {
return extralight * gl_weaponlight; // ((glset.lightmode == 8)? 16:8); return extralight * gl_weaponlight;
} }
void gl_RecalcVertexHeights(vertex_t * v); void gl_RecalcVertexHeights(vertex_t * v);
@ -58,4 +58,6 @@ extern TArray<BYTE> currentmapsection;
void gl_InitPortals(); void gl_InitPortals();
void gl_BuildPortalCoverage(FPortalCoverage *coverage, subsector_t *subsector, FPortal *portal); void gl_BuildPortalCoverage(FPortalCoverage *coverage, subsector_t *subsector, FPortal *portal);
extern long gl_frameMS;
#endif #endif

View file

@ -526,6 +526,11 @@ void ADynamicLight::CollectWithinRadius(subsector_t *subSec, float radius)
subSec->validcount = ::validcount; subSec->validcount = ::validcount;
touching_subsectors = AddLightNode(&subSec->lighthead[additive], subSec, this, touching_subsectors); touching_subsectors = AddLightNode(&subSec->lighthead[additive], subSec, this, touching_subsectors);
if (subSec->sector->validcount != ::validcount)
{
touching_sector = AddLightNode(&subSec->sector->lighthead[additive], subSec->sector, this, touching_sector);
subSec->sector->validcount = ::validcount;
}
for (unsigned int i = 0; i < subSec->numlines; i++) for (unsigned int i = 0; i < subSec->numlines; i++)
{ {
@ -537,8 +542,7 @@ void ADynamicLight::CollectWithinRadius(subsector_t *subSec, float radius)
if (DMulScale32 (y-seg->v1->y, seg->v2->x-seg->v1->x, seg->v1->x-x, seg->v2->y-seg->v1->y) <=0) if (DMulScale32 (y-seg->v1->y, seg->v2->x-seg->v1->x, seg->v1->x-x, seg->v2->y-seg->v1->y) <=0)
{ {
seg->linedef->validcount=validcount; seg->linedef->validcount=validcount;
touching_sides = AddLightNode(&seg->sidedef->lighthead[additive], touching_sides = AddLightNode(&seg->sidedef->lighthead[additive], seg->sidedef, this, touching_sides);
seg->sidedef, this, touching_sides);
} }
} }
@ -581,15 +585,21 @@ void ADynamicLight::LinkLight()
node->lightsource = NULL; node->lightsource = NULL;
node = node->nextTarget; node = node->nextTarget;
} }
node = touching_sector;
while (node)
{
node->lightsource = NULL;
node = node->nextTarget;
}
if (radius>0) if (radius>0)
{ {
// passing in radius*radius allows us to do a distance check without any calls to sqrtf // passing in radius*radius allows us to do a distance check without any calls to sqrtf
::validcount++;
subsector_t * subSec = R_PointInSubsector(x, y); subsector_t * subSec = R_PointInSubsector(x, y);
if (subSec) if (subSec)
{ {
float fradius = FIXED2FLOAT(radius); float fradius = FIXED2FLOAT(radius);
::validcount++;
CollectWithinRadius(subSec, fradius*fradius); CollectWithinRadius(subSec, fradius*fradius);
} }
} }
@ -618,6 +628,17 @@ void ADynamicLight::LinkLight()
else else
node = node->nextTarget; node = node->nextTarget;
} }
node = touching_sector;
while (node)
{
if (node->lightsource == NULL)
{
node = DeleteLightNode(node);
}
else
node = node->nextTarget;
}
} }
@ -670,8 +691,8 @@ size_t AActor::PropagateMark()
CCMD(listlights) CCMD(listlights)
{ {
int walls, sectors; int walls, sectors, subsecs;
int allwalls=0, allsectors=0; int allwalls=0, allsectors=0, allsubsecs = 0;
int i=0; int i=0;
ADynamicLight * dl; ADynamicLight * dl;
TThinkerIterator<ADynamicLight> it; TThinkerIterator<ADynamicLight> it;
@ -680,6 +701,7 @@ CCMD(listlights)
{ {
walls=0; walls=0;
sectors=0; sectors=0;
subsecs = 0;
Printf("%s at (%f, %f, %f), color = 0x%02x%02x%02x, radius = %f ", Printf("%s at (%f, %f, %f), color = 0x%02x%02x%02x, radius = %f ",
dl->target? dl->target->GetClass()->TypeName.GetChars() : dl->GetClass()->TypeName.GetChars(), dl->target? dl->target->GetClass()->TypeName.GetChars() : dl->GetClass()->TypeName.GetChars(),
FIXED2FLOAT(dl->x), FIXED2FLOAT(dl->y), FIXED2FLOAT(dl->z), dl->args[LIGHT_RED], FIXED2FLOAT(dl->x), FIXED2FLOAT(dl->y), FIXED2FLOAT(dl->z), dl->args[LIGHT_RED],
@ -706,17 +728,25 @@ CCMD(listlights)
node=dl->touching_subsectors; node=dl->touching_subsectors;
while (node)
{
allsubsecs++;
subsecs++;
node = node->nextTarget;
}
node = dl->touching_sector;
while (node) while (node)
{ {
allsectors++; allsectors++;
sectors++; sectors++;
node = node->nextTarget; node = node->nextTarget;
} }
Printf("- %d walls, %d subsectors, %d sectors\n", walls, subsecs, sectors);
Printf("- %d walls, %d subsectors\n", walls, sectors);
} }
Printf("%i dynamic lights, %d walls, %d subsectors\n\n\n", i, allwalls, allsectors); Printf("%i dynamic lights, %d walls, %d subsectors, %d sectors\n\n\n", i, allwalls, allsubsecs, allsectors);
} }
CCMD(listsublights) CCMD(listsublights)

View file

@ -95,6 +95,7 @@ public:
FState *targetState; FState *targetState;
FLightNode * touching_sides; FLightNode * touching_sides;
FLightNode * touching_subsectors; FLightNode * touching_subsectors;
FLightNode * touching_sector;
private: private:
float DistToSeg(seg_t *seg); float DistToSeg(seg_t *seg);
@ -183,8 +184,9 @@ struct FDynLightData
bool gl_GetLight(Plane & p, ADynamicLight * light, bool checkside, bool forceadditive, FDynLightData &data); bool gl_GetLight(Plane & p, ADynamicLight * light, bool checkside, bool forceadditive, FDynLightData &data);
bool gl_SetupLight(Plane & p, ADynamicLight * light, Vector & nearPt, Vector & up, Vector & right, float & scale, bool checkside=true, bool forceadditive=true); bool gl_SetupLight(Plane & p, ADynamicLight * light, Vector & nearPt, Vector & up, Vector & right, float & scale, int desaturation, bool checkside=true, bool forceadditive=true);
bool gl_SetupLightTexture(); bool gl_SetupLightTexture();
void gl_UploadLights(FDynLightData &data);
#endif #endif

View file

@ -159,15 +159,13 @@ bool gl_GetLight(Plane & p, ADynamicLight * light, bool checkside, bool forceadd
} }
//========================================================================== //==========================================================================
// //
// Sets up the parameters to render one dynamic light onto one plane // Sets up the parameters to render one dynamic light onto one plane
// //
//========================================================================== //==========================================================================
bool gl_SetupLight(Plane & p, ADynamicLight * light, Vector & nearPt, Vector & up, Vector & right, bool gl_SetupLight(Plane & p, ADynamicLight * light, Vector & nearPt, Vector & up, Vector & right,
float & scale, bool checkside, bool forceadditive) float & scale, int desaturation, bool checkside, bool forceadditive)
{ {
Vector fn, pos; Vector fn, pos;
@ -225,11 +223,45 @@ bool gl_SetupLight(Plane & p, ADynamicLight * light, Vector & nearPt, Vector & u
{ {
gl_RenderState.BlendEquation(GL_FUNC_ADD); gl_RenderState.BlendEquation(GL_FUNC_ADD);
} }
glColor3f(r,g,b); gl_RenderState.SetColor(r, g, b, 1.f, desaturation);
return true; return true;
} }
//==========================================================================
//
//
//
//==========================================================================
#if 0
void gl_UploadLights(FDynLightData &data)
{
ParameterBufferElement *pptr;
int size0 = data.arrays[0].Size()/4;
int size1 = data.arrays[1].Size()/4;
int size2 = data.arrays[2].Size()/4;
if (size0 + size1 + size2 > 0)
{
int sizetotal = size0 + size1 + size2 + 1;
int index = GLRenderer->mParmBuffer->Reserve(sizetotal, &pptr);
float parmcnt[] = { index + 1, index + 1 + size0, index + 1 + size0 + size1, index + 1 + size0 + size1 + size2 };
memcpy(&pptr[0], parmcnt, 4 * sizeof(float));
memcpy(&pptr[1], &data.arrays[0][0], 4 * size0*sizeof(float));
memcpy(&pptr[1 + size0], &data.arrays[1][0], 4 * size1*sizeof(float));
memcpy(&pptr[1 + size0 + size1], &data.arrays[2][0], 4 * size2*sizeof(float));
gl_RenderState.SetDynLightIndex(index);
}
else
{
gl_RenderState.SetDynLightIndex(-1);
}
}
#endif
//========================================================================== //==========================================================================
// //
// //

View file

@ -13,9 +13,6 @@ enum EColorManipulation
CM_INVALID=-1, CM_INVALID=-1,
CM_DEFAULT=0, // untranslated CM_DEFAULT=0, // untranslated
CM_DESAT0=CM_DEFAULT,
CM_DESAT1, // minimum desaturation
CM_DESAT31=CM_DESAT1+30, // maximum desaturation = grayscale
CM_FIRSTSPECIALCOLORMAP, // first special fixed colormap CM_FIRSTSPECIALCOLORMAP, // first special fixed colormap
// special internal values for texture creation // special internal values for texture creation
@ -34,14 +31,14 @@ struct FColormap
{ {
PalEntry LightColor; // a is saturation (0 full, 31=b/w, other=custom colormap) PalEntry LightColor; // a is saturation (0 full, 31=b/w, other=custom colormap)
PalEntry FadeColor; // a is fadedensity>>1 PalEntry FadeColor; // a is fadedensity>>1
int colormap; int desaturation;
int blendfactor; int blendfactor;
void Clear() void Clear()
{ {
LightColor=0xffffff; LightColor=0xffffff;
FadeColor=0; FadeColor=0;
colormap = CM_DEFAULT; desaturation = 0;
blendfactor=0; blendfactor=0;
} }
@ -49,19 +46,14 @@ struct FColormap
{ {
LightColor.r=LightColor.g=LightColor.b=0xff; LightColor.r=LightColor.g=LightColor.b=0xff;
blendfactor=0; blendfactor=0;
desaturation = 0;
} }
void GetFixedColormap()
{
Clear();
colormap = gl_fixedcolormap >= (int)CM_LITE? (int)CM_DEFAULT : gl_fixedcolormap;
}
FColormap & operator=(FDynamicColormap * from) FColormap & operator=(FDynamicColormap * from)
{ {
LightColor = from->Color; LightColor = from->Color;
colormap = from->Desaturate>>3; desaturation = from->Desaturate;
FadeColor = from->Fade; FadeColor = from->Fade;
blendfactor = from->Color.a; blendfactor = from->Color.a;
return * this; return * this;
@ -70,9 +62,15 @@ struct FColormap
void CopyLightColor(FDynamicColormap * from) void CopyLightColor(FDynamicColormap * from)
{ {
LightColor = from->Color; LightColor = from->Color;
colormap = from->Desaturate>>3; desaturation = from->Desaturate;
blendfactor = from->Color.a; blendfactor = from->Color.a;
} }
void Decolorize() // this for 'nocoloredspritelighting' and not the same as desaturation. The normal formula results in a value that's too dark.
{
int v = (LightColor.r + LightColor.g + LightColor.b) / 3;
LightColor.r = LightColor.g = LightColor.b = (255 + v + v) / 3;
}
}; };

View file

@ -72,22 +72,6 @@ CVAR(Bool, gl_brightfog, false, CVAR_ARCHIVE);
//==========================================================================
//
//
//
//==========================================================================
bool gl_BrightmapsActive()
{
return gl.hasGLSL();
}
bool gl_GlowActive()
{
return gl.hasGLSL();
}
//========================================================================== //==========================================================================
// //
// Sets up the fog tables // Sets up the fog tables
@ -337,7 +321,7 @@ void gl_SetColor(int light, int rellight, const FColormap * cm, float alpha, boo
gl_GetLightColor(light, rellight, cm, &r, &g, &b, weapon); gl_GetLightColor(light, rellight, cm, &r, &g, &b, weapon);
gl_RenderState.SetColor(r, g, b, alpha); gl_RenderState.SetColor(r, g, b, alpha, cm->desaturation);
if (glset.lightmode == 8) if (glset.lightmode == 8)
{ {
if (gl_fixedcolormap) if (gl_fixedcolormap)
@ -518,15 +502,9 @@ bool gl_CheckFog(sector_t *frontsector, sector_t *backsector)
void gl_SetShaderLight(float level, float olight) void gl_SetShaderLight(float level, float olight)
{ {
#if 1 //ndef _DEBUG
const float MAXDIST = 256.f; const float MAXDIST = 256.f;
const float THRESHOLD = 96.f; const float THRESHOLD = 96.f;
const float FACTOR = 0.75f; const float FACTOR = 0.75f;
#else
const float MAXDIST = 256.f;
const float THRESHOLD = 96.f;
const float FACTOR = 2.75f;
#endif
if (level > 0) if (level > 0)
{ {
@ -606,9 +584,6 @@ void gl_SetFog(int lightlevel, int rellight, const FColormap *cmap, bool isaddit
{ {
fogcolor=0; fogcolor=0;
} }
// Handle desaturation
if (cmap->colormap != CM_DEFAULT)
gl_ModifyColor(fogcolor.r, fogcolor.g, fogcolor.b, cmap->colormap);
gl_RenderState.EnableFog(true); gl_RenderState.EnableFog(true);
gl_RenderState.SetFog(fogcolor, fogdensity); gl_RenderState.SetFog(fogcolor, fogdensity);
@ -619,29 +594,6 @@ void gl_SetFog(int lightlevel, int rellight, const FColormap *cmap, bool isaddit
} }
} }
//==========================================================================
//
// Modifies a color according to a specified colormap
//
//==========================================================================
void gl_ModifyColor(BYTE & red, BYTE & green, BYTE & blue, int cm)
{
int gray = (red*77 + green*143 + blue*36)>>8;
if (cm >= CM_FIRSTSPECIALCOLORMAP && cm < CM_MAXCOLORMAP)
{
PalEntry pe = SpecialColormaps[cm - CM_FIRSTSPECIALCOLORMAP].GrayscaleToColor[gray];
red = pe.r;
green = pe.g;
blue = pe.b;
}
else if (cm >= CM_DESAT1 && cm <= CM_DESAT31)
{
gl_Desaturate(gray, red, green, blue, red, green, blue, cm - CM_DESAT0);
}
}
//========================================================================== //==========================================================================
// //

View file

@ -5,9 +5,6 @@
#include "r_data/renderstyle.h" #include "r_data/renderstyle.h"
#include "gl/renderer/gl_colormap.h" #include "gl/renderer/gl_colormap.h"
bool gl_BrightmapsActive();
bool gl_GlowActive();
inline int gl_ClampLight(int lightlevel) inline int gl_ClampLight(int lightlevel)
{ {
return clamp(lightlevel, 0, 255); return clamp(lightlevel, 0, 255);
@ -46,14 +43,6 @@ inline bool gl_isFullbright(PalEntry color, int lightlevel)
return gl_fixedcolormap || (gl_isWhite(color) && lightlevel==255); return gl_fixedcolormap || (gl_isWhite(color) && lightlevel==255);
} }
__forceinline void gl_Desaturate(int gray, int ired, int igreen, int iblue, BYTE & red, BYTE & green, BYTE & blue, int fac)
{
red = (ired*(31-fac) + gray*fac)/31;
green = (igreen*(31-fac) + gray*fac)/31;
blue = (iblue*(31-fac) + gray*fac)/31;
}
void gl_ModifyColor(BYTE & red, BYTE & green, BYTE & blue, int cm);
void gl_DeleteAllAttachedLights(); void gl_DeleteAllAttachedLights();
void gl_RecreateAllAttachedLights(); void gl_RecreateAllAttachedLights();

View file

@ -273,10 +273,10 @@ void FGLRenderer::ClearBorders()
glLoadIdentity(); glLoadIdentity();
glOrtho(0.0, width * 1.0, 0.0, trueHeight, -1.0, 1.0); glOrtho(0.0, width * 1.0, 0.0, trueHeight, -1.0, 1.0);
glMatrixMode(GL_MODELVIEW); glMatrixMode(GL_MODELVIEW);
glColor3f(0.f, 0.f, 0.f); gl_RenderState.SetColor(0.f ,0.f ,0.f ,1.f);
gl_RenderState.Set2DMode(true); gl_RenderState.Set2DMode(true);
gl_RenderState.EnableTexture(false); gl_RenderState.EnableTexture(false);
gl_RenderState.Apply(true); gl_RenderState.Apply();
glBegin(GL_QUADS); glBegin(GL_QUADS);
// upper quad // upper quad
@ -311,36 +311,35 @@ void FGLRenderer::DrawTexture(FTexture *img, DCanvas::DrawParms &parms)
double y = parms.y - parms.top * yscale; double y = parms.y - parms.top * yscale;
double w = parms.destwidth; double w = parms.destwidth;
double h = parms.destheight; double h = parms.destheight;
float u1, v1, u2, v2, r, g, b; float u1, v1, u2, v2;
float light = 1.f; int light = 255;
FMaterial * gltex = FMaterial::ValidateTexture(img); FMaterial * gltex = FMaterial::ValidateTexture(img);
if (parms.colorOverlay && (parms.colorOverlay & 0xffffff) == 0) if (parms.colorOverlay && (parms.colorOverlay & 0xffffff) == 0)
{ {
// Right now there's only black. Should be implemented properly later // Right now there's only black. Should be implemented properly later
light = 1.f - APART(parms.colorOverlay)/255.f; light = 255 - APART(parms.colorOverlay);
parms.colorOverlay = 0; parms.colorOverlay = 0;
} }
if (!img->bHasCanvas) if (!img->bHasCanvas)
{ {
if (!parms.alphaChannel) int translation = 0;
if (!parms.alphaChannel)
{ {
int translation = 0;
if (parms.remap != NULL && !parms.remap->Inactive) if (parms.remap != NULL && !parms.remap->Inactive)
{ {
GLTranslationPalette * pal = static_cast<GLTranslationPalette*>(parms.remap->GetNative()); GLTranslationPalette * pal = static_cast<GLTranslationPalette*>(parms.remap->GetNative());
if (pal) translation = -pal->GetIndex(); if (pal) translation = -pal->GetIndex();
} }
gltex->BindPatch(translation);
} }
else else
{ {
// This is an alpha texture // This is an alpha texture
gl_RenderState.SetTextureMode(TM_REDTOALPHA); gl_RenderState.SetTextureMode(TM_REDTOALPHA);
gltex->BindPatch(0);
} }
gltex->BindPatch(translation);
u1 = gltex->GetUL(); u1 = gltex->GetUL();
v1 = gltex->GetVT(); v1 = gltex->GetVT();
@ -373,17 +372,17 @@ void FGLRenderer::DrawTexture(FTexture *img, DCanvas::DrawParms &parms)
u2 = float(u2 - (parms.texwidth - parms.windowright) / parms.texwidth); u2 = float(u2 - (parms.texwidth - parms.windowright) / parms.texwidth);
} }
PalEntry color;
if (parms.style.Flags & STYLEF_ColorIsFixed) if (parms.style.Flags & STYLEF_ColorIsFixed)
{ {
r = RPART(parms.fillcolor)/255.0f; color = parms.fillcolor;
g = GPART(parms.fillcolor)/255.0f;
b = BPART(parms.fillcolor)/255.0f;
} }
else else
{ {
r = g = b = light; color = PalEntry(light, light, light);
} }
color.a = Scale(parms.alpha, 255, FRACUNIT);
// scissor test doesn't use the current viewport for the coordinates, so use real screen coordinates // scissor test doesn't use the current viewport for the coordinates, so use real screen coordinates
int btm = (SCREENHEIGHT - screen->GetHeight()) / 2; int btm = (SCREENHEIGHT - screen->GetHeight()) / 2;
btm = SCREENHEIGHT - btm; btm = SCREENHEIGHT - btm;
@ -398,8 +397,7 @@ void FGLRenderer::DrawTexture(FTexture *img, DCanvas::DrawParms &parms)
gl_RenderState.SetTextureMode(TM_OPAQUE); gl_RenderState.SetTextureMode(TM_OPAQUE);
} }
glColor4f(r, g, b, FIXED2FLOAT(parms.alpha)); gl_RenderState.SetColor(color);
gl_RenderState.EnableAlphaTest(false); gl_RenderState.EnableAlphaTest(false);
gl_RenderState.Apply(); gl_RenderState.Apply();
glBegin(GL_TRIANGLE_STRIP); glBegin(GL_TRIANGLE_STRIP);
@ -418,8 +416,9 @@ void FGLRenderer::DrawTexture(FTexture *img, DCanvas::DrawParms &parms)
gl_RenderState.SetTextureMode(TM_MASK); gl_RenderState.SetTextureMode(TM_MASK);
gl_RenderState.BlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); gl_RenderState.BlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
gl_RenderState.BlendEquation(GL_FUNC_ADD); gl_RenderState.BlendEquation(GL_FUNC_ADD);
gl_RenderState.SetColor(PalEntry(parms.colorOverlay));
gl_RenderState.Apply(); gl_RenderState.Apply();
glColor4ub(RPART(parms.colorOverlay),GPART(parms.colorOverlay),BPART(parms.colorOverlay),APART(parms.colorOverlay));
glBegin(GL_TRIANGLE_STRIP); glBegin(GL_TRIANGLE_STRIP);
glTexCoord2f(u1, v1); glTexCoord2f(u1, v1);
glVertex2d(x, y); glVertex2d(x, y);
@ -450,8 +449,8 @@ void FGLRenderer::DrawLine(int x1, int y1, int x2, int y2, int palcolor, uint32
{ {
PalEntry p = color? (PalEntry)color : GPalette.BaseColors[palcolor]; PalEntry p = color? (PalEntry)color : GPalette.BaseColors[palcolor];
gl_RenderState.EnableTexture(false); gl_RenderState.EnableTexture(false);
gl_RenderState.Apply(true); gl_RenderState.SetColorAlpha(p, 1.f);
glColor3ub(p.r, p.g, p.b); gl_RenderState.Apply();
glBegin(GL_LINES); glBegin(GL_LINES);
glVertex2i(x1, y1); glVertex2i(x1, y1);
glVertex2i(x2, y2); glVertex2i(x2, y2);
@ -468,8 +467,8 @@ void FGLRenderer::DrawPixel(int x1, int y1, int palcolor, uint32 color)
{ {
PalEntry p = color? (PalEntry)color : GPalette.BaseColors[palcolor]; PalEntry p = color? (PalEntry)color : GPalette.BaseColors[palcolor];
gl_RenderState.EnableTexture(false); gl_RenderState.EnableTexture(false);
gl_RenderState.Apply(true); gl_RenderState.SetColorAlpha(p, 1.f);
glColor3ub(p.r, p.g, p.b); gl_RenderState.Apply();
glBegin(GL_POINTS); glBegin(GL_POINTS);
glVertex2i(x1, y1); glVertex2i(x1, y1);
glEnd(); glEnd();
@ -484,19 +483,13 @@ void FGLRenderer::DrawPixel(int x1, int y1, int palcolor, uint32 color)
void FGLRenderer::Dim(PalEntry color, float damount, int x1, int y1, int w, int h) void FGLRenderer::Dim(PalEntry color, float damount, int x1, int y1, int w, int h)
{ {
float r, g, b;
gl_RenderState.EnableTexture(false); gl_RenderState.EnableTexture(false);
gl_RenderState.BlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); gl_RenderState.BlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
gl_RenderState.AlphaFunc(GL_GREATER,0); gl_RenderState.AlphaFunc(GL_GREATER,0);
gl_RenderState.Apply(true); gl_RenderState.SetColorAlpha(color, damount);
gl_RenderState.Apply();
r = color.r/255.0f;
g = color.g/255.0f;
b = color.b/255.0f;
glBegin(GL_TRIANGLE_FAN); glBegin(GL_TRIANGLE_FAN);
glColor4f(r, g, b, damount);
glVertex2i(x1, y1); glVertex2i(x1, y1);
glVertex2i(x1, y1 + h); glVertex2i(x1, y1 + h);
glVertex2i(x1 + w, y1 + h); glVertex2i(x1 + w, y1 + h);
@ -536,9 +529,9 @@ void FGLRenderer::FlatFill (int left, int top, int right, int bottom, FTexture *
fU2 = float(right-left) / src->GetWidth(); fU2 = float(right-left) / src->GetWidth();
fV2 = float(bottom-top) / src->GetHeight(); fV2 = float(bottom-top) / src->GetHeight();
} }
gl_RenderState.ResetColor();
gl_RenderState.Apply(); gl_RenderState.Apply();
glBegin(GL_TRIANGLE_STRIP); glBegin(GL_TRIANGLE_STRIP);
glColor4f(1, 1, 1, 1);
glTexCoord2f(fU1, fV1); glVertex2f(left, top); glTexCoord2f(fU1, fV1); glVertex2f(left, top);
glTexCoord2f(fU1, fV2); glVertex2f(left, bottom); glTexCoord2f(fU1, fV2); glVertex2f(left, bottom);
glTexCoord2f(fU2, fV1); glVertex2f(right, top); glTexCoord2f(fU2, fV1); glVertex2f(right, top);
@ -609,9 +602,7 @@ void FGLRenderer::FillSimplePoly(FTexture *texture, FVector2 *points, int npoint
FColormap cm; FColormap cm;
cm = colormap; cm = colormap;
lightlevel = gl_CalcLightLevel(lightlevel, 0, true); gl_SetColor(lightlevel, 0, &cm, 1.f);
PalEntry pe = gl_CalcLightColor(lightlevel, cm.LightColor, cm.blendfactor, true);
glColor3ub(pe.r, pe.g, pe.b);
gltexture->Bind(); gltexture->Bind();

View file

@ -183,8 +183,7 @@ void GLWall::DrawDecal(DBaseDecal *decal)
if (glset.nocoloredspritelighting) if (glset.nocoloredspritelighting)
{ {
int v = (Colormap.LightColor.r * 77 + Colormap.LightColor.g*143 + Colormap.LightColor.b*35)/255; p.Decolorize();
p.LightColor = PalEntry(p.colormap, v, v, v);
} }

View file

@ -985,7 +985,7 @@ void FDrawInfo::SetupFloodStencil(wallseg * ws)
glStencilOp(GL_KEEP,GL_KEEP,GL_INCR); // increment stencil of valid pixels glStencilOp(GL_KEEP,GL_KEEP,GL_INCR); // increment stencil of valid pixels
glColorMask(0,0,0,0); // don't write to the graphics buffer glColorMask(0,0,0,0); // don't write to the graphics buffer
gl_RenderState.EnableTexture(false); gl_RenderState.EnableTexture(false);
glColor3f(1,1,1); gl_RenderState.ResetColor();
glEnable(GL_DEPTH_TEST); glEnable(GL_DEPTH_TEST);
glDepthMask(true); glDepthMask(true);
@ -1013,7 +1013,7 @@ void FDrawInfo::ClearFloodStencil(wallseg * ws)
glStencilOp(GL_KEEP,GL_KEEP,GL_DECR); glStencilOp(GL_KEEP,GL_KEEP,GL_DECR);
gl_RenderState.EnableTexture(false); gl_RenderState.EnableTexture(false);
glColorMask(0,0,0,0); // don't write to the graphics buffer glColorMask(0,0,0,0); // don't write to the graphics buffer
glColor3f(1,1,1); gl_RenderState.ResetColor();
gl_RenderState.Apply(); gl_RenderState.Apply();
glBegin(GL_TRIANGLE_FAN); glBegin(GL_TRIANGLE_FAN);
@ -1051,7 +1051,7 @@ void FDrawInfo::DrawFloodedPlane(wallseg * ws, float planez, sector_t * sec, boo
if (gl_fixedcolormap) if (gl_fixedcolormap)
{ {
Colormap.GetFixedColormap(); Colormap.Clear();
lightlevel=255; lightlevel=255;
} }
else else

View file

@ -143,12 +143,13 @@ void GLFlat::DrawSubsectorLights(subsector_t * sub, int pass)
} }
p.Set(plane.plane); p.Set(plane.plane);
if (!gl_SetupLight(p, light, nearPt, up, right, scale, false, foggy)) if (!gl_SetupLight(p, light, nearPt, up, right, scale, Colormap.desaturation, false, foggy))
{ {
node=node->nextLight; node=node->nextLight;
continue; continue;
} }
draw_dlightf++; draw_dlightf++;
gl_RenderState.Apply();
// Render the light // Render the light
glBegin(GL_TRIANGLE_FAN); glBegin(GL_TRIANGLE_FAN);
@ -501,7 +502,7 @@ inline void GLFlat::PutFlat(bool fog)
if (gl_fixedcolormap) if (gl_fixedcolormap)
{ {
Colormap.GetFixedColormap(); Colormap.Clear();
} }
if (renderstyle!=STYLE_Translucent || alpha < 1.f - FLT_EPSILON || fog) if (renderstyle!=STYLE_Translucent || alpha < 1.f - FLT_EPSILON || fog)
{ {
@ -533,7 +534,7 @@ inline void GLFlat::PutFlat(bool fog)
else foggy = false; else foggy = false;
list = list_indices[light][masked][foggy]; list = list_indices[light][masked][foggy];
if (list == GLDL_LIGHT && gltexture->tex->gl_info.Brightmap && gl_BrightmapsActive()) list = GLDL_LIGHTBRIGHT; if (list == GLDL_LIGHT && gltexture->tex->gl_info.Brightmap && gl.hasGLSL()) list = GLDL_LIGHTBRIGHT;
gl_drawinfo->drawlists[list].AddFlat (this); gl_drawinfo->drawlists[list].AddFlat (this);
} }

View file

@ -474,7 +474,7 @@ void FGLRenderer::RenderScene(int recursion)
} }
// third pass: modulated texture // third pass: modulated texture
glColor3f(1.0f, 1.0f, 1.0f); gl_RenderState.ResetColor();
gl_RenderState.BlendFunc(GL_DST_COLOR, GL_ZERO); gl_RenderState.BlendFunc(GL_DST_COLOR, GL_ZERO);
gl_RenderState.EnableFog(false); gl_RenderState.EnableFog(false);
glDepthFunc(GL_LEQUAL); glDepthFunc(GL_LEQUAL);
@ -619,7 +619,7 @@ static void FillScreen()
{ {
gl_RenderState.EnableAlphaTest(false); gl_RenderState.EnableAlphaTest(false);
gl_RenderState.EnableTexture(false); gl_RenderState.EnableTexture(false);
gl_RenderState.Apply(true); gl_RenderState.Apply();
glBegin(GL_TRIANGLE_STRIP); glBegin(GL_TRIANGLE_STRIP);
glVertex2f(0.0f, 0.0f); glVertex2f(0.0f, 0.0f);
glVertex2f(0.0f, (float)SCREENHEIGHT); glVertex2f(0.0f, (float)SCREENHEIGHT);
@ -715,7 +715,7 @@ void FGLRenderer::DrawBlend(sector_t * viewsector)
if (extra_red || extra_green || extra_blue) if (extra_red || extra_green || extra_blue)
{ {
gl_RenderState.BlendFunc(GL_DST_COLOR, GL_ZERO); gl_RenderState.BlendFunc(GL_DST_COLOR, GL_ZERO);
glColor4f(extra_red, extra_green, extra_blue, 1.0f); gl_RenderState.SetColor(extra_red, extra_green, extra_blue, 1.0f);
FillScreen(); FillScreen();
} }
} }
@ -773,14 +773,14 @@ void FGLRenderer::DrawBlend(sector_t * viewsector)
if (inverse) if (inverse)
{ {
gl_RenderState.BlendFunc(GL_ONE_MINUS_DST_COLOR, GL_ZERO); gl_RenderState.BlendFunc(GL_ONE_MINUS_DST_COLOR, GL_ZERO);
glColor4f(1.f, 1.f, 1.f, 1.f); gl_RenderState.ResetColor();
FillScreen(); FillScreen();
} }
if (r < WHITE_THRESH || g < WHITE_THRESH || b < WHITE_THRESH) if (r < WHITE_THRESH || g < WHITE_THRESH || b < WHITE_THRESH)
{ {
gl_RenderState.BlendFunc(GL_DST_COLOR, GL_ZERO); gl_RenderState.BlendFunc(GL_DST_COLOR, GL_ZERO);
glColor4f(r, g, b, 1.0f); gl_RenderState.SetColor(r, g, b, 1.0f);
FillScreen(); FillScreen();
} }
} }
@ -806,7 +806,7 @@ void FGLRenderer::DrawBlend(sector_t * viewsector)
if (blend[3]>0.0f) if (blend[3]>0.0f)
{ {
gl_RenderState.BlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); gl_RenderState.BlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
glColor4fv(blend); gl_RenderState.SetColor(blend[0], blend[1], blend[2], blend[3]);
FillScreen(); FillScreen();
} }
} }
@ -850,7 +850,7 @@ void FGLRenderer::EndDrawScene(sector_t * viewsector)
// Restore standard rendering state // Restore standard rendering state
gl_RenderState.BlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); gl_RenderState.BlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
glColor3f(1.0f,1.0f,1.0f); gl_RenderState.ResetColor();
gl_RenderState.EnableTexture(true); gl_RenderState.EnableTexture(true);
gl_RenderState.EnableAlphaTest(true); gl_RenderState.EnableAlphaTest(true);
glDisable(GL_SCISSOR_TEST); glDisable(GL_SCISSOR_TEST);

View file

@ -109,7 +109,7 @@ static void SkyVertex(int r, int c)
if (!foglayer) if (!foglayer)
{ {
// this cannot use the renderstate because it's inside a primitive. // this must not use the renderstate because it's inside a primitive.
glColor4f(1.f, 1.f, 1.f, r==0? 0.0f : 1.0f); glColor4f(1.f, 1.f, 1.f, r==0? 0.0f : 1.0f);
// And the texture coordinates. // And the texture coordinates.
@ -244,7 +244,7 @@ static void RenderDome(FTextureID texno, FMaterial * tex, float x_offset, float
int texh = 0; int texh = 0;
bool texscale = false; bool texscale = false;
// 57 worls units roughly represent one sky texel for the glTranslate call. // 57 world units roughly represent one sky texel for the glTranslate call.
const float skyoffsetfactor = 57; const float skyoffsetfactor = 57;
if (tex) if (tex)
@ -511,7 +511,7 @@ void GLSkyPortal::DrawContents()
FadeColor = origin->fadecolor; FadeColor = origin->fadecolor;
} }
gl_RenderState.SetColor(0xffffffff); gl_RenderState.ResetColor();
gl_RenderState.EnableFog(false); gl_RenderState.EnableFog(false);
gl_RenderState.EnableAlphaTest(false); gl_RenderState.EnableAlphaTest(false);
gl_RenderState.BlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); gl_RenderState.BlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);

View file

@ -112,10 +112,6 @@ void GLSprite::Draw(int pass)
{ {
if (pass!=GLPASS_PLAIN && pass != GLPASS_ALL && pass!=GLPASS_TRANSLUCENT) return; if (pass!=GLPASS_PLAIN && pass != GLPASS_ALL && pass!=GLPASS_TRANSLUCENT) return;
// Hack to enable bright sprites in faded maps
uint32 backupfade = Colormap.FadeColor.d;
if (gl_spritebrightfog && fullbright)
Colormap.FadeColor = 0;
bool additivefog = false; bool additivefog = false;
@ -126,16 +122,15 @@ void GLSprite::Draw(int pass)
{ {
// The translucent pass requires special setup for the various modes. // The translucent pass requires special setup for the various modes.
// Brightmaps will only be used when doing regular drawing ops and having no fog // for special render styles brightmaps would not look good - especially for subtractive.
if (!gl_spritebrightfog && (!gl_isBlack(Colormap.FadeColor) || level.flags&LEVEL_HASFADETABLE || if (RenderStyle.BlendOp != STYLEOP_Add)
RenderStyle.BlendOp != STYLEOP_Add))
{ {
gl_RenderState.EnableBrightmap(false); gl_RenderState.EnableBrightmap(false);
} }
gl_SetRenderStyle(RenderStyle, false, gl_SetRenderStyle(RenderStyle, false,
// The rest of the needed checks are done inside gl_SetRenderStyle // The rest of the needed checks are done inside gl_SetRenderStyle
trans > 1.f - FLT_EPSILON && gl_usecolorblending && gl_fixedcolormap < CM_FIRSTSPECIALCOLORMAP && actor && trans > 1.f - FLT_EPSILON && gl_usecolorblending && gl_fixedcolormap == CM_DEFAULT && actor &&
fullbright && gltexture && !gltexture->GetTransparent()); fullbright && gltexture && !gltexture->GetTransparent());
if (hw_styleflags == STYLEHW_NoAlphaTest) if (hw_styleflags == STYLEHW_NoAlphaTest)
@ -169,7 +164,7 @@ void GLSprite::Draw(int pass)
} }
gl_RenderState.AlphaFunc(GL_GEQUAL,minalpha*gl_mask_sprite_threshold); gl_RenderState.AlphaFunc(GL_GEQUAL,minalpha*gl_mask_sprite_threshold);
gl_RenderState.SetColor(0.2f,0.2f,0.2f,fuzzalpha); gl_RenderState.SetColor(0.2f,0.2f,0.2f,fuzzalpha, Colormap.desaturation);
additivefog = true; additivefog = true;
} }
else if (RenderStyle.BlendOp == STYLEOP_Add && RenderStyle.DestAlpha == STYLEALPHA_One) else if (RenderStyle.BlendOp == STYLEOP_Add && RenderStyle.DestAlpha == STYLEALPHA_One)
@ -339,12 +334,8 @@ void GLSprite::Draw(int pass)
} }
} }
// End of gl_sprite_brightfog hack: restore FadeColor to normalcy
if (backupfade != Colormap.FadeColor.d)
Colormap.FadeColor = backupfade;
gl_RenderState.EnableTexture(true);
gl_RenderState.SetObjectColor(0xffffffff); gl_RenderState.SetObjectColor(0xffffffff);
gl_RenderState.EnableTexture(true);
gl_RenderState.SetDynLight(0,0,0); gl_RenderState.SetDynLight(0,0,0);
} }
@ -696,7 +687,7 @@ void GLSprite::Process(AActor* thing,sector_t * sector)
// allow disabling of the fullbright flag by a brightmap definition // allow disabling of the fullbright flag by a brightmap definition
// (e.g. to do the gun flashes of Doom's zombies correctly. // (e.g. to do the gun flashes of Doom's zombies correctly.
fullbright = (thing->flags5 & MF5_BRIGHT) || fullbright = (thing->flags5 & MF5_BRIGHT) ||
((thing->renderflags & RF_FULLBRIGHT) && (!gl_BrightmapsActive() || !gltexture || !gltexture->tex->gl_info.bBrightmapDisablesFullbright)); ((thing->renderflags & RF_FULLBRIGHT) && (!gl.hasGLSL() || !gltexture || !gltexture->tex->gl_info.bBrightmapDisablesFullbright));
lightlevel=fullbright? 255 : lightlevel=fullbright? 255 :
gl_ClampLight(rendersector->GetTexture(sector_t::ceiling) == skyflatnum ? gl_ClampLight(rendersector->GetTexture(sector_t::ceiling) == skyflatnum ?
@ -717,7 +708,7 @@ void GLSprite::Process(AActor* thing,sector_t * sector)
|| (gl_enhanced_nv_stealth == 3)) // Any fixed colormap || (gl_enhanced_nv_stealth == 3)) // Any fixed colormap
enhancedvision=true; enhancedvision=true;
Colormap.GetFixedColormap(); Colormap.Clear();
if (gl_fixedcolormap==CM_LITE) if (gl_fixedcolormap==CM_LITE)
{ {
@ -750,10 +741,7 @@ void GLSprite::Process(AActor* thing,sector_t * sector)
} }
else if (glset.nocoloredspritelighting) else if (glset.nocoloredspritelighting)
{ {
int v = (Colormap.LightColor.r /* * 77 */ + Colormap.LightColor.g /**143 */ + Colormap.LightColor.b /**35*/)/3;//255; Colormap.Decolorize();
Colormap.LightColor.r=
Colormap.LightColor.g=
Colormap.LightColor.b=(255+v+v)/3;
} }
} }
@ -894,7 +882,7 @@ void GLSprite::ProcessParticle (particle_t *particle, sector_t *sector)//, int s
if (gl_fixedcolormap) if (gl_fixedcolormap)
{ {
Colormap.GetFixedColormap(); Colormap.Clear();
} }
else if (!particle->bright) else if (!particle->bright)
{ {

View file

@ -71,7 +71,7 @@
void GLWall::CheckGlowing() void GLWall::CheckGlowing()
{ {
bottomglowcolor[3] = topglowcolor[3] = 0; bottomglowcolor[3] = topglowcolor[3] = 0;
if (!gl_isFullbright(Colormap.LightColor, lightlevel) && gl_GlowActive()) if (!gl_isFullbright(Colormap.LightColor, lightlevel) && gl.hasGLSL())
{ {
FTexture *tex = TexMan[topflat]; FTexture *tex = TexMan[topflat];
if (tex != NULL && tex->isGlowing()) if (tex != NULL && tex->isGlowing())
@ -133,7 +133,7 @@ void GLWall::PutWall(bool translucent)
// light planes don't get drawn with fullbright rendering // light planes don't get drawn with fullbright rendering
if (!gltexture && passflag[type]!=4) return; if (!gltexture && passflag[type]!=4) return;
Colormap.GetFixedColormap(); Colormap.Clear();
} }
CheckGlowing(); CheckGlowing();
@ -184,7 +184,7 @@ void GLWall::PutWall(bool translucent)
list = list_indices[light][masked][!!(flags&GLWF_FOGGY)]; list = list_indices[light][masked][!!(flags&GLWF_FOGGY)];
if (list == GLDL_LIGHT) if (list == GLDL_LIGHT)
{ {
if (gltexture->tex->gl_info.Brightmap && gl_BrightmapsActive()) list = GLDL_LIGHTBRIGHT; if (gltexture->tex->gl_info.Brightmap && gl.hasGLSL()) list = GLDL_LIGHTBRIGHT;
if (flags & GLWF_GLOW) list = GLDL_LIGHTBRIGHT; if (flags & GLWF_GLOW) list = GLDL_LIGHTBRIGHT;
} }
gl_drawinfo->drawlists[list].AddWall(this); gl_drawinfo->drawlists[list].AddWall(this);
@ -525,7 +525,7 @@ bool GLWall::DoHorizon(seg_t * seg,sector_t * fs, vertex_t * v1,vertex_t * v2)
hi.colormap.LightColor = (light->extra_colormap)->Color; hi.colormap.LightColor = (light->extra_colormap)->Color;
} }
if (gl_fixedcolormap) hi.colormap.GetFixedColormap(); if (gl_fixedcolormap) hi.colormap.Clear();
horizon = &hi; horizon = &hi;
PutWall(0); PutWall(0);
} }
@ -554,8 +554,8 @@ bool GLWall::DoHorizon(seg_t * seg,sector_t * fs, vertex_t * v1,vertex_t * v2)
hi.colormap.LightColor = (light->extra_colormap)->Color; hi.colormap.LightColor = (light->extra_colormap)->Color;
} }
if (gl_fixedcolormap) hi.colormap.GetFixedColormap(); if (gl_fixedcolormap) hi.colormap.Clear();
horizon=&hi; horizon = &hi;
PutWall(0); PutWall(0);
} }
} }

View file

@ -81,7 +81,7 @@ bool GLWall::PrepareLight(texcoord * tcs, ADynamicLight * light)
return false; return false;
} }
if (!gl_SetupLight(p, light, nearPt, up, right, scale, true, !!(flags&GLWF_FOGGY))) if (!gl_SetupLight(p, light, nearPt, up, right, scale, Colormap.desaturation, true, !!(flags&GLWF_FOGGY)))
{ {
return false; return false;
} }
@ -267,7 +267,7 @@ void GLWall::RenderWall(int textured, float * color2, ADynamicLight * light)
if (split && !(flags & GLWF_NOSPLITUPPER)) SplitUpperEdge(tcs); if (split && !(flags & GLWF_NOSPLITUPPER)) SplitUpperEdge(tcs);
// color for right side // color for right side (do not set in render state!)
if (color2) glColor4fv(color2); if (color2) glColor4fv(color2);
// upper right corner // upper right corner
@ -365,15 +365,13 @@ void GLWall::RenderFogBoundary()
float fogd1=(0.95f-exp(-fogdensity*dist1/62500.f)) * 1.05f; float fogd1=(0.95f-exp(-fogdensity*dist1/62500.f)) * 1.05f;
float fogd2=(0.95f-exp(-fogdensity*dist2/62500.f)) * 1.05f; float fogd2=(0.95f-exp(-fogdensity*dist2/62500.f)) * 1.05f;
gl_ModifyColor(Colormap.FadeColor.r, Colormap.FadeColor.g, Colormap.FadeColor.b, Colormap.colormap);
float fc[4]={Colormap.FadeColor.r/255.0f,Colormap.FadeColor.g/255.0f,Colormap.FadeColor.b/255.0f,fogd2}; float fc[4]={Colormap.FadeColor.r/255.0f,Colormap.FadeColor.g/255.0f,Colormap.FadeColor.b/255.0f,fogd2};
gl_RenderState.EnableTexture(false); gl_RenderState.EnableTexture(false);
gl_RenderState.EnableFog(false); gl_RenderState.EnableFog(false);
gl_RenderState.AlphaFunc(GL_GREATER,0); gl_RenderState.AlphaFunc(GL_GREATER,0);
glDepthFunc(GL_LEQUAL); glDepthFunc(GL_LEQUAL);
glColor4f(fc[0],fc[1],fc[2], fogd1); gl_RenderState.SetColor(fc[0], fc[1], fc[2], fogd1, Colormap.desaturation);
gl_RenderState.SetColor(-1, 0, 0, 0); // we do not want the render state to control the color.
if (glset.lightmode == 8) glVertexAttrib1f(VATTR_LIGHTLEVEL, 1.0); // Korshun. if (glset.lightmode == 8) glVertexAttrib1f(VATTR_LIGHTLEVEL, 1.0); // Korshun.
flags &= ~GLWF_GLOW; flags &= ~GLWF_GLOW;
@ -406,10 +404,10 @@ void GLWall::RenderMirrorSurface()
gl_RenderState.SetEffect(EFF_SPHEREMAP); gl_RenderState.SetEffect(EFF_SPHEREMAP);
gl_SetColor(lightlevel, 0, &Colormap ,0.1f); gl_SetColor(lightlevel, 0, &Colormap ,0.1f);
gl_SetFog(lightlevel, 0, &Colormap, true);
gl_RenderState.BlendFunc(GL_SRC_ALPHA,GL_ONE); gl_RenderState.BlendFunc(GL_SRC_ALPHA,GL_ONE);
gl_RenderState.AlphaFunc(GL_GREATER,0); gl_RenderState.AlphaFunc(GL_GREATER,0);
glDepthFunc(GL_LEQUAL); glDepthFunc(GL_LEQUAL);
gl_SetFog(lightlevel, getExtraLight(), &Colormap, true);
FMaterial * pat=FMaterial::ValidateTexture(GLRenderer->mirrortexture); FMaterial * pat=FMaterial::ValidateTexture(GLRenderer->mirrortexture);
pat->BindPatch(0); pat->BindPatch(0);

View file

@ -203,7 +203,7 @@ void FGLRenderer::DrawPlayerSprites(sector_t * viewsector, bool hudModelStep)
{ {
bool disablefullbright = false; bool disablefullbright = false;
FTextureID lump = gl_GetSpriteFrame(psp->sprite, psp->frame, 0, 0, NULL); FTextureID lump = gl_GetSpriteFrame(psp->sprite, psp->frame, 0, 0, NULL);
if (lump.isValid() && gl_BrightmapsActive()) if (lump.isValid() && gl.hasGLSL())
{ {
FMaterial * tex=FMaterial::ValidateTexture(lump, false); FMaterial * tex=FMaterial::ValidateTexture(lump, false);
if (tex) if (tex)
@ -217,7 +217,7 @@ void FGLRenderer::DrawPlayerSprites(sector_t * viewsector, bool hudModelStep)
if (gl_fixedcolormap) if (gl_fixedcolormap)
{ {
lightlevel=255; lightlevel=255;
cm.GetFixedColormap(); cm.Clear();
statebright[0] = statebright[1] = true; statebright[0] = statebright[1] = true;
fakesec = viewsector; fakesec = viewsector;
} }
@ -294,7 +294,7 @@ void FGLRenderer::DrawPlayerSprites(sector_t * viewsector, bool hudModelStep)
playermo->Inventory->AlterWeaponSprite(&vis); playermo->Inventory->AlterWeaponSprite(&vis);
if (vis.colormap >= SpecialColormaps[0].Colormap && if (vis.colormap >= SpecialColormaps[0].Colormap &&
vis.colormap < SpecialColormaps[SpecialColormaps.Size()].Colormap && vis.colormap < SpecialColormaps[SpecialColormaps.Size()].Colormap &&
cm.colormap == CM_DEFAULT) gl_fixedcolormap == CM_DEFAULT)
{ {
// this only happens for Strife's inverted weapon sprite // this only happens for Strife's inverted weapon sprite
vis.RenderStyle.Flags |= STYLEF_InvertSource; vis.RenderStyle.Flags |= STYLEF_InvertSource;
@ -379,7 +379,7 @@ void FGLRenderer::DrawPlayerSprites(sector_t * viewsector, bool hudModelStep)
// set the lighting parameters // set the lighting parameters
if (vis.RenderStyle.BlendOp == STYLEOP_Shadow) if (vis.RenderStyle.BlendOp == STYLEOP_Shadow)
{ {
gl_RenderState.SetColor(0.2f, 0.2f, 0.2f, 0.33f);// 0x55333333, cmc.desaturation); gl_RenderState.SetColor(0.2f, 0.2f, 0.2f, 0.33f, cmc.desaturation);
} }
else else
{ {

View file

@ -393,6 +393,7 @@ FShader *FShaderContainer::Bind(int cm, bool glowing, float Speed, bool lights)
glUniform3fv(sh->colormaprange_index, 1, m); glUniform3fv(sh->colormaprange_index, 1, m);
} }
} }
/*
else else
{ {
bool desat = cm>=CM_DESAT1 && cm<=CM_DESAT31; bool desat = cm>=CM_DESAT1 && cm<=CM_DESAT31;
@ -407,6 +408,7 @@ FShader *FShaderContainer::Bind(int cm, bool glowing, float Speed, bool lights)
} }
} }
} }
*/
return sh; return sh;
} }

View file

@ -771,6 +771,7 @@ struct sector_t
int subsectorcount; // list of subsectors int subsectorcount; // list of subsectors
subsector_t ** subsectors; subsector_t ** subsectors;
FPortal * portals[2]; // floor and ceiling portals FPortal * portals[2]; // floor and ceiling portals
FLightNode * lighthead[2];
enum enum
{ {