فهرست منبع

Wait for input before reconnecting a Bluetooth device

On Windows, the Bluetooth device can remain in a connected state if the controller just shut down. It won't return any errors, but it also won't generate any input reports in this state, so wait until we know for sure that the Bluetooth controller is sending data before letting the application know it's available.
Sam Lantinga 3 سال پیش
والد
کامیت
67db8a9103
3فایلهای تغییر یافته به همراه9 افزوده شده و 3 حذف شده
  1. 3 1
      src/joystick/hidapi/SDL_hidapi_ps4.c
  2. 3 1
      src/joystick/hidapi/SDL_hidapi_ps5.c
  3. 3 1
      src/joystick/hidapi/SDL_hidapi_switch.c

+ 3 - 1
src/joystick/hidapi/SDL_hidapi_ps4.c

@@ -961,7 +961,9 @@ HIDAPI_DriverPS4_UpdateDevice(SDL_HIDAPI_Device *device)
     if (device->num_joysticks == 0 &&
         device->is_bluetooth &&
         !HIDAPI_HasConnectedUSBDevice(device->serial)) {
-        HIDAPI_JoystickConnected(device, NULL);
+        if (SDL_hid_read_timeout(device->dev, data, sizeof(data), 0) > 0) {
+            HIDAPI_JoystickConnected(device, NULL);
+        }
     }
 
     if (device->num_joysticks > 0) {

+ 3 - 1
src/joystick/hidapi/SDL_hidapi_ps5.c

@@ -1269,7 +1269,9 @@ HIDAPI_DriverPS5_UpdateDevice(SDL_HIDAPI_Device *device)
     if (device->num_joysticks == 0 &&
         device->is_bluetooth &&
         !HIDAPI_HasConnectedUSBDevice(device->serial)) {
-        HIDAPI_JoystickConnected(device, NULL);
+        if (SDL_hid_read_timeout(device->dev, data, sizeof(data), 0) > 0) {
+            HIDAPI_JoystickConnected(device, NULL);
+        }
     }
 
     if (device->num_joysticks > 0) {

+ 3 - 1
src/joystick/hidapi/SDL_hidapi_switch.c

@@ -2089,7 +2089,9 @@ HIDAPI_DriverSwitch_UpdateDevice(SDL_HIDAPI_Device *device)
     if (device->num_joysticks == 0 &&
         device->is_bluetooth &&
         !HIDAPI_HasConnectedUSBDevice(device->serial)) {
-        HIDAPI_JoystickConnected(device, NULL);
+        if (ReadInput(ctx) > 0) {
+            HIDAPI_JoystickConnected(device, NULL);
+        }
     }
 
     if (device->num_joysticks > 0) {