From dfa374680055eb25dc28f3f0f89ebc327d40f66d Mon Sep 17 00:00:00 2001 From: havoc Date: Wed, 13 Jun 2007 23:29:13 +0000 Subject: [PATCH] added a score-distribution/place/score block left of the hud added a time remaining clock left of the hud (which shows time in level instead if no timelimit is active or if the server does not send it) git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@7410 d7cf8633-e32d-0410-b094-e92efae38249 --- quakedef.h | 2 ++ sbar.c | 102 +++++++++++++++++++++++++++++++++++++++++++++++++++-- sv_main.c | 2 ++ 3 files changed, 104 insertions(+), 2 deletions(-) diff --git a/quakedef.h b/quakedef.h index ade02aee..0033e47a 100644 --- a/quakedef.h +++ b/quakedef.h @@ -94,6 +94,8 @@ extern char engineversion[128]; //#define STAT_TIME 17 // FTE //#define STAT_VIEW2 20 // FTE #define STAT_VIEWZOOM 21 // DP +#define STAT_FRAGLIMIT 235 // DP +#define STAT_TIMELIMIT 236 // DP #define STAT_MOVEVARS_WALLFRICTION 237 // DP #define STAT_MOVEVARS_FRICTION 238 // DP #define STAT_MOVEVARS_WATERFRICTION 239 // DP diff --git a/sbar.c b/sbar.c index cae35591..baedcd1d 100644 --- a/sbar.c +++ b/sbar.c @@ -471,7 +471,13 @@ void Sbar_DrawXNum (int x, int y, int num, int digits, int lettersize, float r, char str[32], *ptr; int l, frame; - l = sprintf(str, "%i", num); + if (digits < 0) + { + digits = -digits; + l = sprintf(str, "%0*i", digits, num); + } + else + l = sprintf(str, "%i", num); ptr = str; if (l > digits) ptr += (l-digits); @@ -1112,6 +1118,7 @@ Sbar_Draw */ extern float v_dmg_time, v_dmg_roll, v_dmg_pitch; extern cvar_t v_kicktime; +void Sbar_Score (void); void Sbar_Draw (void) { cachepic_t *pic; @@ -1261,6 +1268,8 @@ void Sbar_Draw (void) if (sbar_x + 320 + 160 <= vid_conwidth.integer) Sbar_MiniDeathmatchOverlay (sbar_x + 320, sbar_y); + if (sbar_x > 0) + Sbar_Score(); } else if (sb_lines) { @@ -1344,6 +1353,9 @@ void Sbar_Draw (void) if (sbar_x + 600 + 160 <= vid_conwidth.integer) Sbar_MiniDeathmatchOverlay (sbar_x + 600, sbar_y); + + if (sbar_x > 0) + Sbar_Score(); } } else if (gamemode == GAME_ZYMOTIC) @@ -1528,6 +1540,8 @@ void Sbar_Draw (void) Sbar_MiniDeathmatchOverlay (0, 0); else Sbar_MiniDeathmatchOverlay (324, vid_conheight.integer - sb_lines); + if (sbar_x > 0) + Sbar_Score(); } } } @@ -1684,7 +1698,7 @@ void Sbar_DeathmatchOverlay (void) /* ================== -Sbar_DeathmatchOverlay +Sbar_MiniDeathmatchOverlay ================== */ @@ -1759,6 +1773,90 @@ void Sbar_MiniDeathmatchOverlay (int x, int y) } } +void Sbar_Score (void) +{ + int i, me, score, otherleader, place, distribution, minutes, seconds; + double timeleft; + + sbar_y = vid_conheight.value - (32+12); + me = cl.playerentity - 1; + if (me >= 0 && me < cl.maxclients) + { + // find leading score other than ourselves, to calculate distribution + // find our place in the scoreboard + score = cl.scores[me].frags; + for (i = 0, otherleader = -1, place = 1;i < cl.maxclients;i++) + { + if (cl.scores[i].name[0] && i != me) + { + if (otherleader == -1 || cl.scores[i].frags > cl.scores[otherleader].frags) + otherleader = i; + if (score < cl.scores[i].frags || (score == cl.scores[i].frags && i < me)) + place++; + } + } + distribution = otherleader >= 0 ? score - cl.scores[otherleader].frags : 0; + if (place == 1) + Sbar_DrawXNum(-3*12-24, -12, place, 3, 12, 0, 1, 1, 1, 0); + else if (place == 2) + Sbar_DrawXNum(-3*12-24, -12, place, 3, 12, 1, 1, 1, 1, 0); + else if (place == 3) + Sbar_DrawXNum(-3*12-24, -12, place, 3, 12, 1, 1, 0, 1, 0); + else + Sbar_DrawXNum(-3*12-24, -12, place, 3, 12, 1, 0, 0, 1, 0); + if (otherleader < 0) + Sbar_DrawXNum(-32*4-24, 0, score, 4, 32, 1, 1, 1, 1, 0); + else if (distribution >= 5) + { + Sbar_DrawXNum(-7*12-24, -12, distribution, 4, 12, 0, 1, 1, 1, 0); + Sbar_DrawXNum(-32*4-24, 0, score, 4, 32, 0, 1, 1, 1, 0); + } + else if (distribution >= 0) + { + Sbar_DrawXNum(-7*12-24, -12, distribution, 4, 12, 1, 1, 1, 1, 0); + Sbar_DrawXNum(-32*4-24, 0, score, 4, 32, 1, 1, 1, 1, 0); + } + else if (distribution >= -5) + { + Sbar_DrawXNum(-7*12-24, -12, distribution, 4, 12, 1, 1, 0, 1, 0); + Sbar_DrawXNum(-32*4-24, 0, score, 4, 32, 1, 1, 0, 1, 0); + } + else + { + Sbar_DrawXNum(-7*12-24, -12, distribution, 4, 12, 1, 0, 0, 1, 0); + Sbar_DrawXNum(-32*4-24, 0, score, 4, 32, 1, 0, 0, 1, 0); + } + } + + if (cl.statsf[STAT_TIMELIMIT]) + { + timeleft = max(0, cl.statsf[STAT_TIMELIMIT] * 60 - cl.time); + minutes = (int)floor(timeleft / 60); + seconds = (int)(floor(timeleft) - minutes * 60); + if (minutes >= 5) + { + Sbar_DrawXNum(-12*6-24, 32, minutes, 3, 12, 1, 1, 1, 1, 0); + Sbar_DrawXNum(-12*2-24, 32, seconds, -2, 12, 1, 1, 1, 1, 0); + } + else if (minutes >= 1) + { + Sbar_DrawXNum(-12*6-24, 32, minutes, 3, 12, 1, 1, 0, 1, 0); + Sbar_DrawXNum(-12*2-24, 32, seconds, -2, 12, 1, 1, 0, 1, 0); + } + else if ((int)(timeleft * 4) & 1) + Sbar_DrawXNum(-12*2-24, 32, seconds, -2, 12, 1, 1, 1, 1, 0); + else + Sbar_DrawXNum(-12*2-24, 32, seconds, -2, 12, 1, 0, 0, 1, 0); + } + else + { + minutes = (int)floor(cl.time / 60); + seconds = (int)(floor(cl.time) - minutes * 60); + Sbar_DrawXNum(-12*6-24, 32, minutes, 3, 12, 0, 1, 1, 1, 0); + Sbar_DrawXNum(-12*2-24, 32, seconds, -2, 12, 0, 1, 1, 1, 0); + } +} + /* ================== Sbar_IntermissionOverlay diff --git a/sv_main.c b/sv_main.c index 3d310728..c1a6feb2 100644 --- a/sv_main.c +++ b/sv_main.c @@ -1392,6 +1392,8 @@ void SV_WriteClientdataToMessage (client_t *client, prvm_edict_t *ent, sizebuf_t statsf[STAT_MOVEVARS_AIRACCEL_SIDEWAYS_FRICTION] = sv_airaccel_sideways_friction.value; statsf[STAT_MOVEVARS_FRICTION] = sv_friction.value; statsf[STAT_MOVEVARS_WATERFRICTION] = sv_waterfriction.value >= 0 ? sv_waterfriction.value : sv_friction.value; + statsf[STAT_FRAGLIMIT] = fraglimit.value; + statsf[STAT_TIMELIMIT] = timelimit.value; if (sv.protocol == PROTOCOL_QUAKE || sv.protocol == PROTOCOL_QUAKEDP || sv.protocol == PROTOCOL_NEHAHRAMOVIE || sv.protocol == PROTOCOL_DARKPLACES1 || sv.protocol == PROTOCOL_DARKPLACES2 || sv.protocol == PROTOCOL_DARKPLACES3 || sv.protocol == PROTOCOL_DARKPLACES4 || sv.protocol == PROTOCOL_DARKPLACES5) { -- 2.39.2