From c709fd0885c566cb3a79e46f35d402123383a7b3 Mon Sep 17 00:00:00 2001 From: tmyqlfpir <80724828+tmyqlfpir@users.noreply.github.com> Date: Fri, 13 Sep 2024 07:07:58 +1000 Subject: [PATCH 1/2] Mact: Add solo axis deadzone feature --- source/mact/include/_control.h | 1 + source/mact/include/joystick.h | 1 + source/mact/src/control.cpp | 7 ++++++- 3 files changed, 8 insertions(+), 1 deletion(-) diff --git a/source/mact/include/_control.h b/source/mact/include/_control.h index e43c2c931c..e4ab903458 100644 --- a/source/mact/include/_control.h +++ b/source/mact/include/_control.h @@ -126,6 +126,7 @@ typedef struct ControllerAxis uint16_t deadzone; uint16_t saturation; bool invert; + bool solodeadzone; } ControllerAxis_t; typedef struct UserInputState diff --git a/source/mact/include/joystick.h b/source/mact/include/joystick.h index 671a6b3c7e..42d84fcd9b 100644 --- a/source/mact/include/joystick.h +++ b/source/mact/include/joystick.h @@ -54,6 +54,7 @@ int32_t JOYSTICK_GetControllerButtons( void ); void JOYSTICK_ClearAllButtons( void ); int32_t JOYSTICK_GetHat( int32_t h ); void JOYSTICK_SetDeadZone(int32_t axis, uint16_t dead, uint16_t satur); +void JOYSTICK_SetAxisSoloDeadZone(int32_t axis, bool dead); #ifdef __cplusplus } diff --git a/source/mact/src/control.cpp b/source/mact/src/control.cpp index bf31ced274..3cfaeb4b96 100644 --- a/source/mact/src/control.cpp +++ b/source/mact/src/control.cpp @@ -267,6 +267,11 @@ void JOYSTICK_SetDeadZone(int32_t axis, uint16_t dead, uint16_t satur) joyAxes[axis].saturation = satur; } +void JOYSTICK_SetAxisSoloDeadZone(int32_t axis, bool dead) +{ + joyAxes[axis].solodeadzone = dead; +} + void CONTROL_SetAnalogAxisScale(int32_t whichaxis, int32_t axisscale, controldevice device) { float *set; @@ -488,7 +493,7 @@ static void controlUpdateAxisState(int index, ControlInfo *const info) else { // this assumes there are two sticks comprised of axes 0 and 1, and 2 and 3... because when isGameController is true, there are - if (index <= CONTROLLER_AXIS_LEFTY || (joystick.isGameController && (index <= CONTROLLER_AXIS_RIGHTY))) + if (!a.solodeadzone && (index <= CONTROLLER_AXIS_LEFTY || (joystick.isGameController && (index <= CONTROLLER_AXIS_RIGHTY)))) axisScaled10k = min(10000, joydist(joystick.pAxis[index & ~1], joystick.pAxis[index | 1]) * 10000 / 32767); if (axisScaled10k < a.deadzone) From e2872c51793c107001c22c02bc3814b42a3eefff Mon Sep 17 00:00:00 2001 From: tmyqlfpir <80724828+tmyqlfpir@users.noreply.github.com> Date: Fri, 13 Sep 2024 08:14:19 +1000 Subject: [PATCH 2/2] Blood: Add support for solo axis deadzones --- source/blood/src/_functio.h | 15 ++++++++++++--- source/blood/src/config.cpp | 16 ++++++++++++++++ source/blood/src/config.h | 1 + source/blood/src/menu.cpp | 26 +++++++++++++++++++++++--- 4 files changed, 52 insertions(+), 6 deletions(-) diff --git a/source/blood/src/_functio.h b/source/blood/src/_functio.h index b3b3dea50e..780010dfad 100644 --- a/source/blood/src/_functio.h +++ b/source/blood/src/_functio.h @@ -343,7 +343,7 @@ static const int32_t joystickanalogscaledefaults[MAXJOYAXES] = DEFAULTJOYSTICKANALOGUESCALE, DEFAULTJOYSTICKANALOGUESCALE, DEFAULTJOYSTICKANALOGUESCALE/2, - DEFAULTJOYSTICKANALOGUESCALE/4 + DEFAULTJOYSTICKANALOGUESCALE/4, }; @@ -352,7 +352,16 @@ static const int32_t joystickanalogdeaddefaults[MAXJOYAXES] = DEFAULTJOYSTICKANALOGUEDEAD*5, DEFAULTJOYSTICKANALOGUEDEAD*4, DEFAULTJOYSTICKANALOGUEDEAD*2, - DEFAULTJOYSTICKANALOGUEDEAD*2 + DEFAULTJOYSTICKANALOGUEDEAD*2, + }; + + +static const int32_t joystickanalogaxissolodeadzone[MAXJOYAXES] = + { + 1, + 0, + 0, + 0, }; @@ -361,7 +370,7 @@ static const int32_t joystickanalogsaturatedefaults[MAXJOYAXES] = DEFAULTJOYSTICKANALOGUESATURATE*3, DEFAULTJOYSTICKANALOGUESATURATE*3, DEFAULTJOYSTICKANALOGUESATURATE*2, - DEFAULTJOYSTICKANALOGUESATURATE*2 + DEFAULTJOYSTICKANALOGUESATURATE*2, }; diff --git a/source/blood/src/config.cpp b/source/blood/src/config.cpp index 54a4e81990..6bceb75c67 100644 --- a/source/blood/src/config.cpp +++ b/source/blood/src/config.cpp @@ -65,6 +65,7 @@ int32_t JoystickAnalogueScale[MAXJOYAXES]; int32_t JoystickAnalogueDead[MAXJOYAXES]; int32_t JoystickAnalogueSaturate[MAXJOYAXES]; int32_t JoystickAnalogueInvert[MAXJOYAXES]; +int32_t JoystickAnalogueAxisSoloDeadZone[MAXJOYAXES]; uint8_t KeyboardKeys[NUMGAMEFUNCTIONS][2]; int32_t scripthandle; int32_t setupread; @@ -479,6 +480,9 @@ void CONFIG_SetDefaults(void) JoystickAnalogueInvert[i] = 0; CONTROL_SetAnalogAxisInvert(i, JoystickAnalogueInvert[i]); + + JoystickAnalogueAxisSoloDeadZone[i] = 0; + JOYSTICK_SetAxisSoloDeadZone(i, JoystickAnalogueAxisSoloDeadZone[i]); } #else for (int i=0; inValue = JoystickAnalogueDead[nAxis]; pItemOptionsControlJoystickAxisSaturate[nAxis]->nValue = JoystickAnalogueSaturate[nAxis]; + pItemOptionsControlJoystickAxisSoloDeadzone[nAxis]->at20 = JoystickAnalogueAxisSoloDeadZone[nAxis]; } } @@ -2500,6 +2507,19 @@ void SetJoystickSaturate(CGameMenuItemSlider* pItem) } } +void SetJoystickSoloDeadzone(CGameMenuItemZBool* pItem) +{ + for (int nAxis = 0; nAxis < MAXJOYAXES; nAxis++) + { + if (pItem == pItemOptionsControlJoystickAxisSoloDeadzone[nAxis]) + { + JoystickAnalogueAxisSoloDeadZone[nAxis] = pItem->at20; + JOYSTICK_SetAxisSoloDeadZone(nAxis, JoystickAnalogueAxisSoloDeadZone[nAxis]); + break; + } + } +} + void PreDrawControlMouse(CGameMenuItem *pItem) { if (pItem == &itemOptionsControlMouseVerticalAim)