mirror of
https://git.code.sf.net/p/quake/quakeforge
synced 2025-01-18 23:11:38 +00:00
reduce gl_rmain's dependency on cl*.h
This commit is contained in:
parent
1aef81e9ef
commit
ece576ed4b
9 changed files with 51 additions and 32 deletions
|
@ -172,7 +172,9 @@ extern int reinit_surfcache; // if 1, surface cache is currently empty
|
||||||
extern qboolean r_cache_thrash; // set if thrashing the surface cache
|
extern qboolean r_cache_thrash; // set if thrashing the surface cache
|
||||||
extern qboolean r_inhibit_viewmodel;
|
extern qboolean r_inhibit_viewmodel;
|
||||||
extern qboolean r_force_fullscreen;
|
extern qboolean r_force_fullscreen;
|
||||||
|
extern qboolean r_paused;
|
||||||
extern entity_t *r_view_model;
|
extern entity_t *r_view_model;
|
||||||
|
extern entity_t *r_player_entity;
|
||||||
|
|
||||||
void *D_SurfaceCacheAddress (void);
|
void *D_SurfaceCacheAddress (void);
|
||||||
int D_SurfaceCacheForRes (int width, int height);
|
int D_SurfaceCacheForRes (int width, int height);
|
||||||
|
|
|
@ -505,6 +505,8 @@ CL_RelinkEntities (void)
|
||||||
vec3_t delta;
|
vec3_t delta;
|
||||||
float bobjrotate;
|
float bobjrotate;
|
||||||
dlight_t *dl;
|
dlight_t *dl;
|
||||||
|
|
||||||
|
r_player_entity = &cl_entities[cl.viewentity];
|
||||||
|
|
||||||
// determine partial update time
|
// determine partial update time
|
||||||
frac = CL_LerpPoint ();
|
frac = CL_LerpPoint ();
|
||||||
|
@ -650,8 +652,9 @@ CL_RelinkEntities (void)
|
||||||
|
|
||||||
ent->forcelink = false;
|
ent->forcelink = false;
|
||||||
|
|
||||||
if (i == cl.viewentity && !chase_active->int_val)
|
if (i == cl.viewentity && !chase_active->int_val) {
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
#ifdef QUAKE2
|
#ifdef QUAKE2
|
||||||
if (ent->effects & EF_NODRAW)
|
if (ent->effects & EF_NODRAW)
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -45,12 +45,12 @@
|
||||||
#include "QF/locs.h"
|
#include "QF/locs.h"
|
||||||
#include "QF/mathlib.h"
|
#include "QF/mathlib.h"
|
||||||
#include "QF/qargs.h"
|
#include "QF/qargs.h"
|
||||||
|
#include "QF/render.h"
|
||||||
#include "QF/skin.h"
|
#include "QF/skin.h"
|
||||||
#include "QF/sound.h"
|
#include "QF/sound.h"
|
||||||
#include "QF/sys.h"
|
#include "QF/sys.h"
|
||||||
#include "QF/vid.h"
|
#include "QF/vid.h"
|
||||||
|
|
||||||
#include "chase.h"
|
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
#include "glquake.h"
|
#include "glquake.h"
|
||||||
#include "r_cvar.h"
|
#include "r_cvar.h"
|
||||||
|
@ -585,7 +585,7 @@ R_SetupAliasBlendedFrame (int frame, aliashdr_t *paliashdr, entity_t *e, qboolea
|
||||||
}
|
}
|
||||||
|
|
||||||
// wierd things start happening if blend passes 1
|
// wierd things start happening if blend passes 1
|
||||||
if (cl.paused || blend > 1)
|
if (r_paused || blend > 1)
|
||||||
blend = 1;
|
blend = 1;
|
||||||
|
|
||||||
GL_DrawAliasBlendedFrame (paliashdr, e->pose1, e->pose2, blend, fb);
|
GL_DrawAliasBlendedFrame (paliashdr, e->pose1, e->pose2, blend, fb);
|
||||||
|
@ -635,7 +635,7 @@ R_DrawAliasModel (entity_t *e)
|
||||||
shadelight = R_LightPoint (currententity->origin);
|
shadelight = R_LightPoint (currententity->origin);
|
||||||
|
|
||||||
// always give the gun some light
|
// always give the gun some light
|
||||||
if (e == &cl.viewent)
|
if (e == r_view_model)
|
||||||
shadelight = max (shadelight, 24);
|
shadelight = max (shadelight, 24);
|
||||||
|
|
||||||
for (lnum = 0; lnum < MAX_DLIGHTS; lnum++) {
|
for (lnum = 0; lnum < MAX_DLIGHTS; lnum++) {
|
||||||
|
@ -832,7 +832,7 @@ R_DrawEntitiesOnList (void)
|
||||||
currententity = r_visedicts[i];
|
currententity = r_visedicts[i];
|
||||||
modelalpha = currententity->alpha;
|
modelalpha = currententity->alpha;
|
||||||
|
|
||||||
if (currententity == &cl_entities[cl.viewentity])
|
if (currententity == r_player_entity)
|
||||||
currententity->angles[PITCH] *= 0.3;
|
currententity->angles[PITCH] *= 0.3;
|
||||||
|
|
||||||
R_DrawAliasModel (currententity);
|
R_DrawAliasModel (currententity);
|
||||||
|
@ -852,12 +852,12 @@ R_DrawEntitiesOnList (void)
|
||||||
static void
|
static void
|
||||||
R_DrawViewModel (void)
|
R_DrawViewModel (void)
|
||||||
{
|
{
|
||||||
currententity = &cl.viewent;
|
currententity = r_view_model;
|
||||||
if (!r_drawviewmodel->int_val || chase_active->int_val
|
if (r_inhibit_viewmodel
|
||||||
|
|| !r_drawviewmodel->int_val
|
||||||
|| envmap
|
|| envmap
|
||||||
|| !r_drawentities->int_val
|
|| !r_drawentities->int_val
|
||||||
|| (cl.stats[STAT_ITEMS] & IT_INVISIBILITY)
|
|| !currententity->model)
|
||||||
|| cl.stats[STAT_HEALTH] <= 0 || !currententity->model)
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// this is a HACK! --KB
|
// this is a HACK! --KB
|
||||||
|
@ -1103,7 +1103,7 @@ R_Mirror (void)
|
||||||
|
|
||||||
ent = R_NewEntity();
|
ent = R_NewEntity();
|
||||||
if (ent)
|
if (ent)
|
||||||
*ent = &cl_entities[cl.viewentity];
|
*ent = r_player_entity;
|
||||||
|
|
||||||
gldepthmin = 0.5;
|
gldepthmin = 0.5;
|
||||||
gldepthmax = 1;
|
gldepthmax = 1;
|
||||||
|
|
|
@ -709,6 +709,7 @@ _Host_Frame (float time)
|
||||||
|| (cl.stats[STAT_ITEMS] & IT_INVISIBILITY)
|
|| (cl.stats[STAT_ITEMS] & IT_INVISIBILITY)
|
||||||
|| cl.stats[STAT_HEALTH] <= 0);
|
|| cl.stats[STAT_HEALTH] <= 0);
|
||||||
r_force_fullscreen = cl.intermission;
|
r_force_fullscreen = cl.intermission;
|
||||||
|
r_paused = cl.paused;
|
||||||
r_view_model = &cl.viewent;
|
r_view_model = &cl.viewent;
|
||||||
|
|
||||||
SCR_UpdateScreen (cl.time);
|
SCR_UpdateScreen (cl.time);
|
||||||
|
|
|
@ -5,9 +5,11 @@
|
||||||
|
|
||||||
qboolean r_inhibit_viewmodel;
|
qboolean r_inhibit_viewmodel;
|
||||||
qboolean r_force_fullscreen;
|
qboolean r_force_fullscreen;
|
||||||
|
qboolean r_paused;
|
||||||
double r_realtime;
|
double r_realtime;
|
||||||
dlight_t r_dlights[MAX_DLIGHTS];
|
dlight_t r_dlights[MAX_DLIGHTS];
|
||||||
entity_t *r_view_model;
|
entity_t *r_view_model;
|
||||||
|
entity_t *r_player_entity;
|
||||||
|
|
||||||
dlight_t *
|
dlight_t *
|
||||||
R_AllocDlight (int key)
|
R_AllocDlight (int key)
|
||||||
|
|
|
@ -36,16 +36,18 @@
|
||||||
# include <strings.h>
|
# include <strings.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include "QF/compat.h"
|
||||||
|
#include "QF/console.h"
|
||||||
|
#include "QF/msg.h"
|
||||||
|
#include "QF/render.h"
|
||||||
|
|
||||||
#include "cl_cam.h"
|
#include "cl_cam.h"
|
||||||
#include "cl_ents.h"
|
#include "cl_ents.h"
|
||||||
#include "cl_main.h"
|
#include "cl_main.h"
|
||||||
#include "cl_pred.h"
|
#include "cl_pred.h"
|
||||||
#include "cl_tent.h"
|
#include "cl_tent.h"
|
||||||
#include "QF/compat.h"
|
|
||||||
#include "QF/console.h"
|
|
||||||
#include "d_iface.h"
|
#include "d_iface.h"
|
||||||
#include "host.h"
|
#include "host.h"
|
||||||
#include "QF/msg.h"
|
|
||||||
#include "msg_ucmd.h"
|
#include "msg_ucmd.h"
|
||||||
#include "pmove.h"
|
#include "pmove.h"
|
||||||
#include "r_dynamic.h"
|
#include "r_dynamic.h"
|
||||||
|
@ -794,8 +796,10 @@ CL_LinkPlayers (void)
|
||||||
CL_NewDlight (j, org, state->effects);
|
CL_NewDlight (j, org, state->effects);
|
||||||
|
|
||||||
// the player object never gets added
|
// the player object never gets added
|
||||||
if (j == cl.playernum)
|
if (j == cl.playernum) {
|
||||||
|
r_player_entity = &cl_player_ents[state - frame->playerstate];
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (!state->modelindex)
|
if (!state->modelindex)
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -96,6 +96,7 @@
|
||||||
#include "host.h"
|
#include "host.h"
|
||||||
#include "net.h"
|
#include "net.h"
|
||||||
#include "pmove.h"
|
#include "pmove.h"
|
||||||
|
#include "r_cvar.h"
|
||||||
#include "sbar.h"
|
#include "sbar.h"
|
||||||
#include "view.h"
|
#include "view.h"
|
||||||
|
|
||||||
|
@ -1484,8 +1485,13 @@ Host_Frame (float time)
|
||||||
|| (cl.stats[STAT_ITEMS] & IT_INVISIBILITY)
|
|| (cl.stats[STAT_ITEMS] & IT_INVISIBILITY)
|
||||||
|| cl.stats[STAT_HEALTH] <= 0);
|
|| cl.stats[STAT_HEALTH] <= 0);
|
||||||
r_force_fullscreen = cl.intermission;
|
r_force_fullscreen = cl.intermission;
|
||||||
|
r_paused = cl.paused;
|
||||||
r_view_model = &cl.viewent;
|
r_view_model = &cl.viewent;
|
||||||
|
|
||||||
|
// don't allow cheats in multiplayer
|
||||||
|
if (!atoi (Info_ValueForKey (cl.serverinfo, "watervis")))
|
||||||
|
Cvar_SetValue (r_wateralpha, 1);
|
||||||
|
|
||||||
SCR_UpdateScreen (realtime);
|
SCR_UpdateScreen (realtime);
|
||||||
|
|
||||||
if (host_speeds->int_val)
|
if (host_speeds->int_val)
|
||||||
|
|
|
@ -45,16 +45,14 @@
|
||||||
#include "QF/locs.h"
|
#include "QF/locs.h"
|
||||||
#include "QF/mathlib.h"
|
#include "QF/mathlib.h"
|
||||||
#include "QF/qargs.h"
|
#include "QF/qargs.h"
|
||||||
|
#include "QF/render.h"
|
||||||
#include "QF/skin.h"
|
#include "QF/skin.h"
|
||||||
#include "QF/sound.h"
|
#include "QF/sound.h"
|
||||||
#include "QF/sys.h"
|
#include "QF/sys.h"
|
||||||
#include "QF/vid.h"
|
#include "QF/vid.h"
|
||||||
|
|
||||||
#include "bothdefs.h"
|
#include "cl_parse.h"
|
||||||
#include "cl_cam.h"
|
#include "client.h"
|
||||||
#include "cl_main.h"
|
|
||||||
#include "cl_parse.h" //FIXME CL_NewTranslation
|
|
||||||
#include "cl_tent.h" // only for mirror support
|
|
||||||
#include "glquake.h"
|
#include "glquake.h"
|
||||||
#include "r_cvar.h"
|
#include "r_cvar.h"
|
||||||
#include "r_dynamic.h"
|
#include "r_dynamic.h"
|
||||||
|
@ -63,6 +61,8 @@
|
||||||
|
|
||||||
entity_t r_worldentity;
|
entity_t r_worldentity;
|
||||||
|
|
||||||
|
qboolean r_cache_thrash; // compatability
|
||||||
|
|
||||||
vec3_t modelorg, r_entorigin;
|
vec3_t modelorg, r_entorigin;
|
||||||
entity_t *currententity;
|
entity_t *currententity;
|
||||||
|
|
||||||
|
@ -586,7 +586,7 @@ R_SetupAliasBlendedFrame (int frame, aliashdr_t *paliashdr, entity_t *e, qboolea
|
||||||
}
|
}
|
||||||
|
|
||||||
// wierd things start happening if blend passes 1
|
// wierd things start happening if blend passes 1
|
||||||
if (cl.paused || blend > 1)
|
if (r_paused || blend > 1)
|
||||||
blend = 1;
|
blend = 1;
|
||||||
|
|
||||||
GL_DrawAliasBlendedFrame (paliashdr, e->pose1, e->pose2, blend, fb);
|
GL_DrawAliasBlendedFrame (paliashdr, e->pose1, e->pose2, blend, fb);
|
||||||
|
@ -636,7 +636,7 @@ R_DrawAliasModel (entity_t *e)
|
||||||
shadelight = R_LightPoint (currententity->origin);
|
shadelight = R_LightPoint (currententity->origin);
|
||||||
|
|
||||||
// always give the gun some light
|
// always give the gun some light
|
||||||
if (e == &cl.viewent)
|
if (e == r_view_model)
|
||||||
shadelight = max (shadelight, 24);
|
shadelight = max (shadelight, 24);
|
||||||
|
|
||||||
for (lnum = 0; lnum < MAX_DLIGHTS; lnum++) {
|
for (lnum = 0; lnum < MAX_DLIGHTS; lnum++) {
|
||||||
|
@ -846,6 +846,9 @@ R_DrawEntitiesOnList (void)
|
||||||
currententity = r_visedicts[i];
|
currententity = r_visedicts[i];
|
||||||
modelalpha = currententity->alpha;
|
modelalpha = currententity->alpha;
|
||||||
|
|
||||||
|
if (currententity == r_player_entity)
|
||||||
|
currententity->angles[PITCH] *= 0.3;
|
||||||
|
|
||||||
R_DrawAliasModel (currententity);
|
R_DrawAliasModel (currententity);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -863,12 +866,12 @@ R_DrawEntitiesOnList (void)
|
||||||
static void
|
static void
|
||||||
R_DrawViewModel (void)
|
R_DrawViewModel (void)
|
||||||
{
|
{
|
||||||
currententity = &cl.viewent;
|
currententity = r_view_model;
|
||||||
if (!r_drawviewmodel->int_val || !Cam_DrawViewModel ()
|
if (r_inhibit_viewmodel
|
||||||
|
|| !r_drawviewmodel->int_val
|
||||||
|| envmap
|
|| envmap
|
||||||
|| !r_drawentities->int_val
|
|| !r_drawentities->int_val
|
||||||
|| (cl.stats[STAT_ITEMS] & IT_INVISIBILITY)
|
|| !currententity->model)
|
||||||
|| cl.stats[STAT_HEALTH] <= 0 || !currententity->model)
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// this is a HACK! --KB
|
// this is a HACK! --KB
|
||||||
|
@ -937,10 +940,6 @@ R_SetFrustum (void)
|
||||||
void
|
void
|
||||||
R_SetupFrame (void)
|
R_SetupFrame (void)
|
||||||
{
|
{
|
||||||
// don't allow cheats in multiplayer
|
|
||||||
if (!atoi (Info_ValueForKey (cl.serverinfo, "watervis")))
|
|
||||||
Cvar_SetValue (r_wateralpha, 1);
|
|
||||||
|
|
||||||
R_AnimateLight ();
|
R_AnimateLight ();
|
||||||
|
|
||||||
r_framecount++;
|
r_framecount++;
|
||||||
|
@ -957,6 +956,8 @@ R_SetupFrame (void)
|
||||||
V_SetContentsColor (r_viewleaf->contents);
|
V_SetContentsColor (r_viewleaf->contents);
|
||||||
V_CalcBlend ();
|
V_CalcBlend ();
|
||||||
|
|
||||||
|
r_cache_thrash = false;
|
||||||
|
|
||||||
c_brush_polys = 0;
|
c_brush_polys = 0;
|
||||||
c_alias_polys = 0;
|
c_alias_polys = 0;
|
||||||
|
|
||||||
|
@ -1094,7 +1095,6 @@ void R_RenderBrushPoly (msurface_t *fa);
|
||||||
void
|
void
|
||||||
R_Mirror (void)
|
R_Mirror (void)
|
||||||
{
|
{
|
||||||
#if 0
|
|
||||||
float d;
|
float d;
|
||||||
msurface_t *s;
|
msurface_t *s;
|
||||||
entity_t **ent;
|
entity_t **ent;
|
||||||
|
@ -1117,7 +1117,7 @@ R_Mirror (void)
|
||||||
|
|
||||||
ent = R_NewEntity();
|
ent = R_NewEntity();
|
||||||
if (ent)
|
if (ent)
|
||||||
*ent = &cl_entities[cl.viewentity];
|
*ent = r_player_entity;
|
||||||
|
|
||||||
gldepthmin = 0.5;
|
gldepthmin = 0.5;
|
||||||
gldepthmax = 1;
|
gldepthmax = 1;
|
||||||
|
@ -1149,7 +1149,6 @@ R_Mirror (void)
|
||||||
R_RenderBrushPoly (s);
|
R_RenderBrushPoly (s);
|
||||||
r_worldentity.model->textures[mirrortexturenum]->texturechain = NULL;
|
r_worldentity.model->textures[mirrortexturenum]->texturechain = NULL;
|
||||||
glColor4f (1, 1, 1, 1);
|
glColor4f (1, 1, 1, 1);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -5,9 +5,11 @@
|
||||||
|
|
||||||
qboolean r_inhibit_viewmodel;
|
qboolean r_inhibit_viewmodel;
|
||||||
qboolean r_force_fullscreen;
|
qboolean r_force_fullscreen;
|
||||||
|
qboolean r_paused;
|
||||||
double r_realtime;
|
double r_realtime;
|
||||||
dlight_t r_dlights[MAX_DLIGHTS];
|
dlight_t r_dlights[MAX_DLIGHTS];
|
||||||
entity_t *r_view_model;
|
entity_t *r_view_model;
|
||||||
|
entity_t *r_player_entity;
|
||||||
|
|
||||||
dlight_t *
|
dlight_t *
|
||||||
R_AllocDlight (int key)
|
R_AllocDlight (int key)
|
||||||
|
|
Loading…
Reference in a new issue