From: FruitieX Date: Tue, 16 Nov 2010 19:40:06 +0000 (+0200) Subject: add revive progress indicator to hud X-Git-Tag: xonotic-v0.1.0preview~86^2~2^2~22 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=c475a5d72330ca7f7c88124f0fc2973c087841cc;p=xonotic%2Fxonotic-data.pk3dir.git add revive progress indicator to hud --- diff --git a/defaultXonotic.cfg b/defaultXonotic.cfg index 583b5a3896..61f88009db 100644 --- a/defaultXonotic.cfg +++ b/defaultXonotic.cfg @@ -216,6 +216,7 @@ seta crosshair_fireball_color_blue 0.2 "crosshair color blue component to displa seta crosshair_fireball_alpha 1 "crosshair alpha value to display when wielding the fireball" seta crosshair_fireball_size 1 "crosshair size when wielding the fireball" seta crosshair_ring_size 2 "bullet counter ring size for Rifle, velocity ring for Nex" +seta crosshair_ring_alpha 0.2 "ring alpha" seta crosshair_campingrifle_bulletcounter_alpha 0.15 seta crosshair_nexvelocity_alpha 0.15 diff --git a/qcsrc/client/View.qc b/qcsrc/client/View.qc index b3bb787423..09061eb9c6 100644 --- a/qcsrc/client/View.qc +++ b/qcsrc/client/View.qc @@ -696,8 +696,15 @@ void CSQC_UpdateView(float w, float h) else { if(gametype == GAME_FREEZETAG) + { if(getstati(STAT_FROZEN)) drawfill('0 0 0', eX * vid_conwidth + eY * vid_conheight, '0.25 0.90 1', cvar_or("hud_colorflash_alpha", 0.5), DRAWFLAG_ADDITIVE); + if(getstatf(STAT_REVIVE_PROGRESS)) + { + DrawCircleClippedPic(eX * 0.5 * vid_conwidth + eY * 0.6 * vid_conheight, 0.1 * vid_conheight, "gfx/crosshair_ring.tga", getstatf(STAT_REVIVE_PROGRESS), '0.25 0.90 1', cvar("hud_colorflash_alpha"), DRAWFLAG_ADDITIVE); + drawstring_aspect(eY * 0.64 * vid_conheight, "Revival progress", eX * vid_conwidth + eY * 0.025 * vid_conheight, '1 1 1', 1, DRAWFLAG_NORMAL); + } + } if(cvar("r_letterbox") == 0) if(cvar("viewsize") < 120) diff --git a/qcsrc/common/constants.qh b/qcsrc/common/constants.qh index c072213f14..442f70c41c 100644 --- a/qcsrc/common/constants.qh +++ b/qcsrc/common/constants.qh @@ -347,6 +347,7 @@ const float STAT_PINKALIVE = 103; // freeze tag const float STAT_FROZEN = 104; +const float STAT_REVIVE_PROGRESS = 105; //const float STAT_SPIDERBOT_AIM 53 // compressShotOrigin //const float STAT_SPIDERBOT_TARGET 54 // compressShotOrigin diff --git a/qcsrc/server/defs.qh b/qcsrc/server/defs.qh index 31f103e30c..c5a20b3303 100644 --- a/qcsrc/server/defs.qh +++ b/qcsrc/server/defs.qh @@ -664,3 +664,4 @@ float serverflags; .float freezetag_frozen; .float freezetag_beginrevive_time; +.float freezetag_revive_progress; diff --git a/qcsrc/server/g_world.qc b/qcsrc/server/g_world.qc index 126a6e7759..9d6524a589 100644 --- a/qcsrc/server/g_world.qc +++ b/qcsrc/server/g_world.qc @@ -817,7 +817,10 @@ void spawnfunc_worldspawn (void) addstat(STAT_PINKALIVE, AS_INT, pinkalive_stat); } if(g_freezetag) + { addstat(STAT_FROZEN, AS_INT, freezetag_frozen); + addstat(STAT_REVIVE_PROGRESS, AS_FLOAT, freezetag_revive_progress); + } // g_movementspeed hack addstat(STAT_MOVEVARS_AIRSPEEDLIMIT_NONQW, AS_FLOAT, stat_sv_airspeedlimit_nonqw); diff --git a/qcsrc/server/mutators/gamemode_freezetag.qc b/qcsrc/server/mutators/gamemode_freezetag.qc index bcb7e3e256..3e5deb281f 100644 --- a/qcsrc/server/mutators/gamemode_freezetag.qc +++ b/qcsrc/server/mutators/gamemode_freezetag.qc @@ -179,9 +179,13 @@ MUTATOR_HOOKFUNCTION(freezetag_PlayerPreThink) if(self.freezetag_beginrevive_time == -9999) { self.freezetag_beginrevive_time = time; + self.freezetag_revive_progress = 0; + other.freezetag_revive_progress = 0; } else { + self.freezetag_revive_progress = (time - self.freezetag_beginrevive_time) / cvar("g_freezetag_revive_time"); + other.freezetag_revive_progress = (time - self.freezetag_beginrevive_time) / cvar("g_freezetag_revive_time"); if(time - self.freezetag_beginrevive_time >= cvar("g_freezetag_revive_time")) { freezetag_Unfreeze(); @@ -191,12 +195,16 @@ MUTATOR_HOOKFUNCTION(freezetag_PlayerPreThink) bprint("^7", other.netname, "^5 revived ^7", self.netname, ".\n"); self.freezetag_beginrevive_time = -9999; + self.freezetag_revive_progress = 0; + other.freezetag_revive_progress = 0; } } } else { self.freezetag_beginrevive_time = -9999; + self.freezetag_revive_progress = 0; + other.freezetag_revive_progress = 0; } return 1;