From: terencehill Date: Wed, 8 Jun 2016 22:19:33 +0000 (+0200) Subject: Wrap messages when needed in the infomessages panel X-Git-Tag: xonotic-v0.8.2~758^2~8 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=dbf8f4ded00f7b1cc2365c38122468b48fa0c947;p=xonotic%2Fxonotic-data.pk3dir.git Wrap messages when needed in the infomessages panel --- diff --git a/hud_luma.cfg b/hud_luma.cfg index 2f4f31e92..0034f8a17 100644 --- a/hud_luma.cfg +++ b/hud_luma.cfg @@ -230,7 +230,7 @@ seta hud_panel_engineinfo_bg_padding "" seta hud_panel_engineinfo_framecounter_time "0.1" seta hud_panel_engineinfo_framecounter_decimals "0" -seta hud_panel_infomessages_pos "0.720000 0.100000" +seta hud_panel_infomessages_pos "0.680000 0.100000" seta hud_panel_infomessages_size "0.280000 0.080000" seta hud_panel_infomessages_bg "0" seta hud_panel_infomessages_bg_color "" diff --git a/hud_luminos.cfg b/hud_luminos.cfg index 3d259ebf3..20dd47bef 100644 --- a/hud_luminos.cfg +++ b/hud_luminos.cfg @@ -230,7 +230,7 @@ seta hud_panel_engineinfo_bg_padding "" seta hud_panel_engineinfo_framecounter_time "0.1" seta hud_panel_engineinfo_framecounter_decimals "0" -seta hud_panel_infomessages_pos "0.720000 0.100000" +seta hud_panel_infomessages_pos "0.680000 0.100000" seta hud_panel_infomessages_size "0.280000 0.080000" seta hud_panel_infomessages_bg "0" seta hud_panel_infomessages_bg_color "" diff --git a/hud_luminos_minimal.cfg b/hud_luminos_minimal.cfg index c1ac51b7a..f9250b986 100644 --- a/hud_luminos_minimal.cfg +++ b/hud_luminos_minimal.cfg @@ -231,7 +231,7 @@ seta hud_panel_engineinfo_framecounter_time "0.1" seta hud_panel_engineinfo_framecounter_decimals "0" seta hud_panel_infomessages_pos "0.710000 0" -seta hud_panel_infomessages_size "0.290000 0.100000" +seta hud_panel_infomessages_size "0.280000 0.090000" seta hud_panel_infomessages_bg "0" seta hud_panel_infomessages_bg_color "" seta hud_panel_infomessages_bg_color_team "" diff --git a/hud_luminos_minimal_xhair.cfg b/hud_luminos_minimal_xhair.cfg index d6125985b..a7bbce687 100644 --- a/hud_luminos_minimal_xhair.cfg +++ b/hud_luminos_minimal_xhair.cfg @@ -231,7 +231,7 @@ seta hud_panel_engineinfo_framecounter_time "0.1" seta hud_panel_engineinfo_framecounter_decimals "0" seta hud_panel_infomessages_pos "0.710000 0" -seta hud_panel_infomessages_size "0.290000 0.100000" +seta hud_panel_infomessages_size "0.280000 0.090000" seta hud_panel_infomessages_bg "0" seta hud_panel_infomessages_bg_color "" seta hud_panel_infomessages_bg_color_team "" diff --git a/qcsrc/client/hud/panel/infomessages.qc b/qcsrc/client/hud/panel/infomessages.qc index a197963e7..90e97739a 100644 --- a/qcsrc/client/hud/panel/infomessages.qc +++ b/qcsrc/client/hud/panel/infomessages.qc @@ -5,12 +5,25 @@ // Info messages panel (#14) -#define drawInfoMessage(s) MACRO_BEGIN { \ - if(autocvar_hud_panel_infomessages_flip) \ - o.x = pos.x + mySize.x - stringwidth(s, true, fontsize); \ - drawcolorcodedstring(o, s, fontsize, a, DRAWFLAG_NORMAL); \ - o.y += fontsize.y; \ -} MACRO_END +float stringwidth_colors(string s, vector theSize); +vector InfoMessages_drawstring(string s, vector pos, vector sz, float a, vector fontsize) +{ + getWrappedLine_remaining = s; + float offset = 0; + while(getWrappedLine_remaining) + { + s = getWrappedLine(sz.x - offset, fontsize, stringwidth_colors); + if(autocvar_hud_panel_infomessages_flip) + offset = sz.x - stringwidth_colors(s, fontsize) - offset; + drawcolorcodedstring(pos + eX * offset, s, fontsize, a, DRAWFLAG_NORMAL); + pos.y += fontsize.y; + offset = fontsize.x; + } + return pos; +} + +#define InfoMessage(s, a) pos = InfoMessages_drawstring(s, pos, mySize, a, fontsize) + void HUD_InfoMessages() { if(!autocvar__hud_configure) @@ -34,60 +47,32 @@ void HUD_InfoMessages() mySize -= '2 2 0' * panel_bg_padding; } - // always force 5:1 aspect - vector newSize = '0 0 0'; - if(mySize.x/mySize.y > 5) - { - newSize.x = 5 * mySize.y; - newSize.y = mySize.y; - - pos.x = pos.x + (mySize.x - newSize.x) / 2; - } - else - { - newSize.y = 1/5 * mySize.x; - newSize.x = mySize.x; - - pos.y = pos.y + (mySize.y - newSize.y) / 2; - } - - mySize = newSize; - entity tm; - vector o; - o = pos; - - vector fontsize; - fontsize = '0.20 0.20 0' * mySize.y; - - float a; - a = panel_fg_alpha; - + vector fontsize = '0.2 0.2 0' * mySize.y; string s; if(!autocvar__hud_configure) { if(spectatee_status) { - a = 1; if(spectatee_status == -1) s = _("^1Observing"); else s = sprintf(_("^1Spectating: ^7%s"), entcs_GetName(current_player)); - drawInfoMessage(s); + InfoMessage(s, panel_fg_alpha); if(spectatee_status == -1) s = sprintf(_("^1Press ^3%s^1 to spectate"), getcommandkey("primary fire", "+fire")); else s = sprintf(_("^1Press ^3%s^1 or ^3%s^1 for next or previous player"), getcommandkey("next weapon", "weapnext"), getcommandkey("previous weapon", "weapprev")); - drawInfoMessage(s); + InfoMessage(s, panel_fg_alpha); if(spectatee_status == -1) s = sprintf(_("^1Use ^3%s^1 or ^3%s^1 to change the speed"), getcommandkey("next weapon", "weapnext"), getcommandkey("previous weapon", "weapprev")); else s = sprintf(_("^1Press ^3%s^1 to observe"), getcommandkey("secondary fire", "+fire2")); - drawInfoMessage(s); + InfoMessage(s, panel_fg_alpha); s = sprintf(_("^1Press ^3%s^1 for gamemode info"), getcommandkey("server info", "+show_info")); - drawInfoMessage(s); + InfoMessage(s, panel_fg_alpha); if(gametype == MAPINFO_TYPE_LMS) { @@ -102,7 +87,7 @@ void HUD_InfoMessages() } else s = sprintf(_("^1Press ^3%s^1 to join"), getcommandkey("jump", "+jump")); - drawInfoMessage(s); + InfoMessage(s, panel_fg_alpha); } if (time < STAT(GAMESTARTTIME)) @@ -110,13 +95,13 @@ void HUD_InfoMessages() //we need to ceil, otherwise the countdown would be off by .5 when using round() float countdown = ceil(STAT(GAMESTARTTIME) - time); s = sprintf(_("^1Game starts in ^3%d^1 seconds"), countdown); - drawInfoMessage(s); + InfoMessage(s, panel_fg_alpha); } if(warmup_stage) { s = _("^2Currently in ^1warmup^2 stage!"); - drawInfoMessage(s); + InfoMessage(s, panel_fg_alpha); } string blinkcolor; @@ -141,18 +126,18 @@ void HUD_InfoMessages() else s = _("^2Waiting for others to ready up..."); } - drawInfoMessage(s); + InfoMessage(s, panel_fg_alpha); } else if(warmup_stage && !spectatee_status) { s = sprintf(_("^2Press ^3%s^2 to end warmup"), getcommandkey("ready", "ready")); - drawInfoMessage(s); + InfoMessage(s, panel_fg_alpha); } if(teamplay && !spectatee_status && gametype != MAPINFO_TYPE_CA && teamnagger) { float ts_min = 0, ts_max = 0; - tm = teams.sort_next; + entity tm = teams.sort_next; if (tm) { for (; tm.sort_next; tm = tm.sort_next) @@ -168,24 +153,18 @@ void HUD_InfoMessages() { s = strcat(blinkcolor, _("Teamnumbers are unbalanced!")); tm = GetTeam(myteam, false); - if (tm) - if (tm.team != NUM_SPECTATOR) - if (tm.team_size == ts_max) + if (tm && tm.team != NUM_SPECTATOR && tm.team_size == ts_max) s = strcat(s, sprintf(_(" Press ^3%s%s to adjust"), getcommandkey("team menu", "menu_showteamselect"), blinkcolor)); - drawInfoMessage(s); + InfoMessage(s, panel_fg_alpha); } } } } else { - s = _("^7Press ^3ESC ^7to show HUD options."); - drawInfoMessage(s); - s = _("^3Doubleclick ^7a panel for panel-specific options."); - drawInfoMessage(s); - s = _("^3CTRL ^7to disable collision testing, ^3SHIFT ^7and"); - drawInfoMessage(s); - s = _("^3ALT ^7+ ^3ARROW KEYS ^7for fine adjustments."); - drawInfoMessage(s); + InfoMessage(_("^7Press ^3ESC ^7to show HUD options."), panel_fg_alpha); + InfoMessage(_("^3Doubleclick ^7a panel for panel-specific options."), panel_fg_alpha); + InfoMessage(_("^3CTRL ^7to disable collision testing, ^3SHIFT ^7and"), panel_fg_alpha); + InfoMessage(_("^3ALT ^7+ ^3ARROW KEYS ^7for fine adjustments."), panel_fg_alpha); } }