From 767df3e588d5d75bd56d82a61729054254f0ea63 Mon Sep 17 00:00:00 2001 From: terencehill Date: Sat, 21 May 2011 17:37:14 +0200 Subject: [PATCH] Allow to display more than one centerprint at once --- qcsrc/client/hud.qc | 105 +++++++++++++++++++++++++++++--------------- 1 file changed, 69 insertions(+), 36 deletions(-) diff --git a/qcsrc/client/hud.qc b/qcsrc/client/hud.qc index 025e91907e..d05894456e 100644 --- a/qcsrc/client/hud.qc +++ b/qcsrc/client/hud.qc @@ -142,10 +142,11 @@ float stringwidth_nocolors(string s, vector theSize) return stringwidth(s, FALSE, theSize); } -#define CENTERPRINT_MAX_LINES 30 +#define CENTERPRINT_MAX_LINES 10 +float cpm_index; string centerprint_messages[CENTERPRINT_MAX_LINES]; float centerprint_width[CENTERPRINT_MAX_LINES]; -float centerprint_time; +float centerprint_time[CENTERPRINT_MAX_LINES]; float centerprint_expire; float centerprint_num; float centerprint_offset_hint; @@ -185,10 +186,27 @@ void centerprint(string strMessage) if(strMessage == "") return; - // if we get here, we have a message. Initialize its height. - centerprint_num = 0; + for (i=0, j=cpm_index; i= CENTERPRINT_MAX_LINES) break; } } +#endif #if 0 float h, havail; @@ -278,50 +295,66 @@ void centerprint(string strMessage) #else #endif - centerprint_num = i; + // centerprint_num = i; centerprint_expire = time + autocvar_scr_centertime; } void HUD_DrawCenterPrint (void) { - float i; + float i, j, k, n; vector pos; string ts; - float a, sz; - - if(time - centerprint_time < 0.25) - a = (time - centerprint_time) / 0.25; - else - a = bound(0, 1 - 4 * (time - centerprint_expire), 1); - - if(a <= 0) - return; - - sz = 0.8 + (a / 5); + float a, sz, fade; - if(centerprint_num * autocvar_scr_centersize > 24 && scoreboard_active) // 24 = height of Scoreboard text - centerprint_start_y = scoreboard_bottom + centerprint_fontsize_y; + // if(centerprint_num * autocvar_scr_centersize > 24 && scoreboard_active) // 24 = height of Scoreboard text + // centerprint_start_y = scoreboard_bottom + centerprint_fontsize_y; pos = centerprint_start; - drawfontscale = sz * '1 1 0'; - for (i=0; i time) { - drawcolorcodedstring(pos + '0 1 0' * (1 - sz) * 0.5 *centerprint_fontsize_y, ts, centerprint_fontsize, a, DRAWFLAG_NORMAL); - pos_y = pos_y + centerprint_fontsize_y; + a = 1; + sz = 1; } - else - // half height for empty lines looks better - pos_y = pos_y + sz * centerprint_fontsize_y * 0.5; + else if (centerprint_time[j] + autocvar_scr_centertime > time) + { + a = (centerprint_time[j] + autocvar_scr_centertime - time) / fade; + sz = 0.8 + a * (1 - 0.8); + } + + drawfontscale = sz * '1 1 0'; + n = tokenizebyseparator(centerprint_messages[j], "\n"); + for(k = 0; k < n; ++k) + { + getWrappedLine_remaining = argv(k); + while(getWrappedLine_remaining) + { + ts = getWrappedLine(vid_conwidth * 0.75, centerprint_fontsize, stringwidth_colors); + if (cvar("debug")) + { + ts = strcat(ftos(i), " -", ts, "-"); + print(sprintf("^x8f0ts = %s\n", ts)); + } + pos_x = (vid_conwidth - stringwidth(ts, TRUE, centerprint_fontsize)) * 0.5; + if (ts != "") + { + drawcolorcodedstring(pos + '0 1 0' * (1 - sz) * 0.5 *centerprint_fontsize_y, ts, centerprint_fontsize, a, DRAWFLAG_NORMAL); + pos_y = pos_y + centerprint_fontsize_y; + } + else + // half height for empty lines looks better + pos_y = pos_y + sz * centerprint_fontsize_y * 0.5; + } + } + drawfontscale = '1 1 0'; } - drawfontscale = '1 1 0'; } void drawstringright(vector position, string text, vector scale, vector rgb, float alpha, float flag) -- 2.39.5