From: FruitieX Date: Mon, 15 Nov 2010 21:15:22 +0000 (+0200) Subject: Freeze Tag. It compiles. Untested. (don't test :P) X-Git-Tag: xonotic-v0.1.0preview~86^2~2^2~41 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=7cefe54a276434a171b36fb3bf0d6175ebec78c4;p=xonotic%2Fxonotic-data.pk3dir.git Freeze Tag. It compiles. Untested. (don't test :P) --- diff --git a/models/ice/ice.md3 b/models/ice/ice.md3 new file mode 100644 index 0000000000..fc5cad6a27 Binary files /dev/null and b/models/ice/ice.md3 differ diff --git a/models/ice/ice.tga b/models/ice/ice.tga new file mode 100644 index 0000000000..87e95b3139 Binary files /dev/null and b/models/ice/ice.tga differ diff --git a/models/ice/ice_gloss.tga b/models/ice/ice_gloss.tga new file mode 100644 index 0000000000..9841865240 Binary files /dev/null and b/models/ice/ice_gloss.tga differ diff --git a/models/ice/ice_glow.tga b/models/ice/ice_glow.tga new file mode 100644 index 0000000000..7e4c972d2c Binary files /dev/null and b/models/ice/ice_glow.tga differ diff --git a/models/ice/ice_norm.tga b/models/ice/ice_norm.tga new file mode 100644 index 0000000000..051af6631a Binary files /dev/null and b/models/ice/ice_norm.tga differ diff --git a/models/ice/ice_reflect.tga b/models/ice/ice_reflect.tga new file mode 100644 index 0000000000..1f82c2a611 Binary files /dev/null and b/models/ice/ice_reflect.tga differ diff --git a/models/ice/iceshard.md3 b/models/ice/iceshard.md3 new file mode 100644 index 0000000000..82728cb8a4 Binary files /dev/null and b/models/ice/iceshard.md3 differ diff --git a/qcsrc/common/constants.qh b/qcsrc/common/constants.qh index 4acf797b7d..f3150439a8 100644 --- a/qcsrc/common/constants.qh +++ b/qcsrc/common/constants.qh @@ -39,6 +39,7 @@ const float GAME_RACE = 11; const float GAME_NEXBALL = 12; const float GAME_CTS = 13; const float GAME_CA = 14; +const float GAME_FREEZETAG = 15; const float AS_STRING = 1; const float AS_INT = 2; diff --git a/qcsrc/server/arena.qc b/qcsrc/server/arena.qc index 046743151d..b80a2830cd 100644 --- a/qcsrc/server/arena.qc +++ b/qcsrc/server/arena.qc @@ -262,8 +262,8 @@ void Arena_Warmup() float next_round; float stopalivecheck; -float redalive, bluealive; -.float redalive_stat, bluealive_stat; +float redalive, bluealive, yellowalive, pinkalive; +.float redalive_stat, bluealive_stat, yellowalive_stat, pinkalive_stat; /** * This function finds out whether an arena round is over 1 player is left. * It determines the last player who's still alive and saves it's entity reference @@ -289,6 +289,22 @@ void Spawnqueue_Check() self.bluealive_stat = bluealive; } } + else if(g_freezetag) + { + redalive = 0; bluealive = 0; + FOR_EACH_PLAYER(self) { + if (self.team == COLOR_TEAM1 && self.freezetag_frozen == 0 && self.health >= 1) redalive += 1; + else if (self.team == COLOR_TEAM2 && self.freezetag_frozen == 0 && self.health >= 1) bluealive += 1; + else if (self.team == COLOR_TEAM3 && self.freezetag_frozen == 0 && self.health >= 1) yellowalive += 1; + else if (self.team == COLOR_TEAM4 && self.freezetag_frozen == 0 && self.health >= 1) pinkalive += 1; + } + FOR_EACH_PLAYER(self) { + self.redalive_stat = redalive; + self.bluealive_stat = bluealive; + self.yellowalive_stat = yellowalive; + self.pinkalive_stat = pinkalive; + } + } if(time < warmup + 1 || inWarmupStage) return; diff --git a/qcsrc/server/defs.qh b/qcsrc/server/defs.qh index d369298a56..31f103e30c 100644 --- a/qcsrc/server/defs.qh +++ b/qcsrc/server/defs.qh @@ -17,7 +17,7 @@ float require_spawnfunc_prefix; // if this float exists, only functions with spa float ctf_score_value(string parameter); -float g_dm, g_domination, g_ctf, g_tdm, g_keyhunt, g_onslaught, g_assault, g_arena, g_ca, g_lms, g_runematch, g_race, g_nexball, g_cts; +float g_dm, g_domination, g_ctf, g_tdm, g_keyhunt, g_onslaught, g_assault, g_arena, g_ca, g_lms, g_runematch, g_race, g_nexball, g_cts, g_freezetag; float g_cloaked, g_footsteps, g_jump_grunt, g_grappling_hook, g_midair, g_minstagib, g_pinata, g_norecoil, g_minstagib_invis_alpha, g_bloodloss; float g_warmup_limit; float g_warmup_allguns; @@ -661,3 +661,6 @@ float allowed_to_spawn; // boolean variable used by the clan arena code to deter float serverflags; .float team_forced; // can be a team number to force a team, or 0 for default action, or -1 for forced spectator + +.float freezetag_frozen; +.float freezetag_beginrevive_time; diff --git a/qcsrc/server/mutators/mutators.qh b/qcsrc/server/mutators/mutators.qh index 542014e869..a57db07fd2 100644 --- a/qcsrc/server/mutators/mutators.qh +++ b/qcsrc/server/mutators/mutators.qh @@ -1,4 +1,5 @@ MUTATOR_DECLARATION(gamemode_keyhunt); +MUTATOR_DECLARATION(gamemode_freezetag); MUTATOR_DECLARATION(mutator_nix); MUTATOR_DECLARATION(mutator_dodging); diff --git a/qcsrc/server/progs.src b/qcsrc/server/progs.src index c2718d4e86..b9d7fc1d65 100644 --- a/qcsrc/server/progs.src +++ b/qcsrc/server/progs.src @@ -177,6 +177,7 @@ cheats.qc mutators/base.qc mutators/gamemode_keyhunt.qc +mutators/gamemode_freezetag.qc mutators/mutator_nix.qc mutators/mutator_dodging.qc mutators/mutator_rocketflying.qc diff --git a/qcsrc/server/teamplay.qc b/qcsrc/server/teamplay.qc index b9064c783b..78891a29d2 100644 --- a/qcsrc/server/teamplay.qc +++ b/qcsrc/server/teamplay.qc @@ -317,6 +317,16 @@ void InitGameplayMode() MUTATOR_ADD(gamemode_keyhunt); } + if(g_freezetag) + { + game = GAME_FREEZETAG; + gamemode_name = "Freeze Tag"; + ActivateTeamplay(); + fraglimit_override = cvar("g_freezetag_point_limit"); + leadlimit_override = cvar("g_freezetag_point_leadlimit"); + MUTATOR_ADD(gamemode_freezetag); + } + if(g_assault) { game = GAME_ASSAULT; diff --git a/scripts/ice.shader b/scripts/ice.shader new file mode 100644 index 0000000000..368dcb8680 --- /dev/null +++ b/scripts/ice.shader @@ -0,0 +1,11 @@ +models/ice/ice.tga +{ + cull none + dpnoshadow + dpreflectcube cubemaps/default/sky + { + map models/ice/ice.tga + blendfunc add + rgbgen vertex + } +} \ No newline at end of file