X-Git-Url: http://git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fcommon%2Fphysics%2Fplayer.qc;h=0ecfa180f45bc143e6d11c831bdbbc41bc0a7b60;hb=7223a5e197781dd6d780c2623ec9483dd407dcc0;hp=1fc9ccdf3cdbbc16cc0b92f074de9ead94600bc5;hpb=7f5ad47610dc8b5580cc96ae961a57cca96e6975;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/common/physics/player.qc b/qcsrc/common/physics/player.qc index 1fc9ccdf3..0ecfa180f 100644 --- a/qcsrc/common/physics/player.qc +++ b/qcsrc/common/physics/player.qc @@ -4,7 +4,7 @@ #ifdef SVQC -#include "../../server/miscfunctions.qh" +#include #include "../triggers/trigger/viewloc.qh" // client side physics @@ -107,7 +107,7 @@ void PM_ClientMovement_Unstick(entity this) #define X(unstick_offset) \ { \ vector neworigin = unstick_offset + this.origin; \ - tracebox(neworigin, PL_CROUCH_MIN, PL_CROUCH_MAX, neworigin, MOVE_NORMAL, this); \ + tracebox(neworigin, STAT(PL_CROUCH_MIN, NULL), STAT(PL_CROUCH_MAX, NULL), neworigin, MOVE_NORMAL, this); \ if (!trace_startsolid) \ { \ setorigin(this, neworigin); \ @@ -128,7 +128,17 @@ void PM_ClientMovement_UpdateStatus(entity this, bool ground) PM_ClientMovement_Unstick(this); // set crouched - if (PHYS_INPUT_BUTTON_CROUCH(this)) + bool do_crouch = PHYS_INPUT_BUTTON_CROUCH(this); + if(this.hook && !wasfreed(this.hook)) + do_crouch = false; + if(hud != HUD_NORMAL) + do_crouch = false; + if(STAT(FROZEN, this)) + do_crouch = false; + if((activeweapon == WEP_SHOCKWAVE || activeweapon == WEP_SHOTGUN) && viewmodel.animstate_startframe == viewmodel.anim_fire2_x && time < viewmodel.weapon_nextthink) + do_crouch = false; + + if (do_crouch) { // wants to crouch, this always works if (!IS_DUCKED(this)) SET_DUCKED(this); @@ -138,7 +148,7 @@ void PM_ClientMovement_UpdateStatus(entity this, bool ground) // wants to stand, if currently crouching we need to check for a low ceiling first if (IS_DUCKED(this)) { - tracebox(this.origin, PL_MIN, PL_MAX, this.origin, MOVE_NORMAL, this); + tracebox(this.origin, STAT(PL_MIN, NULL), STAT(PL_MAX, NULL), this.origin, MOVE_NORMAL, this); if (!trace_startsolid) UNSET_DUCKED(this); } } @@ -560,7 +570,7 @@ void CheckWaterJump(entity this) #ifdef SVQC PHYS_TELEPORT_TIME(this) = time + 2; // safety net #elif defined(CSQC) - pmove_waterjumptime = time + 2; + pmove_waterjumptime = 2; #endif } } @@ -690,7 +700,7 @@ void PM_check_nickspam(entity this) { // slight annoyance for nick change scripts this.movement = -1 * this.movement; - this.BUTTON_ATCK = this.BUTTON_JUMP = this.BUTTON_ATCK2 = this.BUTTON_ZOOM = this.BUTTON_CROUCH = this.BUTTON_HOOK = this.BUTTON_USE = 0; + PHYS_INPUT_BUTTON_ATCK(this) = PHYS_INPUT_BUTTON_JUMP(this) = PHYS_INPUT_BUTTON_ATCK2(this) = PHYS_INPUT_BUTTON_ZOOM(this) = PHYS_INPUT_BUTTON_CROUCH(this) = PHYS_INPUT_BUTTON_HOOK(this) = PHYS_INPUT_BUTTON_USE(this) = false; if (this.nickspamcount >= autocvar_g_nick_flood_penalty_red) // if you are persistent and the slight annoyance above does not stop you, I'll show you! { @@ -992,7 +1002,7 @@ void PM_jetpack(entity this, float maxspd_mod) // add the unused velocity as up component wishvel_z = 0; - // if (this.BUTTON_JUMP) + // if (PHYS_INPUT_BUTTON_JUMP(this)) wishvel_z = sqrt(max(0, 1 - wishvel * wishvel)); // it is now normalized, so... @@ -1247,8 +1257,10 @@ void PM_air(entity this, float buttons_prev, float maxspd_mod) if (PHYS_WARSOWBUNNY_TURNACCEL(this) && accelerating && this.movement.y == 0 && this.movement.x != 0) PM_AirAccelerate(this, wishdir, wishspeed2); - else - PM_Accelerate(this, wishdir, wishspeed, wishspeed0, airaccel, airaccelqw, PHYS_AIRACCEL_QW_STRETCHFACTOR(this), PHYS_AIRACCEL_SIDEWAYS_FRICTION(this) / maxairspd, PHYS_AIRSPEEDLIMIT_NONQW(this)); + else { + float sidefric = maxairspd ? (PHYS_AIRACCEL_SIDEWAYS_FRICTION(this) / maxairspd) : 0; + PM_Accelerate(this, wishdir, wishspeed, wishspeed0, airaccel, airaccelqw, PHYS_AIRACCEL_QW_STRETCHFACTOR(this), sidefric, PHYS_AIRSPEEDLIMIT_NONQW(this)); + } if (PHYS_AIRCONTROL(this)) CPM_PM_Aircontrol(this, wishdir, wishspeed2); @@ -1277,12 +1289,16 @@ bool IsFlying(entity this) return false; if(this.waterlevel >= WATERLEVEL_SWIMMING) return false; - //traceline(this.origin, this.origin - '0 0 48', MOVE_NORMAL, this); - //if(trace_fraction < 1) - //return false; + traceline(this.origin, this.origin - '0 0 48', MOVE_NORMAL, this); + if(trace_fraction < 1) + return false; return true; } +#ifdef CSQC +float autocvar_slowmo; +#endif + void PM_Main(entity this) { int buttons = PHYS_INPUT_BUTTON_MASK(this); @@ -1310,7 +1326,7 @@ void PM_Main(entity this) #ifdef SVQC - WarpZone_PlayerPhysics_FixVAngle(); + WarpZone_PlayerPhysics_FixVAngle(this); #endif float maxspeed_mod = 1; maxspeed_mod *= PHYS_HIGHSPEED(this); @@ -1319,8 +1335,11 @@ void PM_Main(entity this) Physics_UpdateStats(this, maxspeed_mod); if (this.PlayerPhysplug) - if (this.PlayerPhysplug()) + if (this.PlayerPhysplug(this)) return; +#elif defined(CSQC) + if(autocvar_slowmo != STAT(MOVEVARS_TIMESCALE)) + cvar_set("slowmo", ftos(STAT(MOVEVARS_TIMESCALE))); #endif #ifdef SVQC @@ -1349,7 +1368,7 @@ void PM_Main(entity this) { if (playerdemo_read(this)) return; - WITH(entity, self, this, bot_think()); + bot_think(this); } #endif @@ -1405,7 +1424,7 @@ void PM_Main(entity this) this.spectatorspeed = maxspeed_mod; if (this.impulse && this.impulse <= 19 || (this.impulse >= 200 && this.impulse <= 209) || (this.impulse >= 220 && this.impulse <= 229)) { - if (this.lastclassname != "player") + if (this.lastclassname != STR_PLAYER) { if (this.impulse == 10 || this.impulse == 15 || this.impulse == 18 || (this.impulse >= 200 && this.impulse <= 209)) this.spectatorspeed = bound(1, this.spectatorspeed + 0.5, 5); @@ -1446,7 +1465,7 @@ void PM_Main(entity this) } #endif - if(PHYS_DEAD(this)) + if(IS_DEAD(this)) { // handle water here vector midpoint = ((this.absmin + this.absmax) * 0.5); @@ -1472,8 +1491,10 @@ void PM_Main(entity this) PM_Footsteps(this); } +#ifdef SVQC if(IsFlying(this)) this.wasFlying = 1; +#endif if (IS_PLAYER(this)) CheckPlayerJump(this); @@ -1482,10 +1503,17 @@ void PM_Main(entity this) { this.velocity_x = this.movedir.x; this.velocity_y = this.movedir.y; - if (time > PHYS_TELEPORT_TIME(this) || this.waterlevel == WATERLEVEL_NONE) + if (time > PHYS_TELEPORT_TIME(this) || this.waterlevel == WATERLEVEL_NONE + #ifdef CSQC + || pmove_waterjumptime <= 0 + #endif + ) { this.flags &= ~FL_WATERJUMP; PHYS_TELEPORT_TIME(this) = 0; + #ifdef CSQC + pmove_waterjumptime = 0; + #endif } } @@ -1514,7 +1542,7 @@ void PM_Main(entity this) else PM_air(this, buttons_prev, maxspeed_mod); -:end +LABEL(end) if (IS_ONGROUND(this)) this.lastground = time;