From 438541bbe0c4033540b09bfee5f8c55493e1f595 Mon Sep 17 00:00:00 2001 From: CherryEx <57710259+CherryEx@users.noreply.github.com> Date: Wed, 17 Jul 2024 03:20:42 +0330 Subject: [PATCH] Let some scrollbars have out of range values This is necessary because options like mouse sensivity get replaced with their scrollbar max value every time you open their settings page. --- src/game/client/components/menus_callback.cpp | 8 ++++---- src/game/client/components/menus_settings.cpp | 4 ++-- src/game/client/ui.cpp | 8 +++++++- src/game/client/ui.h | 8 +++++++- 4 files changed, 20 insertions(+), 8 deletions(-) diff --git a/src/game/client/components/menus_callback.cpp b/src/game/client/components/menus_callback.cpp index 3da1b628c9..70e19e1ca2 100644 --- a/src/game/client/components/menus_callback.cpp +++ b/src/game/client/components/menus_callback.cpp @@ -145,11 +145,11 @@ float CMenus::RenderSettingsControlsMouse(CUIRect View) View.HSplitTop(Spacing, 0, &View); View.HSplitTop(ButtonHeight, &Button, &View); - UI()->DoScrollbarOption(&Config()->m_InpMousesens, &Config()->m_InpMousesens, &Button, Localize("In-game mouse sens."), 1, 500, &CUI::ms_LogarithmicScrollbarScale); + UI()->DoScrollbarOption(&Config()->m_InpMousesens, &Config()->m_InpMousesens, &Button, Localize("In-game mouse sens."), 1, 500, &CUI::ms_LogarithmicScrollbarScale, CUI::SCROLLBAR_NO_STRICT_RANGE); View.HSplitTop(Spacing, 0, &View); View.HSplitTop(ButtonHeight, &Button, &View); - UI()->DoScrollbarOption(&Config()->m_UiMousesens, &Config()->m_UiMousesens, &Button, Localize("Menu mouse sens."), 1, 500, &CUI::ms_LogarithmicScrollbarScale); + UI()->DoScrollbarOption(&Config()->m_UiMousesens, &Config()->m_UiMousesens, &Button, Localize("Menu mouse sens."), 1, 500, &CUI::ms_LogarithmicScrollbarScale, CUI::SCROLLBAR_NO_STRICT_RANGE); return BackgroundHeight; } @@ -217,12 +217,12 @@ float CMenus::RenderSettingsControlsJoystick(CUIRect View) { View.HSplitTop(Spacing, 0, &View); View.HSplitTop(ButtonHeight, &Button, &View); - UI()->DoScrollbarOption(&Config()->m_JoystickSens, &Config()->m_JoystickSens, &Button, Localize("In-game joystick sensitivity"), 1, 500, &CUI::ms_LogarithmicScrollbarScale); + UI()->DoScrollbarOption(&Config()->m_JoystickSens, &Config()->m_JoystickSens, &Button, Localize("In-game joystick sensitivity"), 1, 500, &CUI::ms_LogarithmicScrollbarScale, CUI::SCROLLBAR_NO_STRICT_RANGE); } View.HSplitTop(Spacing, 0, &View); View.HSplitTop(ButtonHeight, &Button, &View); - UI()->DoScrollbarOption(&Config()->m_UiJoystickSens, &Config()->m_UiJoystickSens, &Button, Localize("Menu/Editor joystick sensitivity"), 1, 500, &CUI::ms_LogarithmicScrollbarScale); + UI()->DoScrollbarOption(&Config()->m_UiJoystickSens, &Config()->m_UiJoystickSens, &Button, Localize("Menu/Editor joystick sensitivity"), 1, 500, &CUI::ms_LogarithmicScrollbarScale, CUI::SCROLLBAR_NO_STRICT_RANGE); View.HSplitTop(Spacing, 0, &View); View.HSplitTop(ButtonHeight, &Button, &View); diff --git a/src/game/client/components/menus_settings.cpp b/src/game/client/components/menus_settings.cpp index 4c6c299613..c0fe93febc 100644 --- a/src/game/client/components/menus_settings.cpp +++ b/src/game/client/components/menus_settings.cpp @@ -977,7 +977,7 @@ void CMenus::RenderSettingsGeneral(CUIRect MainView) Config()->m_ClAutoDemoRecord ^= 1; if(Config()->m_ClAutoDemoRecord) - UI()->DoScrollbarOption(&Config()->m_ClAutoDemoMax, &Config()->m_ClAutoDemoMax, &ClientRight, Localize("Max"), 0, 1000, &CUI::ms_LogarithmicScrollbarScale, true); + UI()->DoScrollbarOption(&Config()->m_ClAutoDemoMax, &Config()->m_ClAutoDemoMax, &ClientRight, Localize("Max"), 0, 1000, &CUI::ms_LogarithmicScrollbarScale, CUI::SCROLLBAR_INFINITE); Client.HSplitTop(Spacing, 0, &Client); Client.HSplitTop(ButtonHeight, &ClientLeft, &Client); @@ -986,7 +986,7 @@ void CMenus::RenderSettingsGeneral(CUIRect MainView) Config()->m_ClAutoScreenshot ^= 1; if(Config()->m_ClAutoScreenshot) - UI()->DoScrollbarOption(&Config()->m_ClAutoScreenshotMax, &Config()->m_ClAutoScreenshotMax, &ClientRight, Localize("Max"), 0, 1000, &CUI::ms_LogarithmicScrollbarScale, true); + UI()->DoScrollbarOption(&Config()->m_ClAutoScreenshotMax, &Config()->m_ClAutoScreenshotMax, &ClientRight, Localize("Max"), 0, 1000, &CUI::ms_LogarithmicScrollbarScale, CUI::SCROLLBAR_INFINITE); MainView.HSplitTop(10.0f, 0, &MainView); diff --git a/src/game/client/ui.cpp b/src/game/client/ui.cpp index 6b5815311e..11b2b28fff 100644 --- a/src/game/client/ui.cpp +++ b/src/game/client/ui.cpp @@ -705,8 +705,10 @@ float CUI::DoScrollbarH(const void *pID, const CUIRect *pRect, float Current) return ReturnValue; } -void CUI::DoScrollbarOption(const void *pID, int *pOption, const CUIRect *pRect, const char *pStr, int Min, int Max, const IScrollbarScale *pScale, bool Infinite) +void CUI::DoScrollbarOption(const void *pID, int *pOption, const CUIRect *pRect, const char *pStr, int Min, int Max, const IScrollbarScale *pScale, unsigned char Options) { + const bool Infinite = Options & CUI::SCROLLBAR_INFINITE; + const bool NoRangeEnforcement = Options & CUI::SCROLLBAR_NO_STRICT_RANGE; int Value = *pOption; if(Infinite) { @@ -736,6 +738,10 @@ void CUI::DoScrollbarOption(const void *pID, int *pOption, const CUIRect *pRect, ScrollBar.VMargin(4.0f, &ScrollBar); Value = pScale->ToAbsolute(DoScrollbarH(pID, &ScrollBar, pScale->ToRelative(Value, Min, Max)), Min, Max); + if (NoRangeEnforcement && ((Value == Min && *pOption < Min) || (Value == Max && *pOption > Max))) + { + Value = *pOption; + } if(Infinite && Value == Max) Value = 0; diff --git a/src/game/client/ui.h b/src/game/client/ui.h index 943dec6735..54ea1856b9 100644 --- a/src/game/client/ui.h +++ b/src/game/client/ui.h @@ -273,9 +273,15 @@ class CUI // scrollbars float DoScrollbarV(const void *pID, const CUIRect *pRect, float Current); float DoScrollbarH(const void *pID, const CUIRect *pRect, float Current); - void DoScrollbarOption(const void *pID, int *pOption, const CUIRect *pRect, const char *pStr, int Min, int Max, const IScrollbarScale *pScale = &ms_LinearScrollbarScale, bool Infinite = false); + void DoScrollbarOption(const void *pID, int *pOption, const CUIRect *pRect, const char *pStr, int Min, int Max, const IScrollbarScale *pScale = &ms_LinearScrollbarScale, unsigned char Options = 0); void DoScrollbarOptionLabeled(const void *pID, int *pOption, const CUIRect *pRect, const char *pStr, const char *apLabels[], int NumLabels, const IScrollbarScale *pScale = &ms_LinearScrollbarScale); + enum + { + SCROLLBAR_INFINITE = 1 << 0, + SCROLLBAR_NO_STRICT_RANGE = 1 << 1, + }; + // tooltips void DoTooltip(const void *pID, const CUIRect *pRect, const char *pText); void RenderTooltip();