From: FruitieX Date: Tue, 16 Nov 2010 08:18:10 +0000 (+0200) Subject: YAY found a way to block player movement, but still allow him to be pushed around X-Git-Tag: xonotic-v0.1.0preview~86^2~2^2~32 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=7558eada9b5835073350eccca3f128d22ef67a43;p=xonotic%2Fxonotic-data.pk3dir.git YAY found a way to block player movement, but still allow him to be pushed around --- diff --git a/qcsrc/server/arena.qc b/qcsrc/server/arena.qc index 85d4b71912..dbd7e964b1 100644 --- a/qcsrc/server/arena.qc +++ b/qcsrc/server/arena.qc @@ -265,7 +265,7 @@ void Arena_Warmup() } } - if(self.classname == "player" && self.health > 0) + if(self.classname == "player" && self.health > 0 && self.movetype == MOVETYPE_NONE) self.movetype = MOVETYPE_WALK; } diff --git a/qcsrc/server/cl_physics.qc b/qcsrc/server/cl_physics.qc index e211275b0f..2492f764b4 100644 --- a/qcsrc/server/cl_physics.qc +++ b/qcsrc/server/cl_physics.qc @@ -46,6 +46,9 @@ When you press the jump key */ void PlayerJump (void) { + if(g_freezetag && self.freezetag_frozen) + return; // no jumping in freezetag when frozen + float mjumpheight; float doublejump; diff --git a/qcsrc/server/mutators/gamemode_freezetag.qc b/qcsrc/server/mutators/gamemode_freezetag.qc index 3939ef5b11..8d602a3de6 100644 --- a/qcsrc/server/mutators/gamemode_freezetag.qc +++ b/qcsrc/server/mutators/gamemode_freezetag.qc @@ -71,7 +71,7 @@ void freezetag_Freeze() //setattachment(ice, self, ""); - self.movetype = MOVETYPE_NONE; + //self.movetype = MOVETYPE_NONE; self.movement = '0 0 0'; } @@ -111,7 +111,7 @@ MUTATOR_HOOKFUNCTION(freezetag_PlayerDies) centerprint(frag_attacker, strcat("^2You froze ^7", frag_target.netname, ".\n")); if(frag_attacker == frag_target || frag_attacker == world) { - centerprint(frag_target, strcat("^1You froze yourself.\n")); + centerprint(frag_target, "^1You froze yourself.\n"); bprint("^7", frag_target.netname, "^1 froze himself.\n"); } else @@ -134,7 +134,7 @@ MUTATOR_HOOKFUNCTION(freezetag_PlayerSpawn) if(time > warmup) // spawn too late, freeze player { - centerprint(self, strcat("^1You spawned after the round started, you'll spawn as frozen.\n")); + centerprint(self, "^1You spawned after the round started, you'll spawn as frozen.\n"); freezetag_Freeze(); } else // we are still in the delay period before the round starts @@ -153,16 +153,6 @@ MUTATOR_HOOKFUNCTION(freezetag_GiveFragsForKill) MUTATOR_HOOKFUNCTION(freezetag_PlayerPreThink) { - if(self.freezetag_frozen) - { - // nasty hack, i want them to move around later on as i figure out a better way to block movement TODO TODO TODO !!! - self.velocity_x = 0; - self.velocity_y = 0; - self.velocity_z = min(self.velocity_z, 0); - self.movement = '0 0 0'; // don't move anywhere :-P - self.avelocity = '0 0 0'; - } - vector revive_extra_size; revive_extra_size = '1 1 1' * cvar("g_freezetag_revive_extra_size"); @@ -207,6 +197,13 @@ MUTATOR_HOOKFUNCTION(freezetag_PlayerPreThink) return 1; } +MUTATOR_HOOKFUNCTION(freezetag_PlayerPhysics) +{ + if(self.freezetag_frozen) + self.movement = '0 0 0'; + return 1; +} + MUTATOR_DEFINITION(gamemode_freezetag) { MUTATOR_HOOK(MakePlayerObserver, freezetag_RemovePlayer, CBC_ORDER_ANY); @@ -215,6 +212,7 @@ MUTATOR_DEFINITION(gamemode_freezetag) MUTATOR_HOOK(PlayerSpawn, freezetag_PlayerSpawn, CBC_ORDER_ANY); MUTATOR_HOOK(GiveFragsForKill, freezetag_GiveFragsForKill, CBC_ORDER_FIRST); MUTATOR_HOOK(PlayerPreThink, freezetag_PlayerPreThink, CBC_ORDER_FIRST); + MUTATOR_HOOK(PlayerPhysics, freezetag_PlayerPhysics, CBC_ORDER_FIRST); MUTATOR_ONADD {