From bba0aeef62a2b740bb7fb7ad0118767b755e05c2 Mon Sep 17 00:00:00 2001 From: lordhavoc Date: Wed, 13 Mar 2002 12:23:18 +0000 Subject: [PATCH] fixed grenades to behave more like quake again (60 normal-dot-velocity tolerance for stopping), fixed continuous bounce sound (repeated touch when sitting on floor), you can now walk on SOLID_SLIDEBOX/SOLID_BBOX objects (like in Q2/Q3), if two objects are stacked and the bottom one moves out from under, the top one will fall (always wished quake would do that) git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@1637 d7cf8633-e32d-0410-b094-e92efae38249 --- sv_phys.c | 62 ++++++++++++++++++++++++++++++++----------------------- 1 file changed, 36 insertions(+), 26 deletions(-) diff --git a/sv_phys.c b/sv_phys.c index ff2b16c3..c7f3b270 100644 --- a/sv_phys.c +++ b/sv_phys.c @@ -161,10 +161,10 @@ Two entities have touched, so run their touch functions void SV_Impact (edict_t *e1, edict_t *e2) { int old_self, old_other; - + old_self = pr_global_struct->self; old_other = pr_global_struct->other; - + pr_global_struct->time = sv.time; if (e1->v.touch && e1->v.solid != SOLID_NOT) { @@ -200,7 +200,7 @@ int ClipVelocity (vec3_t in, vec3_t normal, vec3_t out, float overbounce) float backoff; float change; int i, blocked; - + blocked = 0; if (normal[2] > 0) blocked |= 1; // floor @@ -247,7 +247,7 @@ int SV_FlyMove (edict_t *ent, float time, trace_t *steptrace) trace_t trace; vec3_t end; float time_left; - int blocked; + int blocked, impact; numbumps = 4; @@ -287,10 +287,23 @@ int SV_FlyMove (edict_t *ent, float time, trace_t *steptrace) if (!trace.ent) Host_Error ("SV_FlyMove: !trace.ent"); + if ((int) ent->v.flags & FL_ONGROUND) + { + if (ent->v.groundentity == EDICT_TO_PROG(trace.ent)) + impact = false; + else + { + ent->v.flags = (int)ent->v.flags & ~FL_ONGROUND; + impact = true; + } + } + else + impact = true; + if (trace.plane.normal[2] > 0.7) { blocked |= 1; // floor - if (trace.ent->v.solid == SOLID_BSP) + //if (trace.ent->v.solid == SOLID_BSP) { ent->v.flags = (int)ent->v.flags | FL_ONGROUND; ent->v.groundentity = EDICT_TO_PROG(trace.ent); @@ -306,7 +319,8 @@ int SV_FlyMove (edict_t *ent, float time, trace_t *steptrace) // // run the impact function // - SV_Impact (ent, trace.ent); + if (impact) + SV_Impact (ent, trace.ent); if (ent->free) break; // removed by the impact function @@ -795,7 +809,7 @@ qboolean SV_CheckWater (edict_t *ent) point[0] = ent->v.origin[0]; point[1] = ent->v.origin[1]; - point[2] = ent->v.origin[2] + ent->v.mins[2] + 1; + point[2] = ent->v.origin[2] + ent->v.mins[2] + 1; ent->v.waterlevel = 0; ent->v.watertype = CONTENTS_EMPTY; @@ -866,7 +880,7 @@ int SV_TryUnstick (edict_t *ent, vec3_t oldvel) vec3_t dir; int clip; trace_t steptrace; - + VectorCopy (ent->v.origin, oldorg); VectorClear (dir); @@ -944,7 +958,7 @@ void SV_WalkMove (edict_t *ent) if (ent->v.movetype != MOVETYPE_WALK) return; // gibbed by a trigger - + if (sv_nostep.integer) return; @@ -983,7 +997,7 @@ void SV_WalkMove (edict_t *ent) clip = SV_TryUnstick (ent, oldvel); } } - + // extra friction based on view angle if ( clip & 2 ) SV_WallFriction (ent, &steptrace); @@ -1228,12 +1242,13 @@ void SV_Physics_Toss (edict_t *ent) trace_t trace; vec3_t move; float backoff; - edict_t *groundentity; + //edict_t *groundentity; // regular thinking if (!SV_RunThink (ent)) return; // if onground, return without moving + /* if ( ((int)ent->v.flags & FL_ONGROUND) ) { // LordHavoc: fall if the groundentity was removed @@ -1244,7 +1259,7 @@ void SV_Physics_Toss (edict_t *ent) return; } } - ent->v.flags = (int)ent->v.flags & ~FL_ONGROUND; + */ SV_CheckVelocity (ent); @@ -1260,10 +1275,10 @@ void SV_Physics_Toss (edict_t *ent) // move origin VectorScale (ent->v.velocity, sv.frametime, move); trace = SV_PushEntity (ent, move, vec3_origin); - if (trace.fraction == 1) - return; if (ent->free) return; + if (trace.fraction == 1) + return; if (ent->v.movetype == MOVETYPE_BOUNCE) backoff = 1.5; @@ -1279,19 +1294,14 @@ void SV_Physics_Toss (edict_t *ent) ent->v.flags = (int)ent->v.flags & ~FL_ONGROUND; else if (ent->v.movetype == MOVETYPE_BOUNCE) { - if (trace.plane.normal[2] > 0.7) + // LordHavoc: fixed grenades not bouncing when fired down a slope + if (trace.plane.normal[2] > 0.7 && DotProduct(trace.plane.normal, ent->v.velocity) < 60) + //if (trace.plane.normal[2] > 0.7 && ent->v.velocity[2] < 60) { - // LordHavoc: fixed grenades not bouncing when fired down a slope - if (DotProduct(trace.plane.normal, ent->v.velocity) < 100) - //if (ent->v.velocity[2] < 60) - { - ent->v.flags = (int)ent->v.flags | FL_ONGROUND; - ent->v.groundentity = EDICT_TO_PROG(trace.ent); - VectorClear (ent->v.velocity); - VectorClear (ent->v.avelocity); - } - else - ent->v.flags = (int)ent->v.flags & ~FL_ONGROUND; + ent->v.flags = (int)ent->v.flags | FL_ONGROUND; + ent->v.groundentity = EDICT_TO_PROG(trace.ent); + VectorClear (ent->v.velocity); + VectorClear (ent->v.avelocity); } else ent->v.flags = (int)ent->v.flags & ~FL_ONGROUND; -- 2.39.5