From: Samual Date: Tue, 18 Oct 2011 23:13:55 +0000 (-0400) Subject: New cvars for the hud_panel_centerprint fading effects... now just needs configs... X-Git-Tag: xonotic-v0.6.0~35^2~78^2~7^2~32 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=3175c5d856967d7be2b9c4474fb386268ad94d81;p=xonotic%2Fxonotic-data.pk3dir.git New cvars for the hud_panel_centerprint fading effects... now just needs configs to be updated. --- diff --git a/qcsrc/client/autocvars.qh b/qcsrc/client/autocvars.qh index 7259761c2..20e8399da 100644 --- a/qcsrc/client/autocvars.qh +++ b/qcsrc/client/autocvars.qh @@ -202,6 +202,27 @@ float autocvar_hud_panel_bg_border; vector autocvar_hud_panel_bg_color; float autocvar_hud_panel_bg_color_team; float autocvar_hud_panel_bg_padding; +float autocvar_hud_panel_centerprint; +string autocvar_hud_panel_centerprint_pos; +string autocvar_hud_panel_centerprint_size; +string autocvar_hud_panel_centerprint_bg; +string autocvar_hud_panel_centerprint_bg_color; +string autocvar_hud_panel_centerprint_bg_color_team; +string autocvar_hud_panel_centerprint_bg_alpha; +string autocvar_hud_panel_centerprint_bg_border = ""; +string autocvar_hud_panel_centerprint_bg_padding = ""; +float autocvar_hud_panel_centerprint_align; +float autocvar_hud_panel_centerprint_fade_in; +float autocvar_hud_panel_centerprint_fade_out; +float autocvar_hud_panel_centerprint_fade_subsequent; +float autocvar_hud_panel_centerprint_fade_subsequent_passone; +float autocvar_hud_panel_centerprint_fade_subsequent_passone_minalpha; +float autocvar_hud_panel_centerprint_fade_subsequent_passtwo; +float autocvar_hud_panel_centerprint_fade_subsequent_passtwo_minalpha; +float autocvar_hud_panel_centerprint_fade_minfontsize; +float autocvar_hud_panel_centerprint_flip; +float autocvar_hud_panel_centerprint_fontscale; +float autocvar_hud_panel_centerprint_time; float autocvar_hud_panel_chat; float autocvar_hud_panel_engineinfo; float autocvar_hud_panel_engineinfo_framecounter_decimals; @@ -220,22 +241,6 @@ float autocvar_hud_panel_healtharmor_progressbar_gfx; float autocvar_hud_panel_healtharmor_progressbar_gfx_damage; float autocvar_hud_panel_healtharmor_progressbar_gfx_lowhealth; float autocvar_hud_panel_healtharmor_progressbar_gfx_smooth; - -// TEMPORARY hard coded default for compatibility - remove after 0.2 release -var float autocvar_hud_panel_centerprint = 1; -noref var string autocvar_hud_panel_centerprint_pos = "0.180000 0.260000"; -noref var string autocvar_hud_panel_centerprint_size = "0.650000 0.210000"; -noref var string autocvar_hud_panel_centerprint_bg = ""; -noref var string autocvar_hud_panel_centerprint_bg_color = ""; -noref var string autocvar_hud_panel_centerprint_bg_color_team = ""; -noref var string autocvar_hud_panel_centerprint_bg_alpha = ""; -noref var string autocvar_hud_panel_centerprint_bg_border = ""; -noref var string autocvar_hud_panel_centerprint_bg_padding = ""; -var float autocvar_hud_panel_centerprint_align = 0.5; -var float autocvar_hud_panel_centerprint_fadetime = 0.25; -var float autocvar_hud_panel_centerprint_flip = 1; -var float autocvar_hud_panel_centerprint_fontscale = 1; -var float autocvar_hud_panel_centerprint_time = 3; float autocvar_hud_panel_healtharmor_text; float autocvar_hud_panel_infomessages; float autocvar_hud_panel_infomessages_flip; diff --git a/qcsrc/client/hud.qc b/qcsrc/client/hud.qc index f806ae991..48568de96 100644 --- a/qcsrc/client/hud.qc +++ b/qcsrc/client/hud.qc @@ -4481,7 +4481,6 @@ float centerprint_msgID[CENTERPRINT_MAX_MSGS]; float centerprint_time[CENTERPRINT_MAX_MSGS]; float centerprint_expire_time[CENTERPRINT_MAX_MSGS]; float centerprint_countdown_num[CENTERPRINT_MAX_MSGS]; -float centerprint_fadetime; float centerprint_showing; void centerprint_generic(float new_id, string strMessage, float duration, float countdown_num) @@ -4514,8 +4513,6 @@ void centerprint_generic(float new_id, string strMessage, float duration, float if (!centerprint_showing) centerprint_showing = TRUE; - centerprint_fadetime = bound(0, autocvar_hud_panel_centerprint_fadetime, 1); - for (i=0, j=cpm_index; i time + centerprint_fadetime || centerprint_expire_time[j] < time) - centerprint_expire_time[j] = time + centerprint_fadetime; + centerprint_time[j] = autocvar_hud_panel_centerprint_fade_out; + if (centerprint_expire_time[j] > time + autocvar_hud_panel_centerprint_fade_out || centerprint_expire_time[j] < time) + centerprint_expire_time[j] = time + autocvar_hud_panel_centerprint_fade_out; return; } break; // found a msg with the same id, at position j @@ -4672,21 +4669,24 @@ void HUD_CenterPrint (void) } // fade the centerprint in/out - if (centerprint_time[j] < 0 || centerprint_expire_time[j] - centerprint_fadetime > time) + if (centerprint_time[j] < 0 || centerprint_expire_time[j] - autocvar_hud_panel_centerprint_fade_in > time) { - a = bound(0, (time - (centerprint_expire_time[j] - centerprint_time[j])) / centerprint_fadetime, 1); + a = bound(0, (time - (centerprint_expire_time[j] - centerprint_time[j])) / max(0.0001, autocvar_hud_panel_centerprint_fade_in), 1); } - else if (centerprint_expire_time[j] > time) + else if ((centerprint_expire_time[j] > time) && autocvar_hud_panel_centerprint_fade_out) { - a = (centerprint_expire_time[j] - time) / centerprint_fadetime; + a = (centerprint_expire_time[j] - time) / max(0.0001, autocvar_hud_panel_centerprint_fade_out); } // also fade it based on positioning - a = a * bound(0.5, (1 - (i / 2)), 1); // pass one: all messages after the first have half alpha - a = a * bound(0.5, (1 - (i / 10)), 1); // pass two: after that, gradually lower alpha even more for each message + if(autocvar_hud_panel_centerprint_fade_subsequent) + { + a = a * bound(autocvar_hud_panel_centerprint_fade_subsequent_passone_minalpha, (1 - (i / max(1, autocvar_hud_panel_centerprint_fade_subsequent_passone))), 1); // pass one: all messages after the first have half alpha + a = a * bound(autocvar_hud_panel_centerprint_fade_subsequent_passtwo_minalpha, (1 - (i / max(1, autocvar_hud_panel_centerprint_fade_subsequent_passtwo))), 1); // pass two: after that, gradually lower alpha even more for each message + } // finally set the size based on the new alpha - sz = 0.75 + a * (1 - 0.75); + sz = autocvar_hud_panel_centerprint_fade_minfontsize + a * (1 - autocvar_hud_panel_centerprint_fade_minfontsize); drawfontscale = sz * '1 1 0'; if (centerprint_countdown_num[j])