mirror of
https://github.com/Relintai/sdl2_frt.git
synced 2025-01-22 01:57:18 +01:00
Added support for wireless Xbox 360 controllers using the HIDAPI driver
This commit is contained in:
parent
e7f7e3f40f
commit
15d30298cf
@ -255,17 +255,16 @@ public class HIDDeviceManager {
|
|||||||
if (usbInterface.getInterfaceClass() == UsbConstants.USB_CLASS_HID) {
|
if (usbInterface.getInterfaceClass() == UsbConstants.USB_CLASS_HID) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (interface_number == 0) {
|
if (isXbox360Controller(usbDevice, usbInterface) || isXboxOneController(usbDevice, usbInterface)) {
|
||||||
if (isXbox360Controller(usbDevice, usbInterface) || isXboxOneController(usbDevice, usbInterface)) {
|
return true;
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isXbox360Controller(UsbDevice usbDevice, UsbInterface usbInterface) {
|
private boolean isXbox360Controller(UsbDevice usbDevice, UsbInterface usbInterface) {
|
||||||
final int XB360_IFACE_SUBCLASS = 93;
|
final int XB360_IFACE_SUBCLASS = 93;
|
||||||
final int XB360_IFACE_PROTOCOL = 1; // Wired only
|
final int XB360_IFACE_PROTOCOL = 1; // Wired
|
||||||
|
final int XB360W_IFACE_PROTOCOL = 129; // Wireless
|
||||||
final int[] SUPPORTED_VENDORS = {
|
final int[] SUPPORTED_VENDORS = {
|
||||||
0x0079, // GPD Win 2
|
0x0079, // GPD Win 2
|
||||||
0x044f, // Thrustmaster
|
0x044f, // Thrustmaster
|
||||||
@ -290,10 +289,10 @@ public class HIDDeviceManager {
|
|||||||
0x24c6, // PowerA
|
0x24c6, // PowerA
|
||||||
};
|
};
|
||||||
|
|
||||||
if (usbInterface.getId() == 0 &&
|
if (usbInterface.getInterfaceClass() == UsbConstants.USB_CLASS_VENDOR_SPEC &&
|
||||||
usbInterface.getInterfaceClass() == UsbConstants.USB_CLASS_VENDOR_SPEC &&
|
|
||||||
usbInterface.getInterfaceSubclass() == XB360_IFACE_SUBCLASS &&
|
usbInterface.getInterfaceSubclass() == XB360_IFACE_SUBCLASS &&
|
||||||
usbInterface.getInterfaceProtocol() == XB360_IFACE_PROTOCOL) {
|
(usbInterface.getInterfaceProtocol() == XB360_IFACE_PROTOCOL ||
|
||||||
|
usbInterface.getInterfaceProtocol() == XB360W_IFACE_PROTOCOL)) {
|
||||||
int vendor_id = usbDevice.getVendorId();
|
int vendor_id = usbDevice.getVendorId();
|
||||||
for (int supportedVid : SUPPORTED_VENDORS) {
|
for (int supportedVid : SUPPORTED_VENDORS) {
|
||||||
if (vendor_id == supportedVid) {
|
if (vendor_id == supportedVid) {
|
||||||
|
@ -481,7 +481,8 @@ int HID_API_EXPORT hid_exit(void)
|
|||||||
static int is_xbox360(unsigned short vendor_id, const struct libusb_interface_descriptor *intf_desc)
|
static int is_xbox360(unsigned short vendor_id, const struct libusb_interface_descriptor *intf_desc)
|
||||||
{
|
{
|
||||||
static const int XB360_IFACE_SUBCLASS = 93;
|
static const int XB360_IFACE_SUBCLASS = 93;
|
||||||
static const int XB360_IFACE_PROTOCOL = 1; /* Wired only */
|
static const int XB360_IFACE_PROTOCOL = 1; /* Wired */
|
||||||
|
static const int XB360W_IFACE_PROTOCOL = 129; /* Wireless */
|
||||||
static const int SUPPORTED_VENDORS[] = {
|
static const int SUPPORTED_VENDORS[] = {
|
||||||
0x0079, /* GPD Win 2 */
|
0x0079, /* GPD Win 2 */
|
||||||
0x044f, /* Thrustmaster */
|
0x044f, /* Thrustmaster */
|
||||||
@ -506,10 +507,10 @@ static int is_xbox360(unsigned short vendor_id, const struct libusb_interface_de
|
|||||||
0x24c6, /* PowerA */
|
0x24c6, /* PowerA */
|
||||||
};
|
};
|
||||||
|
|
||||||
if (intf_desc->bInterfaceNumber == 0 &&
|
if (intf_desc->bInterfaceClass == LIBUSB_CLASS_VENDOR_SPEC &&
|
||||||
intf_desc->bInterfaceClass == LIBUSB_CLASS_VENDOR_SPEC &&
|
|
||||||
intf_desc->bInterfaceSubClass == XB360_IFACE_SUBCLASS &&
|
intf_desc->bInterfaceSubClass == XB360_IFACE_SUBCLASS &&
|
||||||
intf_desc->bInterfaceProtocol == XB360_IFACE_PROTOCOL) {
|
(intf_desc->bInterfaceProtocol == XB360_IFACE_PROTOCOL ||
|
||||||
|
intf_desc->bInterfaceProtocol == XB360W_IFACE_PROTOCOL)) {
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < sizeof(SUPPORTED_VENDORS)/sizeof(SUPPORTED_VENDORS[0]); ++i) {
|
for (i = 0; i < sizeof(SUPPORTED_VENDORS)/sizeof(SUPPORTED_VENDORS[0]); ++i) {
|
||||||
if (vendor_id == SUPPORTED_VENDORS[i]) {
|
if (vendor_id == SUPPORTED_VENDORS[i]) {
|
||||||
|
@ -169,7 +169,7 @@ static const ControllerDescription_t arrControllers[] = {
|
|||||||
{ MAKE_CONTROLLER_ID( 0x044f, 0xb326 ), k_eControllerType_XBox360Controller, NULL }, // Thrustmaster Gamepad GP XID
|
{ MAKE_CONTROLLER_ID( 0x044f, 0xb326 ), k_eControllerType_XBox360Controller, NULL }, // Thrustmaster Gamepad GP XID
|
||||||
{ MAKE_CONTROLLER_ID( 0x045e, 0x028e ), k_eControllerType_XBox360Controller, "Xbox 360 Controller" }, // Microsoft X-Box 360 pad
|
{ MAKE_CONTROLLER_ID( 0x045e, 0x028e ), k_eControllerType_XBox360Controller, "Xbox 360 Controller" }, // Microsoft X-Box 360 pad
|
||||||
{ MAKE_CONTROLLER_ID( 0x045e, 0x028f ), k_eControllerType_XBox360Controller, "Xbox 360 Controller" }, // Microsoft X-Box 360 pad v2
|
{ MAKE_CONTROLLER_ID( 0x045e, 0x028f ), k_eControllerType_XBox360Controller, "Xbox 360 Controller" }, // Microsoft X-Box 360 pad v2
|
||||||
{ MAKE_CONTROLLER_ID( 0x045e, 0x0291 ), k_eControllerType_XBox360Controller, NULL }, // Xbox 360 Wireless Receiver (XBOX)
|
{ MAKE_CONTROLLER_ID( 0x045e, 0x0291 ), k_eControllerType_XBox360Controller, "Xbox 360 Wireless Controller" }, // Xbox 360 Wireless Receiver (XBOX)
|
||||||
{ MAKE_CONTROLLER_ID( 0x045e, 0x02a0 ), k_eControllerType_XBox360Controller, NULL }, // Microsoft X-Box 360 Big Button IR
|
{ MAKE_CONTROLLER_ID( 0x045e, 0x02a0 ), k_eControllerType_XBox360Controller, NULL }, // Microsoft X-Box 360 Big Button IR
|
||||||
{ MAKE_CONTROLLER_ID( 0x045e, 0x02a1 ), k_eControllerType_XBox360Controller, NULL }, // Microsoft X-Box 360 pad
|
{ MAKE_CONTROLLER_ID( 0x045e, 0x02a1 ), k_eControllerType_XBox360Controller, NULL }, // Microsoft X-Box 360 pad
|
||||||
{ MAKE_CONTROLLER_ID( 0x045e, 0x0719 ), k_eControllerType_XBox360Controller, "Xbox 360 Wireless Controller" }, // Xbox 360 Wireless Receiver
|
{ MAKE_CONTROLLER_ID( 0x045e, 0x0719 ), k_eControllerType_XBox360Controller, "Xbox 360 Wireless Controller" }, // Xbox 360 Wireless Receiver
|
||||||
|
@ -69,6 +69,7 @@ static SDL_HIDAPI_DeviceDriver *SDL_HIDAPI_drivers[] = {
|
|||||||
#endif
|
#endif
|
||||||
#ifdef SDL_JOYSTICK_HIDAPI_XBOX360
|
#ifdef SDL_JOYSTICK_HIDAPI_XBOX360
|
||||||
&SDL_HIDAPI_DriverXbox360,
|
&SDL_HIDAPI_DriverXbox360,
|
||||||
|
&SDL_HIDAPI_DriverXbox360W,
|
||||||
#endif
|
#endif
|
||||||
#ifdef SDL_JOYSTICK_HIDAPI_XBOXONE
|
#ifdef SDL_JOYSTICK_HIDAPI_XBOXONE
|
||||||
&SDL_HIDAPI_DriverXboxOne,
|
&SDL_HIDAPI_DriverXboxOne,
|
||||||
|
@ -93,6 +93,7 @@ extern SDL_HIDAPI_DeviceDriver SDL_HIDAPI_DriverPS4;
|
|||||||
extern SDL_HIDAPI_DeviceDriver SDL_HIDAPI_DriverSteam;
|
extern SDL_HIDAPI_DeviceDriver SDL_HIDAPI_DriverSteam;
|
||||||
extern SDL_HIDAPI_DeviceDriver SDL_HIDAPI_DriverSwitch;
|
extern SDL_HIDAPI_DeviceDriver SDL_HIDAPI_DriverSwitch;
|
||||||
extern SDL_HIDAPI_DeviceDriver SDL_HIDAPI_DriverXbox360;
|
extern SDL_HIDAPI_DeviceDriver SDL_HIDAPI_DriverXbox360;
|
||||||
|
extern SDL_HIDAPI_DeviceDriver SDL_HIDAPI_DriverXbox360W;
|
||||||
extern SDL_HIDAPI_DeviceDriver SDL_HIDAPI_DriverXboxOne;
|
extern SDL_HIDAPI_DeviceDriver SDL_HIDAPI_DriverXboxOne;
|
||||||
|
|
||||||
/* Return true if a HID device is present and supported as a joystick */
|
/* Return true if a HID device is present and supported as a joystick */
|
||||||
|
Loading…
Reference in New Issue
Block a user