From 33da1d8de42583ed771f92a4d73d830c92ea0814 Mon Sep 17 00:00:00 2001 From: terencehill Date: Fri, 3 Dec 2010 10:36:58 +0100 Subject: [PATCH] Add physics panel options to the menu and remove old cl_showspeed/cl_showacceleration code Also remove obsolete definitions of cl_racetimer_position cl_showpressedkeys* cvars --- _hud_descriptions.cfg | 2 +- defaultXonotic.cfg | 19 --- qcsrc/client/hud.qc | 103 --------------- qcsrc/menu/classes.c | 1 + qcsrc/menu/xonotic/dialog_hudpanel_physics.c | 127 +++++++++++++++++++ qcsrc/menu/xonotic/dialog_settings_misc.c | 26 ---- qcsrc/menu/xonotic/mainwindow.c | 4 + 7 files changed, 133 insertions(+), 149 deletions(-) create mode 100644 qcsrc/menu/xonotic/dialog_hudpanel_physics.c diff --git a/_hud_descriptions.cfg b/_hud_descriptions.cfg index 9ad7ce37a8..3438a25e84 100644 --- a/_hud_descriptions.cfg +++ b/_hud_descriptions.cfg @@ -216,6 +216,6 @@ seta hud_panel_physics_bg_color_team "" "override panel color with team color in seta hud_panel_physics_bg_alpha "" "if set to something else than \"\" = override default panel background alpha" seta hud_panel_physics_bg_border "" "if set to something else than \"\" = override default size of border around the background" seta hud_panel_physics_bg_padding "" "if set to something else than \"\" = override default padding of contents from border" -seta hud_panel_physics_baralign "" "1 = align bars to the right" +seta hud_panel_physics_baralign "" "0 = align bars to the left, 1 = align bars to the right, 2 = align only left bar to the right, 3 = align only right bar to the right" seta hud_panel_physics_flip "" "flip speed/acceleration positions" seta hud_panel_physics_progressbar "" "enable progressbar in panel" diff --git a/defaultXonotic.cfg b/defaultXonotic.cfg index cbec66e3d1..51a5edb4d7 100644 --- a/defaultXonotic.cfg +++ b/defaultXonotic.cfg @@ -1697,25 +1697,6 @@ seta cl_gentle_gibs 0 "client side gentle mode (only replaces gibs); when set t seta cl_gentle_messages 0 "client side gentle mode (only replaces frag messages/centerprints)" seta cl_gentle_damage 0 "client side gentle mode (only replaces damage flash); when set to 1, a white flash replaces the blood image, when set to 2, a randomily colored flash is used instead" -seta cl_racetimer_position 0.25 "Y-axis positioning of the race timer (from 0 to 1)" -seta cl_showpressedkeys 0 "Show which movement keys someone is pressing: 1 for spectating, 2 for always" -seta cl_showpressedkeys_position "0.5 0.8" "1 0 would be upper right corner, 0.5 0.5 the center" - -seta cl_showspeed 0 "show the XY speed of the player" -seta cl_showspeed_unit 0 "unit selection (0 = qu/s (no postfix), 1 = qu/s, 2 = m/s, 3 = km/h, 4 = mph, 5 = knots)" -seta cl_showspeed_z 0 "include the speed on the Z-axis" -seta cl_showspeed_size 30 "size of the numbers" -seta cl_showspeed_position 0.7 "Y-axis positioning of the numbers" - -seta cl_showacceleration 0 "show the XY acceleration of the player" -seta cl_showacceleration_z 0 "include the speed on the Z-axis" -seta cl_showacceleration_size 40 "height of the bar" -seta cl_showacceleration_scale 1 "X-axis scale of the bar" -seta cl_showacceleration_alpha 0.5 "alpha of the bar" -seta cl_showacceleration_color_custom 0 "0 = dynamic color depending on acceleration, 1 = use custom color" -seta cl_showacceleration_color "1 0 0" "color of the bar, needs cl_showacceleration_color_custom to be 1" -seta cl_showacceleration_position 0.6 "Y-axis positioning of the bar" - set g_jetpack 0 "Jetpack mutator (uses the hook's button, can't coexist with the offhand hook, but only with the onhand one)" set g_running_guns 0 "... or wonder, till it drives you mad, what would have followed if you had." diff --git a/qcsrc/client/hud.qc b/qcsrc/client/hud.qc index 51126009a4..4a65b2c177 100644 --- a/qcsrc/client/hud.qc +++ b/qcsrc/client/hud.qc @@ -5103,103 +5103,6 @@ Main HUD system ================== */ -void HUD_ShowSpeed(void) -{ - vector numsize; - float pos, conversion_factor; - string speed, zspeed, unit; - - switch(cvar("cl_showspeed_unit")) - { - default: - case 0: - unit = ""; - conversion_factor = 1.0; - break; - case 1: - unit = " qu/s"; - conversion_factor = 1.0; - break; - case 2: - unit = " m/s"; - conversion_factor = 0.0254; - break; - case 3: - unit = " km/h"; - conversion_factor = 0.0254 * 3.6; - break; - case 4: - unit = " mph"; - conversion_factor = 0.0254 * 3.6 * 0.6213711922; - break; - case 5: - unit = " knots"; - conversion_factor = 0.0254 * 1.943844492; // 1 m/s = 1.943844492 knots, because 1 knot = 1.852 km/h - break; - } - - speed = strcat(ftos(floor( vlen(pmove_vel - pmove_vel_z * '0 0 1') * conversion_factor + 0.5 )), unit); - - numsize_x = numsize_y = cvar("cl_showspeed_size"); - pos = (vid_conheight - numsize_y) * cvar("cl_showspeed_position"); - - drawfont = hud_bigfont; - drawstringcenter(eX + pos * eY, speed, numsize, '1 1 1', autocvar_hud_panel_fg_alpha * hud_fade_alpha, DRAWFLAG_NORMAL); - - if (cvar("cl_showspeed_z") == 1) { - zspeed = strcat(ftos(fabs(floor( pmove_vel_z * conversion_factor + 0.5 ))), unit); - drawstringcenter(eX + pos * eY + numsize_y * eY, zspeed, numsize * 0.5, '1 1 1', autocvar_hud_panel_fg_alpha * hud_fade_alpha, DRAWFLAG_NORMAL); - } - - drawfont = hud_font; -} - -void HUD_ShowAcceleration(void) -{ - float acceleration, sz, scale, alpha, f; - vector pos, mySize, rgb; - - f = time - acc_prevtime; - if(cvar("cl_showacceleration_z")) - acceleration = (vlen(pmove_vel) - vlen(acc_prevspeed)) * (1 / f); - else - acceleration = (vlen(pmove_vel - '0 0 1' * pmove_vel_z) - vlen(acc_prevspeed - '0 0 1' * acc_prevspeed_z)) * (1 / f); - acc_prevspeed = pmove_vel; - acc_prevtime = time; - - f = bound(0, f * 10, 1); - acc_avg = acc_avg * (1 - f) + acceleration * f; - acceleration = acc_avg / getstatf(STAT_MOVEVARS_MAXSPEED); - if (acceleration == 0) - return; - - sz = cvar("cl_showacceleration_size"); - scale = cvar("cl_showacceleration_scale"); - alpha = cvar("cl_showacceleration_alpha"); - if (cvar("cl_showacceleration_color_custom")) - rgb = stov(cvar_string("cl_showacceleration_color")); - else { - if (acceleration < 0) - rgb = '1 .5 .5' - '0 .5 .5' * bound(0, -acceleration * 0.2, 1); - else - rgb = '.5 1 .5' - '.5 0 .5' * bound(0, +acceleration * 0.2, 1); - } - - mySize_x = vid_conwidth/2; - mySize_y = sz; - pos_y = cvar("cl_showacceleration_position") * vid_conheight - sz/2; - if (acceleration > 0) - { - pos_x = mySize_x; - HUD_Panel_DrawProgressBar(pos, mySize, acceleration * scale, 0, 0, rgb, alpha * autocvar_hud_panel_fg_alpha * hud_fade_alpha, DRAWFLAG_NORMAL); - } - else - { - //pos_x = 0; - HUD_Panel_DrawProgressBar(pos, mySize, -acceleration * scale, 0, 1, rgb, alpha * autocvar_hud_panel_fg_alpha * hud_fade_alpha, DRAWFLAG_NORMAL); - } -} - void HUD_Reset (void) { // reset gametype specific icons @@ -5378,12 +5281,6 @@ void HUD_Main (void) if(autocvar__con_chat_maximized) HUD_Chat(); // HUD_DrawPanel(HUD_PANEL_CHAT); - // TODO hud_'ify these - if (cvar("cl_showspeed")) - HUD_ShowSpeed(); - if (cvar("cl_showacceleration")) - HUD_ShowAcceleration(); - if (autocvar__hud_configure && spectatee_status && hud_configure_prev == -1) // try to join if we are in hud_configure mode, but still spectating, and in the first frame (in order to get rid of motd when launching a server via the menu "HUD Setup" button) localcmd("cmd selectteam auto; cmd join\n"); diff --git a/qcsrc/menu/classes.c b/qcsrc/menu/classes.c index 9ebcbb8f5b..2de870cf91 100644 --- a/qcsrc/menu/classes.c +++ b/qcsrc/menu/classes.c @@ -101,4 +101,5 @@ #include "xonotic/dialog_hudpanel_engineinfo.c" #include "xonotic/dialog_hudpanel_infomessages.c" #include "xonotic/dialog_hudpanel_weapons.c" +#include "xonotic/dialog_hudpanel_physics.c" #include "xonotic/slider_picmip.c" diff --git a/qcsrc/menu/xonotic/dialog_hudpanel_physics.c b/qcsrc/menu/xonotic/dialog_hudpanel_physics.c new file mode 100644 index 0000000000..e00524167b --- /dev/null +++ b/qcsrc/menu/xonotic/dialog_hudpanel_physics.c @@ -0,0 +1,127 @@ +#ifdef INTERFACE +CLASS(XonoticHUDPhysicsDialog) EXTENDS(XonoticRootDialog) + METHOD(XonoticHUDPhysicsDialog, fill, void(entity)) + ATTRIB(XonoticHUDPhysicsDialog, title, string, "Physics Panel") + ATTRIB(XonoticHUDPhysicsDialog, color, vector, SKINCOLOR_DIALOG_TEAMSELECT) + ATTRIB(XonoticHUDPhysicsDialog, intendedWidth, float, 0.4) + ATTRIB(XonoticHUDPhysicsDialog, rows, float, 15) + ATTRIB(XonoticHUDPhysicsDialog, columns, float, 4) + ATTRIB(XonoticHUDPhysicsDialog, name, string, "HUDphysics") + ATTRIB(XonoticHUDPhysicsDialog, sliderTopspeedTime, entity, NULL) +ENDCLASS(XonoticHUDPhysicsDialog) +#endif + +#ifdef IMPLEMENTATION +void XonoticHUDPhysicsDialog_fill(entity me) +{ + entity e; + string panelname = "physics"; + float i; + + me.TR(me); + me.TD(me, 1, 3, e = makeXonoticCheckBox(0, "hud_panel_physics", "Enable panel")); + me.TR(me); + me.TD(me, 1, 1.4, e = makeXonoticTextLabel(0, "Background:")); + me.TD(me, 1, 1.6, e = makeXonoticTextSlider(strzone(strcat("hud_panel_", panelname, "_bg")))); + e.addValue(e, "Default", ""); + e.addValue(e, "Disable", "0"); + e.addValue(e, strzone(strcat("border_", panelname)), strzone(strcat("border_", panelname))); + e.configureXonoticTextSliderValues(e); + me.TR(me); + me.TDempty(me, 0.2); + me.TD(me, 1, 1.2, e = makeXonoticTextLabel(0, "Color:")); + me.TD(me, 2, 2.4, e = makeXonoticColorpickerString(strzone(strcat("hud_panel_", panelname, "_bg_color")), "hud_panel_bg_color")); + setDependentStringNotEqual(e, strzone(strcat("hud_panel_", panelname, "_bg_color")), ""); + me.TR(me); + me.TDempty(me, 0.2); + me.TD(me, 1, 1.2, e = makeXonoticCheckBoxString("", "1 1 1", strzone(strcat("hud_panel_", panelname, "_bg_color")), "Use default")); + me.TR(me); + me.TDempty(me, 0.2); + me.TD(me, 1, 1.2, e = makeXonoticTextLabel(0, "Border size:")); + me.TD(me, 1, 2.6, e = makeXonoticTextSlider(strzone(strcat("hud_panel_", panelname, "_bg_border")))); + e.addValue(e, "Default", ""); + e.addValue(e, "Disable", "0"); + for(i = 1; i <= 10; ++i) + e.addValue(e, strzone(ftos_decimals(i * 2, 0)), strzone(ftos(i * 2))); + e.configureXonoticTextSliderValues(e); + me.TR(me); + me.TDempty(me, 0.2); + me.TD(me, 1, 1.2, e = makeXonoticTextLabel(0, "Alpha:")); + me.TD(me, 1, 2.6, e = makeXonoticTextSlider(strzone(strcat("hud_panel_", panelname, "_bg_alpha")))); + e.addValue(e, "Default", ""); + for(i = 1; i <= 10; ++i) + e.addValue(e, strzone(ftos_decimals(i/10, 1)), strzone(ftos(i/10))); + e.configureXonoticTextSliderValues(e); + me.TR(me); + me.TDempty(me, 0.2); + me.TD(me, 1, 1.2, e = makeXonoticTextLabel(0, "Team Color:")); + me.TD(me, 1, 2.6, e = makeXonoticTextSlider(strzone(strcat("hud_panel_", panelname, "_bg_color_team")))); + e.addValue(e, "Default", ""); + e.addValue(e, "Disable", "0"); + for(i = 1; i <= 10; ++i) + e.addValue(e, strzone(ftos_decimals(i/10, 1)), strzone(ftos(i/10))); + e.configureXonoticTextSliderValues(e); + me.TR(me); + me.TDempty(me, 0.4); + me.TD(me, 1, 3, e = makeXonoticCheckBox(0, "hud_configure_teamcolorforced", "Test the team color in HUD configure mode")); + me.TR(me); + me.TDempty(me, 0.2); + me.TD(me, 1, 1.2, e = makeXonoticTextLabel(0, "Padding:")); + me.TD(me, 1, 2.6, e = makeXonoticTextSlider(strzone(strcat("hud_panel_", panelname, "_bg_padding")))); + e.addValue(e, "Default", ""); + for(i = 0; i <= 10; ++i) + e.addValue(e, strzone(ftos_decimals(i - 5, 0)), strzone(ftos(i - 5))); + e.configureXonoticTextSliderValues(e); + me.TR(me); + me.TD(me, 1, 1.4, e = makeXonoticCheckBox(0, "hud_panel_physics_progressbar", "Status bar")); + me.TD(me, 1, 1.6, e = makeXonoticTextSlider("hud_panel_physics_baralign")); + e.addValue(e, "Left align" , "0"); + e.addValue(e, "Right align" , "1"); + e.addValue(e, "Inward align" , "2"); + e.addValue(e, "Outward align", "3"); + e.configureXonoticTextSliderValues(e); + setDependent(e, "hud_panel_physics_progressbar", 1, 1); + me.TR(me); + me.TD(me, 1, 3, e = makeXonoticCheckBox(0, "hud_panel_physics_flip", "Flip speed/acceleration positions")); + +//speed + me.TR(me); + me.TD(me, 1, 1, e = makeXonoticTextLabel(0, "Speed:")); + me.TD(me, 1, 3, e = makeXonoticCheckBox(0, "hud_panel_physics_speed_z", "Include vertical speed")); + // me.TR(me); + // me.TDempty(me, 0.2); + // me.TD(me, 1, 1.8, e = makeXonoticTextLabel(0, "Full status bar at:")); + // setDependent(e, "hud_panel_physics_progressbar", 1, 1); + // me.TD(me, 1, 1, e = makeXonoticInputBox(1, "hud_panel_physics_speed_max")); + // setDependent(e, "hud_panel_physics_progressbar", 1, 1); + // me.TD(me, 1, 1, e = makeXonoticTextLabel(0, "qu/s")); + // setDependent(e, "hud_panel_physics_progressbar", 1, 1); + me.TR(me); + me.TDempty(me, 0.2); + me.TD(me, 1, 1.2, e = makeXonoticTextLabel(0, "Speed unit:")); + me.TD(me, 1, 2.6/3*2, e = makeXonoticTextSlider("hud_panel_physics_speed_unit")); + e.addValue(e, "qu/s" , "1"); + e.addValue(e, "m/s" , "2"); + e.addValue(e, "km/h" , "3"); + e.addValue(e, "mph" , "4"); + e.addValue(e, "knots", "5"); + e.configureXonoticTextSliderValues(e); + me.TD(me, 1, 2.6/3, e = makeXonoticCheckBox(0, "hud_panel_physics_speed_unit_show", "Show")); + me.TR(me); + me.TDempty(me, 0.2); + me.TD(me, 1, 3.8/2, e = makeXonoticCheckBox(0, "hud_panel_physics_topspeed", "Top Speed")); + me.TD(me, 1, 3.8/2, e = makeXonoticSlider(1, 10, 1, "hud_panel_physics_topspeed_time")); + setDependent(e, "hud_panel_physics_topspeed", 1, 1); + +//acceleration + me.TR(me); + me.TD(me, 1, 1, e = makeXonoticTextLabel(0, "Acceleration:")); + me.TD(me, 1, 3, e = makeXonoticCheckBox(0, "hud_panel_physics_acceleration_z", "Include vertical acc.")); + // me.TR(me); + // me.TDempty(me, 0.2); + // me.TD(me, 1, 1.8, e = makeXonoticTextLabel(0, "Full status bar at:")); + // setDependent(e, "hud_panel_physics_progressbar", 1, 1); + // me.TD(me, 1, 0.6, e = makeXonoticInputBox(1, "hud_panel_physics_acceleration_max")); + // setDependent(e, "hud_panel_physics_progressbar", 1, 1); +} +#endif \ No newline at end of file diff --git a/qcsrc/menu/xonotic/dialog_settings_misc.c b/qcsrc/menu/xonotic/dialog_settings_misc.c index 89c8471ca7..addabfd1bc 100644 --- a/qcsrc/menu/xonotic/dialog_settings_misc.c +++ b/qcsrc/menu/xonotic/dialog_settings_misc.c @@ -37,32 +37,6 @@ void XonoticMiscSettingsTab_fill(entity me) me.TD(me, 1, 3, e = makeXonoticCheckBox(0, "showdate", "Show current date")); me.TR(me); me.TD(me, 1, 3, e = makeXonoticCheckBox(0, "showfps", "Show frames per second")); - me.TR(me); - me.TD(me, 1, 3, e = makeXonoticCheckBox(0, "cl_showspeed", "Speedometer")); - me.TR(me); - me.TDempty(me, 0.2); - me.TD(me, 1, 2.8/3, e = makeXonoticRadioButton(1, "cl_showspeed_unit", "0", "qu/s (hidden)")); - setDependent(e, "cl_showspeed", 1, 1); - me.TD(me, 1, 2.8/3, e = makeXonoticRadioButton(1, "cl_showspeed_unit", "1", "qu/s")); - setDependent(e, "cl_showspeed", 1, 1); - me.TD(me, 1, 2.8/3, e = makeXonoticRadioButton(1, "cl_showspeed_unit", "2", "m/s")); - setDependent(e, "cl_showspeed", 1, 1); - me.TR(me); - me.TDempty(me, 0.2); - me.TD(me, 1, 2.8/3, e = makeXonoticRadioButton(1, "cl_showspeed_unit", "3", "km/h")); - setDependent(e, "cl_showspeed", 1, 1); - me.TD(me, 1, 2.8/3, e = makeXonoticRadioButton(1, "cl_showspeed_unit", "4", "mph")); - setDependent(e, "cl_showspeed", 1, 1); - me.TD(me, 1, 2.8/3, e = makeXonoticRadioButton(1, "cl_showspeed_unit", "5", "knots")); - setDependent(e, "cl_showspeed", 1, 1); - me.TR(me); - me.TD(me, 1, 3, e = makeXonoticCheckBox(0, "cl_showacceleration", "Show accelerometer")); - me.TR(me); - me.TDempty(me, 0.2); - me.TD(me, 1, 2.8/2, e = makeXonoticTextLabel(0, "Accelerometer scale:")); - setDependent(e, "cl_showacceleration", 1, 1); - me.TD(me, 1, 2.8/2, e = makeXonoticSlider(1, 10, 0.5, "cl_showacceleration_scale")); - setDependent(e, "cl_showacceleration", 1, 1); me.TR(me); me.TR(me); me.TDempty(me, 0.2); diff --git a/qcsrc/menu/xonotic/mainwindow.c b/qcsrc/menu/xonotic/mainwindow.c index 72e5faac36..a885630368 100644 --- a/qcsrc/menu/xonotic/mainwindow.c +++ b/qcsrc/menu/xonotic/mainwindow.c @@ -97,6 +97,10 @@ void MainWindow_configureMainWindow(entity me) i.configureDialog(i); me.addItemCentered(me, i, i.intendedWidth * eX + i.intendedHeight * eY, SKINALPHAS_MAINMENU_z); + i = spawnXonoticHUDPhysicsDialog(); + i.configureDialog(i); + me.addItemCentered(me, i, i.intendedWidth * eX + i.intendedHeight * eY, SKINALPHAS_MAINMENU_z); + me.advancedDialog = i = spawnXonoticAdvancedDialog(); i.configureDialog(i); me.addItemCentered(me, i, i.intendedWidth * eX + i.intendedHeight * eY, SKINALPHAS_MAINMENU_z); -- 2.39.5