mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 08:50:55 +00:00
Rescan for controllers when toggling gamepads back on
git-svn-id: https://svn.eduke32.com/eduke32@7985 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
0bf4f744a8
commit
1bbd251bff
6 changed files with 123 additions and 73 deletions
|
@ -230,6 +230,7 @@ void mouseSetCallback(void (*callback)(int32_t,int32_t));
|
||||||
void joySetCallback(void (*callback)(int32_t,int32_t));
|
void joySetCallback(void (*callback)(int32_t,int32_t));
|
||||||
const char *keyGetName(int32_t num);
|
const char *keyGetName(int32_t num);
|
||||||
const char *joyGetName(int32_t what, int32_t num); // what: 0=axis, 1=button, 2=hat
|
const char *joyGetName(int32_t what, int32_t num); // what: 0=axis, 1=button, 2=hat
|
||||||
|
void joyScanDevices(void);
|
||||||
|
|
||||||
char keyGetScan(void);
|
char keyGetScan(void);
|
||||||
char keyGetChar(void);
|
char keyGetChar(void);
|
||||||
|
|
|
@ -825,6 +825,103 @@ static void LoadSDLControllerDB()
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
void joyScanDevices()
|
||||||
|
{
|
||||||
|
inputdevices &= ~4;
|
||||||
|
|
||||||
|
if (controller)
|
||||||
|
{
|
||||||
|
SDL_GameControllerClose(controller);
|
||||||
|
controller = nullptr;
|
||||||
|
}
|
||||||
|
if (joydev)
|
||||||
|
{
|
||||||
|
SDL_JoystickClose(joydev);
|
||||||
|
joydev = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
int numjoysticks = SDL_NumJoysticks();
|
||||||
|
if (numjoysticks < 1)
|
||||||
|
{
|
||||||
|
buildputs("No game controllers found\n");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
buildputs("Game controllers:\n");
|
||||||
|
for (int i = 0; i < numjoysticks; i++)
|
||||||
|
{
|
||||||
|
const char * name;
|
||||||
|
#if SDL_MAJOR_VERSION >= 2
|
||||||
|
if (SDL_IsGameController(i))
|
||||||
|
name = SDL_GameControllerNameForIndex(i);
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
name = SDL_JoystickNameForIndex(i);
|
||||||
|
|
||||||
|
buildprintf(" %d. %s\n", i+1, name);
|
||||||
|
}
|
||||||
|
|
||||||
|
#if SDL_MAJOR_VERSION >= 2
|
||||||
|
for (int i = 0; i < numjoysticks; i++)
|
||||||
|
{
|
||||||
|
if ((controller = SDL_GameControllerOpen(i)))
|
||||||
|
{
|
||||||
|
buildprintf("Using controller %s\n", SDL_GameControllerName(controller));
|
||||||
|
|
||||||
|
joystick.numAxes = SDL_CONTROLLER_AXIS_MAX;
|
||||||
|
joystick.numButtons = SDL_CONTROLLER_BUTTON_MAX;
|
||||||
|
joystick.numHats = 0;
|
||||||
|
joystick.isGameController = 1;
|
||||||
|
|
||||||
|
Xfree(joystick.pAxis);
|
||||||
|
joystick.pAxis = (int32_t *)Xcalloc(joystick.numAxes, sizeof(int32_t));
|
||||||
|
Xfree(joystick.pHat);
|
||||||
|
joystick.pHat = nullptr;
|
||||||
|
|
||||||
|
inputdevices |= 4;
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
for (int i = 0; i < numjoysticks; i++)
|
||||||
|
{
|
||||||
|
if ((joydev = SDL_JoystickOpen(i)))
|
||||||
|
{
|
||||||
|
buildprintf("Using joystick %s\n", SDL_JoystickName(joydev));
|
||||||
|
|
||||||
|
// KEEPINSYNC duke3d/src/gamedefs.h, mact/include/_control.h
|
||||||
|
joystick.numAxes = min(9, SDL_JoystickNumAxes(joydev));
|
||||||
|
joystick.numButtons = min(32, SDL_JoystickNumButtons(joydev));
|
||||||
|
joystick.numHats = min((36-joystick.numButtons)/4,SDL_JoystickNumHats(joydev));
|
||||||
|
joystick.isGameController = 0;
|
||||||
|
|
||||||
|
initprintf("Joystick %d has %d axes, %d buttons, and %d hat(s).\n", i+1, joystick.numAxes, joystick.numButtons, joystick.numHats);
|
||||||
|
|
||||||
|
Xfree(joystick.pAxis);
|
||||||
|
joystick.pAxis = (int32_t *)Xcalloc(joystick.numAxes, sizeof(int32_t));
|
||||||
|
|
||||||
|
Xfree(joystick.pHat);
|
||||||
|
if (joystick.numHats)
|
||||||
|
joystick.pHat = (int32_t *)Xcalloc(joystick.numHats, sizeof(int32_t));
|
||||||
|
else
|
||||||
|
joystick.pHat = nullptr;
|
||||||
|
|
||||||
|
for (int j = 0; j < joystick.numHats; j++)
|
||||||
|
joystick.pHat[j] = -1; // center
|
||||||
|
|
||||||
|
SDL_JoystickEventState(SDL_ENABLE);
|
||||||
|
inputdevices |= 4;
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
buildputs("No controllers are usable\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// initinput() -- init input system
|
// initinput() -- init input system
|
||||||
//
|
//
|
||||||
|
@ -878,76 +975,7 @@ int32_t initinput(void)
|
||||||
LoadSDLControllerDB();
|
LoadSDLControllerDB();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int numjoysticks = SDL_NumJoysticks();
|
joyScanDevices();
|
||||||
if (numjoysticks < 1)
|
|
||||||
{
|
|
||||||
buildputs("No game controllers found\n");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
buildputs("Game controllers:\n");
|
|
||||||
for (i = 0; i < numjoysticks; i++)
|
|
||||||
{
|
|
||||||
const char * name;
|
|
||||||
#if SDL_MAJOR_VERSION >= 2
|
|
||||||
if (SDL_IsGameController(i))
|
|
||||||
name = SDL_GameControllerNameForIndex(i);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
name = SDL_JoystickNameForIndex(i);
|
|
||||||
|
|
||||||
buildprintf(" %d. %s\n", i+1, name);
|
|
||||||
}
|
|
||||||
|
|
||||||
#if SDL_MAJOR_VERSION >= 2
|
|
||||||
for (i = 0; i < numjoysticks; i++)
|
|
||||||
{
|
|
||||||
if ((controller = SDL_GameControllerOpen(i)))
|
|
||||||
{
|
|
||||||
buildprintf("Using controller %s\n", SDL_GameControllerName(controller));
|
|
||||||
|
|
||||||
inputdevices |= 4;
|
|
||||||
|
|
||||||
joystick.numAxes = SDL_CONTROLLER_AXIS_MAX;
|
|
||||||
joystick.numButtons = SDL_CONTROLLER_BUTTON_MAX;
|
|
||||||
joystick.numHats = 0;
|
|
||||||
joystick.isGameController = 1;
|
|
||||||
|
|
||||||
joystick.pAxis = (int32_t *)Xcalloc(joystick.numAxes, sizeof(int32_t));
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
for (i = 0; i < numjoysticks; i++)
|
|
||||||
{
|
|
||||||
if ((joydev = SDL_JoystickOpen(i)))
|
|
||||||
{
|
|
||||||
buildprintf("Using joystick %s\n", SDL_JoystickName(joydev));
|
|
||||||
|
|
||||||
SDL_JoystickEventState(SDL_ENABLE);
|
|
||||||
inputdevices |= 4;
|
|
||||||
|
|
||||||
// KEEPINSYNC duke3d/src/gamedefs.h, mact/include/_control.h
|
|
||||||
joystick.numAxes = min(9, SDL_JoystickNumAxes(joydev));
|
|
||||||
joystick.numButtons = min(32, SDL_JoystickNumButtons(joydev));
|
|
||||||
joystick.numHats = min((36-joystick.numButtons)/4,SDL_JoystickNumHats(joydev));
|
|
||||||
initprintf("Joystick %d has %d axes, %d buttons, and %d hat(s).\n", i+1, joystick.numAxes, joystick.numButtons, joystick.numHats);
|
|
||||||
|
|
||||||
joystick.pAxis = (int32_t *)Xcalloc(joystick.numAxes, sizeof(int32_t));
|
|
||||||
|
|
||||||
if (joystick.numHats)
|
|
||||||
joystick.pHat = (int32_t *)Xcalloc(joystick.numHats, sizeof(int32_t));
|
|
||||||
|
|
||||||
for (i = 0; i < joystick.numHats; i++) joystick.pHat[i] = -1; // centre
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
buildputs("No controllers are usable\n");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -1150,6 +1150,10 @@ const char *joyGetName(int32_t what, int32_t num)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void joyScanDevices()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// AcquireInputDevices() -- (un)acquires the input devices
|
// AcquireInputDevices() -- (un)acquires the input devices
|
||||||
//
|
//
|
||||||
|
|
|
@ -3380,7 +3380,11 @@ static int32_t Menu_EntryOptionModify(MenuEntry_t *entry, int32_t newOption)
|
||||||
else if (entry == &ME_MOUSESETUP_SMOOTH)
|
else if (entry == &ME_MOUSESETUP_SMOOTH)
|
||||||
CONTROL_SmoothMouse = ud.config.SmoothInput;
|
CONTROL_SmoothMouse = ud.config.SmoothInput;
|
||||||
else if (entry == &ME_JOYSTICK_ENABLE)
|
else if (entry == &ME_JOYSTICK_ENABLE)
|
||||||
|
{
|
||||||
|
if (newOption)
|
||||||
|
CONTROL_ScanForControllers();
|
||||||
CONTROL_JoystickEnabled = (newOption && CONTROL_JoyPresent);
|
CONTROL_JoystickEnabled = (newOption && CONTROL_JoyPresent);
|
||||||
|
}
|
||||||
else if (entry == &ME_JOYSTICKAXIS_ANALOG)
|
else if (entry == &ME_JOYSTICKAXIS_ANALOG)
|
||||||
CONTROL_MapAnalogAxis(M_JOYSTICKAXES.currentEntry, newOption, controldevice_joystick);
|
CONTROL_MapAnalogAxis(M_JOYSTICKAXES.currentEntry, newOption, controldevice_joystick);
|
||||||
else if (entry == &ME_NETOPTIONS_EPISODE)
|
else if (entry == &ME_NETOPTIONS_EPISODE)
|
||||||
|
|
|
@ -198,6 +198,8 @@ void CONTROL_MapAnalogAxis(int whichaxis, int whichanalog, controldevice device)
|
||||||
void CONTROL_MapDigitalAxis(int32_t whichaxis, int32_t whichfunction, int32_t direction, controldevice device);
|
void CONTROL_MapDigitalAxis(int32_t whichaxis, int32_t whichfunction, int32_t direction, controldevice device);
|
||||||
void CONTROL_SetAnalogAxisScale(int32_t whichaxis, int32_t axisscale, controldevice device);
|
void CONTROL_SetAnalogAxisScale(int32_t whichaxis, int32_t axisscale, controldevice device);
|
||||||
|
|
||||||
|
void CONTROL_ScanForControllers(void);
|
||||||
|
|
||||||
int32_t CONTROL_GetGameControllerDigitalAxisPos(int32_t axis);
|
int32_t CONTROL_GetGameControllerDigitalAxisPos(int32_t axis);
|
||||||
int32_t CONTROL_GetGameControllerDigitalAxisNeg(int32_t axis);
|
int32_t CONTROL_GetGameControllerDigitalAxisNeg(int32_t axis);
|
||||||
void CONTROL_ClearGameControllerDigitalAxisPos(int32_t axis);
|
void CONTROL_ClearGameControllerDigitalAxisPos(int32_t axis);
|
||||||
|
|
|
@ -842,6 +842,19 @@ void CONTROL_GetInput(ControlInfo *info)
|
||||||
inputchecked = 1;
|
inputchecked = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void CONTROL_ResetJoystickValues()
|
||||||
|
{
|
||||||
|
CONTROL_NumJoyAxes = min(MAXJOYAXES, joystick.numAxes);
|
||||||
|
CONTROL_NumJoyButtons = min(MAXJOYBUTTONS, joystick.numButtons + 4 * (joystick.numHats > 0));
|
||||||
|
CONTROL_JoystickEnabled = CONTROL_JoyPresent = !!((inputdevices & 4) >> 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CONTROL_ScanForControllers()
|
||||||
|
{
|
||||||
|
joyScanDevices();
|
||||||
|
CONTROL_ResetJoystickValues();
|
||||||
|
}
|
||||||
|
|
||||||
bool CONTROL_Startup(controltype which, int32_t(*TimeFunction)(void), int32_t ticspersecond)
|
bool CONTROL_Startup(controltype which, int32_t(*TimeFunction)(void), int32_t ticspersecond)
|
||||||
{
|
{
|
||||||
UNREFERENCED_PARAMETER(which);
|
UNREFERENCED_PARAMETER(which);
|
||||||
|
@ -866,9 +879,7 @@ bool CONTROL_Startup(controltype which, int32_t(*TimeFunction)(void), int32_t ti
|
||||||
CONTROL_MousePresent = Mouse_Init();
|
CONTROL_MousePresent = Mouse_Init();
|
||||||
CONTROL_MouseEnabled = CONTROL_MousePresent;
|
CONTROL_MouseEnabled = CONTROL_MousePresent;
|
||||||
|
|
||||||
CONTROL_NumJoyAxes = min(MAXJOYAXES, joystick.numAxes);
|
CONTROL_ResetJoystickValues();
|
||||||
CONTROL_NumJoyButtons = min(MAXJOYBUTTONS, joystick.numButtons + 4 * (joystick.numHats > 0));
|
|
||||||
CONTROL_JoystickEnabled = CONTROL_JoyPresent = !!((inputdevices & 4) >> 2);
|
|
||||||
|
|
||||||
#ifdef GEKKO
|
#ifdef GEKKO
|
||||||
if (CONTROL_MousePresent)
|
if (CONTROL_MousePresent)
|
||||||
|
|
Loading…
Reference in a new issue