mirror of
https://github.com/Relintai/sdl2_frt.git
synced 2025-01-22 01:57:18 +01:00
Fixed Xbox 360 wireless controller being picked up by WGI when it's being managed by RAWINPUT
This commit is contained in:
parent
37c9e4afa3
commit
8a449de20d
@ -674,7 +674,7 @@ EnumJoysticksCallback(const DIDEVICEINSTANCE * pdidInstance, VOID * pContext)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SDL_JOYSTICK_RAWINPUT
|
#ifdef SDL_JOYSTICK_RAWINPUT
|
||||||
if (RAWINPUT_IsDevicePresent(vendor, product, 0)) {
|
if (RAWINPUT_IsDevicePresent(vendor, product, 0, pNewJoystick->joystickname)) {
|
||||||
/* The RAWINPUT driver is taking care of this device */
|
/* The RAWINPUT driver is taking care of this device */
|
||||||
SDL_free(pNewJoystick);
|
SDL_free(pNewJoystick);
|
||||||
return DIENUM_CONTINUE;
|
return DIENUM_CONTINUE;
|
||||||
|
@ -923,7 +923,7 @@ RAWINPUT_IsEnabled()
|
|||||||
}
|
}
|
||||||
|
|
||||||
SDL_bool
|
SDL_bool
|
||||||
RAWINPUT_IsDevicePresent(Uint16 vendor_id, Uint16 product_id, Uint16 version)
|
RAWINPUT_IsDevicePresent(Uint16 vendor_id, Uint16 product_id, Uint16 version, const char *name)
|
||||||
{
|
{
|
||||||
SDL_RAWINPUT_Device *device;
|
SDL_RAWINPUT_Device *device;
|
||||||
|
|
||||||
@ -932,9 +932,16 @@ RAWINPUT_IsDevicePresent(Uint16 vendor_id, Uint16 product_id, Uint16 version)
|
|||||||
|
|
||||||
device = SDL_RAWINPUT_devices;
|
device = SDL_RAWINPUT_devices;
|
||||||
while (device) {
|
while (device) {
|
||||||
if (device->vendor_id == vendor_id && device->product_id == product_id) {
|
if (vendor_id == device->vendor_id && product_id == device->product_id ) {
|
||||||
return SDL_TRUE;
|
return SDL_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* The Xbox 360 wireless controller shows up as product 0 in WGI */
|
||||||
|
if (vendor_id == device->vendor_id && product_id == 0 &&
|
||||||
|
name && SDL_strstr(device->name, name) != NULL) {
|
||||||
|
return SDL_TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
device = device->next;
|
device = device->next;
|
||||||
}
|
}
|
||||||
return SDL_FALSE;
|
return SDL_FALSE;
|
||||||
|
@ -25,7 +25,7 @@
|
|||||||
extern SDL_bool RAWINPUT_IsEnabled();
|
extern SDL_bool RAWINPUT_IsEnabled();
|
||||||
|
|
||||||
/* Return true if a RawInput device is present and supported as a joystick */
|
/* Return true if a RawInput device is present and supported as a joystick */
|
||||||
extern SDL_bool RAWINPUT_IsDevicePresent(Uint16 vendor_id, Uint16 product_id, Uint16 version);
|
extern SDL_bool RAWINPUT_IsDevicePresent(Uint16 vendor_id, Uint16 product_id, Uint16 version, const char *name);
|
||||||
|
|
||||||
/* Returns 0 if message was handled */
|
/* Returns 0 if message was handled */
|
||||||
extern LRESULT RAWINPUT_WindowProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
extern LRESULT RAWINPUT_WindowProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
|
@ -249,7 +249,7 @@ static HRESULT STDMETHODCALLTYPE IEventHandler_CRawGameControllerVtbl_InvokeAdde
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SDL_JOYSTICK_RAWINPUT
|
#ifdef SDL_JOYSTICK_RAWINPUT
|
||||||
if (!ignore_joystick && RAWINPUT_IsDevicePresent(vendor, product, version)) {
|
if (!ignore_joystick && RAWINPUT_IsDevicePresent(vendor, product, version, name)) {
|
||||||
ignore_joystick = SDL_TRUE;
|
ignore_joystick = SDL_TRUE;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -302,7 +302,7 @@ AddXInputDevice(Uint8 userid, BYTE SubType, JoyStick_DeviceData **pContext)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SDL_JOYSTICK_RAWINPUT
|
#ifdef SDL_JOYSTICK_RAWINPUT
|
||||||
if (RAWINPUT_IsDevicePresent(vendor, product, version)) {
|
if (RAWINPUT_IsDevicePresent(vendor, product, version, pNewJoystick->joystickname)) {
|
||||||
/* The RAWINPUT driver is taking care of this device */
|
/* The RAWINPUT driver is taking care of this device */
|
||||||
SDL_free(pNewJoystick);
|
SDL_free(pNewJoystick);
|
||||||
return;
|
return;
|
||||||
|
Loading…
Reference in New Issue
Block a user