cvar_t r_draweffects = {0, "r_draweffects", "1"};
-cvar_t cl_explosions = {CVAR_SAVE, "cl_explosions", "1"};
cvar_t cl_explosions_alpha_start = {CVAR_SAVE, "cl_explosions_alpha_start", "1.5"};
cvar_t cl_explosions_alpha_end = {CVAR_SAVE, "cl_explosions_alpha_end", "0"};
cvar_t cl_explosions_size_start = {CVAR_SAVE, "cl_explosions_size_start", "16"};
// wipe the entire cl structure
memset (&cl, 0, sizeof(cl));
+ // reset the view zoom interpolation
+ cl.viewzoomold = cl.viewzoomnew = 1;
SZ_Clear (&cls.message);
// LordHavoc: have to set up the baseline info for alpha and other stuff
for (i = 0;i < cl_max_entities;i++)
{
- ClearStateToDefault(&cl_entities[i].state_baseline);
- ClearStateToDefault(&cl_entities[i].state_previous);
- ClearStateToDefault(&cl_entities[i].state_current);
+ cl_entities[i].state_baseline = defaultstate;
+ cl_entities[i].state_previous = defaultstate;
+ cl_entities[i].state_current = defaultstate;
}
CL_CGVM_Clear();
// make relative to the entity
matrix = &t->render.matrix;
// if a valid tagindex is used, make it relative to that tag instead
+ // FIXME: use a model function to get tag info (need to handle skeletal)
if (e->state_current.tagentity && e->state_current.tagindex >= 1 && (model = t->render.model) && e->state_current.tagindex <= t->render.model->alias.aliasnum_tags)
{
// blend the matrices
if (e->state_previous.active && e->state_previous.modelindex == e->state_current.modelindex)
{
if (e->render.flags & RENDER_GLOWTRAIL)
- CL_RocketTrail2(e->persistent.trail_origin, origin, e->state_current.glowcolor, e);
- else if (trailtype >= 0)
- CL_RocketTrail(e->persistent.trail_origin, origin, trailtype, e);
+ trailtype = 9;
+ if (trailtype >= 0)
+ CL_RocketTrail(e->persistent.trail_origin, origin, trailtype, e->state_current.glowcolor, e);
}
VectorCopy(origin, e->persistent.trail_origin);
// note: the cl.viewentity and intermission check is to hide player
ent = &cl.viewent;
ent->state_previous = ent->state_current;
- ClearStateToDefault(&ent->state_current);
+ ent->state_current = defaultstate;
ent->state_current.time = cl.time;
ent->state_current.number = -1;
ent->state_current.active = true;
// if coming from the player, update the start position
//if (b->entity == cl.viewentity)
// VectorCopy (cl_entities[cl.viewentity].render.origin, b->start);
- if (cl_beams_relative.integer && b->entity && cl_entities[b->entity].state_current.active && b->relativestartvalid)
+ if (cl_beams_relative.integer && b->entity == cl.viewentity && b->entity && cl_entities[b->entity].state_current.active && b->relativestartvalid)
{
entity_state_t *p = &cl_entities[b->entity].state_previous;
//entity_state_t *c = &cl_entities[b->entity].state_current;
CL_Init
=================
*/
+//VorteX: cvars for GAME_NETHERWORLD
+cvar_t cl_playermodel = {CVAR_SAVE, "cl_playermodel", "ranger"};
+cvar_t cl_footsteps = {CVAR_SAVE, "cl_footsteps", "1"};
+cvar_t cl_weapon_ofs = {CVAR_SAVE, "cl_weapon_ofs", "0 0 0"};
+cvar_t cl_weapon_bstep = {CVAR_SAVE, "cl_weapon_bstep", "100 0 0"};
+cvar_t cl_weapon_bborder = {CVAR_SAVE, "cl_weapon_bborder", "2 0 0"};
+cvar_t cl_weapon_bphase = {CVAR_SAVE, "cl_weapon_bphase", "0 0 0"};
+cvar_t cl_weapon_bphasescale = {CVAR_SAVE, "cl_weapon_bphasescale", "1 1 1"};
+cvar_t cl_weapon_bphasescissor = {CVAR_SAVE, "cl_weapon_bphasescissor", "-1 -1 -1 1 1 1"};
+cvar_t cl_deathcam = {CVAR_SAVE, "cl_deathcam", "0"};
+cvar_t cl_askonresave = {CVAR_SAVE, "cl_askonresave", "1"}; //Asking on saving to full saveslot in savegame menu
+cvar_t sv_corpses_solid = {CVAR_SAVE, "sv_corpses_solid", "1"};
+cvar_t sv_corpses_removetime = {CVAR_SAVE, "sv_corpses_removetime", "0"};
+cvar_t sv_monsters_healthscale = {CVAR_SAVE, "sv_monsters_healthscale", "1"};
+cvar_t sv_monsters_damagescale = {CVAR_SAVE, "sv_monsters_damagescale", "1"};
+cvar_t sv_monsters_multiply = {CVAR_SAVE, "sv_monsters_multiply", "1"};
+cvar_t sv_monsters_randomize = {CVAR_SAVE, "sv_monsters_randomize", "0"};
+cvar_t sv_monsters_multiply_radius = {CVAR_SAVE, "sv_monsters_multiply_radius", "5"};
+cvar_t sv_monsters_ai_skillmod = {CVAR_SAVE, "sv_monsters_ai_skillmod", "1"};
+cvar_t sv_monsters_ai_agrmod = {CVAR_SAVE, "sv_monsters_ai_agrmod", "1"};
+cvar_t sv_monsters_ai_dexmod = {CVAR_SAVE, "sv_monsters_ai_dexmod", "1"};
+cvar_t sv_monsters_deathmatch = {CVAR_SAVE, "sv_monsters_deathmatch", "0"};
+cvar_t sv_monsters_deathmatch_maxnum = {CVAR_SAVE, "sv_monsters_deathmatch_maxnum", "20"};
+cvar_t sv_monsters_deathmatch_spawntime = {CVAR_SAVE, "sv_monsters_deathmatch_spawntime", "5"};
+cvar_t sv_monsters_deathmatch_fragpermonster = {CVAR_SAVE, "sv_monsters_deathmatch_fragpermonster", "0"};
+
void CL_Init (void)
{
- cl_entities_mempool = Mem_AllocPool("client entities");
- cl_refdef_mempool = Mem_AllocPool("refdef");
+ cl_entities_mempool = Mem_AllocPool("client entities", 0, NULL);
+ cl_refdef_mempool = Mem_AllocPool("refdef", 0, NULL);
memset(&r_refdef, 0, sizeof(r_refdef));
// max entities sent to renderer per frame
Cmd_AddCommand ("pausedemo", CL_PauseDemo_f);
Cvar_RegisterVariable(&r_draweffects);
- Cvar_RegisterVariable(&cl_explosions);
Cvar_RegisterVariable(&cl_explosions_alpha_start);
Cvar_RegisterVariable(&cl_explosions_alpha_end);
Cvar_RegisterVariable(&cl_explosions_size_start);
Cvar_RegisterVariable(&cl_beams_lightatend);
Cvar_RegisterVariable(&cl_noplayershadow);
+ if (gamemode == GAME_NETHERWORLD)
+ {
+ Cvar_RegisterVariable (&cl_playermodel);
+ Cvar_RegisterVariable (&cl_footsteps);
+ Cvar_RegisterVariable (&cl_weapon_ofs);
+ Cvar_RegisterVariable (&cl_weapon_bstep);
+ Cvar_RegisterVariable (&cl_weapon_bborder);
+ Cvar_RegisterVariable (&cl_weapon_bphase);
+ Cvar_RegisterVariable (&cl_weapon_bphasescale);
+ Cvar_RegisterVariable (&cl_weapon_bphasescissor);
+ Cvar_RegisterVariable (&cl_deathcam); //Hack for q3-style death
+ Cvar_RegisterVariable (&cl_askonresave); //Every time ask if saving to "full" saveslot
+ //This must be server-side cvars, after complete finishing of subsystems whitch uses this, they must be moved to server-side
+ Cvar_RegisterVariable (&sv_monsters_healthscale);
+ Cvar_RegisterVariable (&sv_monsters_damagescale);
+ Cvar_RegisterVariable (&sv_monsters_randomize);
+ Cvar_RegisterVariable (&sv_monsters_multiply);
+ Cvar_RegisterVariable (&sv_monsters_multiply_radius);
+ Cvar_RegisterVariable (&sv_monsters_ai_skillmod);
+ Cvar_RegisterVariable (&sv_monsters_ai_agrmod);
+ Cvar_RegisterVariable (&sv_monsters_ai_dexmod);
+ Cvar_RegisterVariable (&sv_monsters_deathmatch); //Keeping RPG mod
+ Cvar_RegisterVariable (&sv_monsters_deathmatch_maxnum);
+ Cvar_RegisterVariable (&sv_monsters_deathmatch_spawntime);
+ Cvar_RegisterVariable (&sv_monsters_deathmatch_fragpermonster);
+ Cvar_RegisterVariable (&sv_corpses_solid);
+ }
+
CL_Parse_Init();
CL_Particles_Init();
CL_Screen_Init();
CL_Video_Init();
}
+
+