shithub: qk1

Download patch

ref: ba66476bc4dad2003cd5b404ef13c84d882cf35a
parent: d6265371c542cc4f66ccd1559837ab8a8c3978a3
author: Sigrid Solveig Haflínudóttir <sigrid@ftrv.se>
date: Fri Nov 10 15:31:59 EST 2023

view: better stair-step smoothing (thanks mh)

--- a/cl_parse.c
+++ b/cl_parse.c
@@ -283,7 +283,8 @@
 	// local state
 	cl_entities[0].model = cl.worldmodel = cl.model_precache[1];
 
-	R_NewMap ();
+	R_NewMap();
+	V_NewMap();
 
 	noclip_anglehack = false;		// noclip is turned off at start
 }
--- a/view.c
+++ b/view.c
@@ -43,7 +43,8 @@
 
 static cvar_t gl_cshiftpercent = {"gl_cshiftpercent", "100", false};
 
-static float v_dmg_time, v_dmg_roll, v_dmg_pitch;
+static double v_dmg_time, v_dmg_roll, v_dmg_pitch;
+static double v_step_time, v_step_z, v_step_oldz;
 
 extern	int			in_forward, in_forward2, in_back;
 
@@ -701,7 +702,6 @@
 	vec3_t		forward, right, up;
 	vec3_t		angles;
 	float		bob;
-	static float oldz = 0;
 
 	V_DriftPitch ();
 
@@ -787,27 +787,34 @@
 	VectorAdd (r_refdef.viewangles, cl.punchangle, r_refdef.viewangles);
 
 	// smooth out stair step ups
-	if (cl.onground && ent->origin[2] - oldz > 0){
-		float steptime;
+	if(!noclip_anglehack && cl.onground && ent->origin[2] - v_step_z > 0){
+		v_step_z = v_step_oldz + (cl.time - v_step_time) * 80.0;
 
-		steptime = cl.time - cl.oldtime;
-		if (steptime < 0){
-			//FIXME I_Error ("steptime < 0");
-			steptime = 0;
+		if(v_step_z > ent->origin[2]){
+			v_step_z = v_step_oldz = ent->origin[2];
+			v_step_time = cl.time;
 		}
+		if(v_step_z < ent->origin[2]-12.0){
+			v_step_z = v_step_oldz = ent->origin[2] - 12.0;
+			v_step_time = cl.time;
+		}
 
-		oldz += steptime * 80;
-		if (oldz > ent->origin[2])
-			oldz = ent->origin[2];
-		if (ent->origin[2] - oldz > 12)
-			oldz = ent->origin[2] - 12;
-		r_refdef.vieworg[2] += oldz - ent->origin[2];
-		view->origin[2] += oldz - ent->origin[2];
-	}else
-		oldz = ent->origin[2];
+		r_refdef.vieworg[2] += v_step_z - ent->origin[2];
+		view->origin[2] += v_step_z - ent->origin[2];
+	}else{
+		v_step_z = v_step_oldz = ent->origin[2];
+		v_step_time = cl.time;
+	}
 
 	if (chase_active.value)
 		Chase_Update ();
+}
+
+void
+V_NewMap(void)
+{
+	v_step_z = v_step_oldz = 0.0;
+	v_step_time = 0.0;
 }
 
 /*
--- a/view.h
+++ b/view.h
@@ -5,9 +5,8 @@
 
 extern cvar_t lcd_x;
 
-
 void V_Init (void);
 void V_RenderView (void);
 float V_CalcRoll (vec3_t angles, vec3_t velocity);
 void V_UpdatePalette (void);
-
+void V_NewMap(void);