mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
Add r_pr_lighting 2, which disables the hard-coded lights while leaving lights added in maps enabled.
This also adds a menu option to control r_pr_lighting. git-svn-id: https://svn.eduke32.com/eduke32@5406 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
3ae7f7ade3
commit
f22dbc6fdb
5 changed files with 60 additions and 27 deletions
|
@ -2133,10 +2133,9 @@ static int32_t polymost_md3draw(md3model_t *m, const tspritetype *tspr)
|
||||||
if (grhalfxdown10x < 0) { mat[0] = -mat[0]; mat[4] = -mat[4]; mat[8] = -mat[8]; mat[12] = -mat[12]; }
|
if (grhalfxdown10x < 0) { mat[0] = -mat[0]; mat[4] = -mat[4]; mat[8] = -mat[8]; mat[12] = -mat[12]; }
|
||||||
|
|
||||||
//------------
|
//------------
|
||||||
// Bit 10 is an ugly hack in game.c:G_DoSpriteAnimations() telling md2sprite
|
// TSPR_EXTRA_MDHACK is an ugly hack in game.c:G_DoSpriteAnimations() telling md2sprite
|
||||||
// to use Z-buffer hacks to hide overdraw problems with the
|
// to use Z-buffer hacks to hide overdraw problems with the flat-tsprite-on-floor shadows,
|
||||||
// flat-tsprite-on-floor shadows.
|
// also disabling detail, glow, normal, and specular maps.
|
||||||
// is this still needed?
|
|
||||||
|
|
||||||
if (tspr->extra&TSPR_EXTRA_MDHACK)
|
if (tspr->extra&TSPR_EXTRA_MDHACK)
|
||||||
{
|
{
|
||||||
|
|
|
@ -5685,7 +5685,7 @@ void polymost_initosdfuncs(void)
|
||||||
|
|
||||||
#ifdef POLYMER
|
#ifdef POLYMER
|
||||||
// polymer cvars
|
// polymer cvars
|
||||||
{ "r_pr_lighting", "enable/disable dynamic lights - restarts renderer", (void *) &pr_lighting, CVAR_BOOL | CVAR_RESTARTVID, 0, 1 },
|
{ "r_pr_lighting", "enable/disable dynamic lights - restarts renderer", (void *) &pr_lighting, CVAR_INT | CVAR_RESTARTVID, 0, 2 },
|
||||||
{ "r_pr_normalmapping", "enable/disable virtual displacement mapping", (void *) &pr_normalmapping, CVAR_BOOL, 0, 1 },
|
{ "r_pr_normalmapping", "enable/disable virtual displacement mapping", (void *) &pr_normalmapping, CVAR_BOOL, 0, 1 },
|
||||||
{ "r_pr_specularmapping", "enable/disable specular mapping", (void *) &pr_specularmapping, CVAR_BOOL, 0, 1 },
|
{ "r_pr_specularmapping", "enable/disable specular mapping", (void *) &pr_specularmapping, CVAR_BOOL, 0, 1 },
|
||||||
{ "r_pr_shadows", "enable/disable dynamic shadows", (void *) &pr_shadows, CVAR_BOOL, 0, 1 },
|
{ "r_pr_shadows", "enable/disable dynamic shadows", (void *) &pr_shadows, CVAR_BOOL, 0, 1 },
|
||||||
|
|
|
@ -784,7 +784,7 @@ void G_AddGameLight(int32_t radius, int32_t srcsprite, int32_t zoffset, int32_t
|
||||||
#ifdef POLYMER
|
#ifdef POLYMER
|
||||||
spritetype *s = &sprite[srcsprite];
|
spritetype *s = &sprite[srcsprite];
|
||||||
|
|
||||||
if (getrendermode() != REND_POLYMER)
|
if (getrendermode() != REND_POLYMER || pr_lighting != 1)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (actor[srcsprite].lightptr == NULL)
|
if (actor[srcsprite].lightptr == NULL)
|
||||||
|
@ -7949,6 +7949,9 @@ static void A_DoLight(int32_t i)
|
||||||
A_DeleteLight(i);
|
A_DeleteLight(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (pr_lighting != 1)
|
||||||
|
return;
|
||||||
|
|
||||||
for (ii=0; ii<2; ii++)
|
for (ii=0; ii<2; ii++)
|
||||||
{
|
{
|
||||||
if (sprite[i].picnum <= 0) // oob safety
|
if (sprite[i].picnum <= 0) // oob safety
|
||||||
|
@ -8260,6 +8263,27 @@ int32_t A_CheckSwitchTile(int32_t i)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void G_RefreshLights(void)
|
||||||
|
{
|
||||||
|
#ifdef POLYMER
|
||||||
|
if (getrendermode() == REND_POLYMER)
|
||||||
|
{
|
||||||
|
int32_t i, k = 0;
|
||||||
|
|
||||||
|
do
|
||||||
|
{
|
||||||
|
i = headspritestat[k++];
|
||||||
|
|
||||||
|
while (i >= 0)
|
||||||
|
{
|
||||||
|
A_DoLight(i);
|
||||||
|
i = nextspritestat[i];
|
||||||
|
}
|
||||||
|
} while (k < MAXSTATUS);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
void G_MoveWorld(void)
|
void G_MoveWorld(void)
|
||||||
{
|
{
|
||||||
extern double g_moveActorsTime;
|
extern double g_moveActorsTime;
|
||||||
|
@ -8346,24 +8370,7 @@ void G_MoveWorld(void)
|
||||||
} while (k < MAXSTATUS);
|
} while (k < MAXSTATUS);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef POLYMER
|
G_RefreshLights();
|
||||||
if (getrendermode() == REND_POLYMER)
|
|
||||||
{
|
|
||||||
int32_t i, k = 0;
|
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
i = headspritestat[k++];
|
|
||||||
|
|
||||||
while (i >= 0)
|
|
||||||
{
|
|
||||||
A_DoLight(i);
|
|
||||||
i = nextspritestat[i];
|
|
||||||
}
|
|
||||||
} while (k < MAXSTATUS);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
G_DoSectorAnimations();
|
G_DoSectorAnimations();
|
||||||
G_MoveFX(); //ST 11
|
G_MoveFX(); //ST 11
|
||||||
}
|
}
|
||||||
|
|
|
@ -314,6 +314,7 @@ void G_AddGameLight(int32_t radius,int32_t srcsprite,int32_t zoff
|
||||||
void G_ClearCameraView(DukePlayer_t *ps);
|
void G_ClearCameraView(DukePlayer_t *ps);
|
||||||
void G_DoInterpolations(int32_t smoothratio);
|
void G_DoInterpolations(int32_t smoothratio);
|
||||||
void G_MoveWorld(void);
|
void G_MoveWorld(void);
|
||||||
|
void G_RefreshLights(void);
|
||||||
int32_t G_SetInterpolation(int32_t * const posptr);
|
int32_t G_SetInterpolation(int32_t * const posptr);
|
||||||
void G_StopInterpolation(int32_t * const posptr);
|
void G_StopInterpolation(int32_t * const posptr);
|
||||||
|
|
||||||
|
|
|
@ -897,6 +897,12 @@ static MenuEntry_t ME_RENDERERSETUP_DETAILTEX = MAKE_MENUENTRY( "Detail textures
|
||||||
static MenuOption_t MEO_RENDERERSETUP_MODELS = MAKE_MENUOPTION( &MF_Bluefont, &MEOS_NoYes, &usemodels );
|
static MenuOption_t MEO_RENDERERSETUP_MODELS = MAKE_MENUOPTION( &MF_Bluefont, &MEOS_NoYes, &usemodels );
|
||||||
static MenuEntry_t ME_RENDERERSETUP_MODELS = MAKE_MENUENTRY( "Models:", &MF_BluefontRed, &MEF_SmallOptions, &MEO_RENDERERSETUP_MODELS, Option );
|
static MenuEntry_t ME_RENDERERSETUP_MODELS = MAKE_MENUENTRY( "Models:", &MF_BluefontRed, &MEF_SmallOptions, &MEO_RENDERERSETUP_MODELS, Option );
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef POLYMER
|
||||||
|
static char *MEOSN_RENDERERSETUP_LIGHTS [] ={ "Off", "Full", "Map only", };
|
||||||
|
static MenuOptionSet_t MEOS_RENDERERSETUP_LIGHTS = MAKE_MENUOPTIONSET(MEOSN_RENDERERSETUP_LIGHTS, NULL, 0x2);
|
||||||
|
static MenuOption_t MEO_RENDERERSETUP_LIGHTS = MAKE_MENUOPTION(&MF_Bluefont, &MEOS_RENDERERSETUP_LIGHTS, &pr_lighting);
|
||||||
|
static MenuEntry_t ME_RENDERERSETUP_LIGHTS = MAKE_MENUENTRY("Dynamic lights (Polymer)", &MF_BluefontRed, &MEF_SmallOptions, &MEO_RENDERERSETUP_LIGHTS, Option);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
static MenuEntry_t *MEL_RENDERERSETUP[] = {
|
static MenuEntry_t *MEL_RENDERERSETUP[] = {
|
||||||
|
@ -909,6 +915,10 @@ static MenuEntry_t *MEL_RENDERERSETUP[] = {
|
||||||
#endif
|
#endif
|
||||||
&ME_Space4,
|
&ME_Space4,
|
||||||
&ME_RENDERERSETUP_MODELS,
|
&ME_RENDERERSETUP_MODELS,
|
||||||
|
#ifdef POLYMER
|
||||||
|
&ME_Space4,
|
||||||
|
&ME_RENDERERSETUP_LIGHTS,
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -1617,6 +1627,9 @@ static void M_PreMenu(MenuID_t cm)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MENU_RENDERERSETUP:
|
case MENU_RENDERERSETUP:
|
||||||
|
#ifdef POLYMER
|
||||||
|
MenuEntry_DisableOnCondition(&ME_RENDERERSETUP_LIGHTS, getrendermode() != REND_POLYMER);
|
||||||
|
#endif
|
||||||
MenuEntry_DisableOnCondition(&ME_RENDERERSETUP_TEXQUALITY, !usehightile);
|
MenuEntry_DisableOnCondition(&ME_RENDERERSETUP_TEXQUALITY, !usehightile);
|
||||||
MenuEntry_DisableOnCondition(&ME_RENDERERSETUP_PRECACHE, !usehightile);
|
MenuEntry_DisableOnCondition(&ME_RENDERERSETUP_PRECACHE, !usehightile);
|
||||||
#ifndef EDUKE32_GLES
|
#ifndef EDUKE32_GLES
|
||||||
|
@ -2794,6 +2807,8 @@ static int32_t M_MenuEntryOptionModify(MenuEntry_t *entry, int32_t newOption)
|
||||||
|
|
||||||
static void M_MenuEntryOptionDidModify(MenuEntry_t *entry)
|
static void M_MenuEntryOptionDidModify(MenuEntry_t *entry)
|
||||||
{
|
{
|
||||||
|
int domodechange = 0;
|
||||||
|
|
||||||
if (entry == &ME_GAMESETUP_AIM_AUTO ||
|
if (entry == &ME_GAMESETUP_AIM_AUTO ||
|
||||||
entry == &ME_GAMESETUP_WEAPSWITCH_PICKUP ||
|
entry == &ME_GAMESETUP_WEAPSWITCH_PICKUP ||
|
||||||
entry == &ME_PLAYER_NAME ||
|
entry == &ME_PLAYER_NAME ||
|
||||||
|
@ -2806,10 +2821,21 @@ static void M_MenuEntryOptionDidModify(MenuEntry_t *entry)
|
||||||
else if (entry == &ME_RENDERERSETUP_TEXQUALITY)
|
else if (entry == &ME_RENDERERSETUP_TEXQUALITY)
|
||||||
{
|
{
|
||||||
texcache_invalidate();
|
texcache_invalidate();
|
||||||
resetvideomode();
|
|
||||||
if (setgamemode(fullscreen,xdim,ydim,bpp))
|
|
||||||
OSD_Printf("restartvid: Reset failed...\n");
|
|
||||||
r_downsizevar = r_downsize;
|
r_downsizevar = r_downsize;
|
||||||
|
domodechange = 1;
|
||||||
|
}
|
||||||
|
#ifdef POLYMER
|
||||||
|
else if (entry == &ME_RENDERERSETUP_LIGHTS)
|
||||||
|
domodechange = 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (domodechange)
|
||||||
|
{
|
||||||
|
resetvideomode();
|
||||||
|
if (setgamemode(fullscreen, xdim, ydim, bpp))
|
||||||
|
OSD_Printf("restartvid: Reset failed...\n");
|
||||||
|
onvideomodechange(ud.config.ScreenBPP>8);
|
||||||
|
G_RefreshLights();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue