add r_drawflat_nonworldmodel, defaults to 0

git-svn-id: https://svn.code.sf.net/p/fteqw/code/trunk@2315 fc73d0e0-1445-4013-8a0c-d673dee63da5
This commit is contained in:
TimeServ 2006-06-04 16:02:03 +00:00
parent f67a1e5ce4
commit 3866a4c292
10 changed files with 33 additions and 17 deletions

View File

@ -542,6 +542,7 @@ qboolean CL_CheckMD2Skins (char *name)
return false; return false;
} }
/* /*
================= =================
Model_NextDownload Model_NextDownload

View File

@ -364,7 +364,7 @@ qbyte *CIN_ReadNextFrame (void)
if (cin.s_width == 1) if (cin.s_width == 1)
COM_CharBias(samples, count*cin.s_channels); COM_CharBias(samples, count*cin.s_channels);
else if (cin.s_width == 2) else if (cin.s_width == 2)
COM_SwapLittleShortBlock(samples, count*cin.s_channels); COM_SwapLittleShortBlock((short *)samples, count*cin.s_channels);
S_RawAudio (0, samples, cin.s_rate, count, cin.s_channels, cin.s_width); S_RawAudio (0, samples, cin.s_rate, count, cin.s_channels, cin.s_width);

View File

@ -589,6 +589,7 @@ void CLQ3_ParseGameState(void)
if (!cl.worldmodel) if (!cl.worldmodel)
Host_EndGame("CGame didn't set a map.\n"); Host_EndGame("CGame didn't set a map.\n");
R_NewMap (); R_NewMap ();
SCR_EndLoadingPlaque(); SCR_EndLoadingPlaque();

View File

@ -221,6 +221,7 @@ extern cvar_t r_novis;
extern cvar_t r_netgraph; extern cvar_t r_netgraph;
cvar_t r_drawflat = SCVARF("r_drawflat","0", CVAR_SEMICHEAT|CVAR_RENDERERCALLBACK); cvar_t r_drawflat = SCVARF("r_drawflat","0", CVAR_SEMICHEAT|CVAR_RENDERERCALLBACK);
cvar_t r_drawflat_nonworldmodel = SCVAR("r_drawflat_nonworldmodel", "0");
cvar_t r_wallcolour = SCVARF("r_wallcolour","255 255 255", CVAR_RENDERERCALLBACK); cvar_t r_wallcolour = SCVARF("r_wallcolour","255 255 255", CVAR_RENDERERCALLBACK);
cvar_t r_floorcolour = SCVARF("r_floorcolour","255 255 255", CVAR_RENDERERCALLBACK); cvar_t r_floorcolour = SCVARF("r_floorcolour","255 255 255", CVAR_RENDERERCALLBACK);
cvar_t r_walltexture = SCVARF("r_walltexture","", CVAR_RENDERERCALLBACK); cvar_t r_walltexture = SCVARF("r_walltexture","", CVAR_RENDERERCALLBACK);
@ -433,7 +434,6 @@ void SWRenderer_Init(void)
} }
#endif #endif
void R_InitTextures (void) void R_InitTextures (void)
{ {
int x,y, m; int x,y, m;
@ -567,6 +567,7 @@ void Renderer_Init(void)
Cvar_Register (&r_wateralpha, GRAPHICALNICETIES); Cvar_Register (&r_wateralpha, GRAPHICALNICETIES);
Cvar_Register (&r_drawflat, GRAPHICALNICETIES); Cvar_Register (&r_drawflat, GRAPHICALNICETIES);
Cvar_Register (&r_drawflat_nonworldmodel, GRAPHICALNICETIES);
Cvar_Register (&r_menutint, GRAPHICALNICETIES); Cvar_Register (&r_menutint, GRAPHICALNICETIES);
Cvar_Register (&r_fb_models, GRAPHICALNICETIES); Cvar_Register (&r_fb_models, GRAPHICALNICETIES);

View File

@ -1622,7 +1622,7 @@ void S_RawAudio(int sourceid, qbyte *data, int speed, int samples, int channels,
// Con_Printf("Restarting raw stream\n"); // Con_Printf("Restarting raw stream\n");
} }
speedfactor = (float)speed/snd_speed; speedfactor = (double)speed/snd_speed;
outsamples = samples/speedfactor; outsamples = samples/speedfactor;
oldlength = s->sfxcache->length; oldlength = s->sfxcache->length;

View File

@ -173,16 +173,17 @@ typedef struct texture_s
unsigned offsets[MIPLEVELS]; // four mip maps stored unsigned offsets[MIPLEVELS]; // four mip maps stored
} texture_t; } texture_t;
#define SURF_DRAWSKYBOX 1 #define SURF_DRAWSKYBOX 0x00001
#define SURF_PLANEBACK 2 #define SURF_PLANEBACK 0x00002
#define SURF_DRAWSKY 4 #define SURF_DRAWSKY 0x00004
#define SURF_DRAWSPRITE 8 #define SURF_DRAWSPRITE 0x00008
#define SURF_DRAWTURB 0x10 #define SURF_DRAWTURB 0x00010
#define SURF_DRAWTILED 0x20 #define SURF_DRAWTILED 0x00020
#define SURF_DRAWBACKGROUND 0x40 #define SURF_DRAWBACKGROUND 0x00040
#define SURF_UNDERWATER 0x80 #define SURF_UNDERWATER 0x00080
#define SURF_DONTWARP 0x100 #define SURF_DONTWARP 0x00100
#define SURF_BULLETEN 0x200 #define SURF_BULLETEN 0x00200
#define SURF_NOFLAT 0x08000
#define SURF_DRAWALPHA 0x10000 #define SURF_DRAWALPHA 0x10000
// !!! if this is changed, it must be changed in asm_draw.h too !!! // !!! if this is changed, it must be changed in asm_draw.h too !!!

View File

@ -1515,7 +1515,7 @@ static void PPL_BaseTextureChain(msurface_t *first)
return; return;
} }
} }
else else if (!(first->flags & SURF_NOFLAT))
{ {
if (gl_mtexarbable >= 2 && simpletextures) if (gl_mtexarbable >= 2 && simpletextures)
PPL_BaseChain_SimpleTexture(first); PPL_BaseChain_SimpleTexture(first);
@ -1830,9 +1830,11 @@ void PPL_BaseTextures(model_t *model)
void PPL_BaseBModelTextures(entity_t *e) void PPL_BaseBModelTextures(entity_t *e)
{ {
extern cvar_t r_drawflat_nonworldmodel;
extern msurface_t *r_alpha_surfaces; extern msurface_t *r_alpha_surfaces;
int i, k; int i, k;
int shift; int shift;
int sflags;
model_t *model; model_t *model;
msurface_t *s; msurface_t *s;
msurface_t *chain = NULL; msurface_t *chain = NULL;
@ -1891,6 +1893,10 @@ void PPL_BaseBModelTextures(entity_t *e)
R_RenderDynamicLightmaps (s, shift); R_RenderDynamicLightmaps (s, shift);
} }
if (!r_drawflat_nonworldmodel.value && (!cl.worldmodel->submodels || model->submodels != cl.worldmodel->submodels))
sflags = SURF_NOFLAT;
else
sflags = 0;
for (s = model->surfaces+model->firstmodelsurface,i = 0; i < model->nummodelsurfaces; i++, s++) for (s = model->surfaces+model->firstmodelsurface,i = 0; i < model->nummodelsurfaces; i++, s++)
{ {
@ -1907,6 +1913,7 @@ void PPL_BaseBModelTextures(entity_t *e)
chain = NULL; chain = NULL;
} }
s->flags |= sflags;
s->texturechain = chain; s->texturechain = chain;
chain = s; chain = s;
} }

View File

@ -1099,7 +1099,6 @@ TRACE(("dbg: GLR_NewMap: ui\n"));
TRACE(("dbg: GLR_NewMap: tp\n")); TRACE(("dbg: GLR_NewMap: tp\n"));
TP_NewMap(); TP_NewMap();
if (r_shadows.value) if (r_shadows.value)
{ {
R_LoadRTLights(); R_LoadRTLights();

View File

@ -433,7 +433,7 @@ void R_DrawSubmodelPolygons (model_t *pmodel, int clipflags)
int i; int i;
vec_t dot; vec_t dot;
msurface_t *psurf; msurface_t *psurf;
int numsurfaces; int numsurfaces, sflags;
mplane_t *pplane; mplane_t *pplane;
// FIXME: use bounding-box-based frustum clipping info? // FIXME: use bounding-box-based frustum clipping info?
@ -441,6 +441,11 @@ void R_DrawSubmodelPolygons (model_t *pmodel, int clipflags)
psurf = &pmodel->surfaces[pmodel->firstmodelsurface]; psurf = &pmodel->surfaces[pmodel->firstmodelsurface];
numsurfaces = pmodel->nummodelsurfaces; numsurfaces = pmodel->nummodelsurfaces;
if (!cl.worldmodel->submodels || pmodel->submodels != cl.worldmodel->submodels)
sflags = SURF_NOFLAT;
else
sflags = 0;
for (i=0 ; i<numsurfaces ; i++, psurf++) for (i=0 ; i<numsurfaces ; i++, psurf++)
{ {
// find which side of the node we are on // find which side of the node we are on
@ -454,6 +459,7 @@ void R_DrawSubmodelPolygons (model_t *pmodel, int clipflags)
{ {
r_currentkey = ((mleaf_t *)currententity->topnode)->key; r_currentkey = ((mleaf_t *)currententity->topnode)->key;
psurf->flags |= sflags;
// FIXME: use bounding-box-based frustum clipping info? // FIXME: use bounding-box-based frustum clipping info?
R_RenderFace (psurf, clipflags); R_RenderFace (psurf, clipflags);
} }

View File

@ -1103,7 +1103,7 @@ void R_DrawSurface (void)
if (r_pixbytes == 1 || r_pixbytes == 4) //if we are using 4, textures are stored as 1 and expanded acording to palette if (r_pixbytes == 1 || r_pixbytes == 4) //if we are using 4, textures are stored as 1 and expanded acording to palette
{ {
if (r_drawflat.value) if (r_drawflat.value && !(r_drawsurf.surf->flags & SURF_NOFLAT))
{ {
if (r_drawsurf.surf->plane->normal[2] <= 0.5) if (r_drawsurf.surf->plane->normal[2] <= 0.5)
ptexcolor = r_wallindex; ptexcolor = r_wallindex;