mirror of
https://github.com/Relintai/sdl2_frt.git
synced 2025-01-22 01:57:18 +01:00
4dea340ca7
Jimb Esser Add new RawInput controller API, and improved correlation with XInput/WGI Reorder joystick init so drivers can ask the others if they handle a device reliably Do not poll disconnected XInput devices (major perf issue) Fix various cases where incorrect correlation could happen Simple mechanism for propagating unhandled Guide button presses even before guaranteed correlation Correlate by axis motion as well as button presses Fix failing to zero other trigger Fix SDL_HINT_JOYSTICK_HIDAPI not working if set before calling SDL_Init() Add missing device to device names Disable RawInput if we have a mismatch of XInput-capable but not RawInput-capable devices Updated to SDL 2.0.13 code with the following notes: New HID driver: xbox360w - no idea what that is, hopefully urelated SDL_hidapijoystick.c had been refactored to couple data handling logic with device opening logic and device lists caused some problems, yields slightly uglier integration than previously when the 360 HID device driver was just handling the data. SDL_hidapijoystick.c now often pulls the device off of the joystick_hwdata structure for some rumble logic, but it appears that code path is never reached, so probably not a problem. Looks like joystick_hwdata was refactored to not include a mutex in other drivers, maintainers may want to do the same refactor here if that's useful for some reason. Something changed in how devices get names, so getting generic names. Had to fix a (new?) bug where removing an XInput controller caused existing controllers (that moved to a new XInput index) to get identified as 0x045e/0x02fd ("it's probably Bluetooth" in code), rendering the existing HIDAPI_IsDevicePresent and new RAWINPUT_IsDevicePresent unreliable.
114 lines
5.2 KiB
C
114 lines
5.2 KiB
C
/*
|
|
Simple DirectMedia Layer
|
|
Copyright (C) 1997-2020 Sam Lantinga <slouken@libsdl.org>
|
|
|
|
This software is provided 'as-is', without any express or implied
|
|
warranty. In no event will the authors be held liable for any damages
|
|
arising from the use of this software.
|
|
|
|
Permission is granted to anyone to use this software for any purpose,
|
|
including commercial applications, and to alter it and redistribute it
|
|
freely, subject to the following restrictions:
|
|
|
|
1. The origin of this software must not be misrepresented; you must not
|
|
claim that you wrote the original software. If you use this software
|
|
in a product, an acknowledgment in the product documentation would be
|
|
appreciated but is not required.
|
|
2. Altered source versions must be plainly marked as such, and must not be
|
|
misrepresented as being the original software.
|
|
3. This notice may not be removed or altered from any source distribution.
|
|
*/
|
|
|
|
#ifndef SDL_joystick_c_h_
|
|
#define SDL_joystick_c_h_
|
|
|
|
#include "../SDL_internal.h"
|
|
|
|
/* Useful functions and variables from SDL_joystick.c */
|
|
#include "SDL_gamecontroller.h"
|
|
#include "SDL_joystick.h"
|
|
|
|
struct _SDL_JoystickDriver;
|
|
|
|
/* Initialization and shutdown functions */
|
|
extern int SDL_JoystickInit(void);
|
|
extern void SDL_JoystickQuit(void);
|
|
|
|
/* Function to get the next available joystick instance ID */
|
|
extern SDL_JoystickID SDL_GetNextJoystickInstanceID(void);
|
|
|
|
/* Initialization and shutdown functions */
|
|
extern int SDL_GameControllerInitMappings(void);
|
|
extern void SDL_GameControllerQuitMappings(void);
|
|
extern int SDL_GameControllerInit(void);
|
|
extern void SDL_GameControllerQuit(void);
|
|
|
|
/* Function to get the joystick driver and device index for an API device index */
|
|
extern SDL_bool SDL_GetDriverAndJoystickIndex(int device_index, struct _SDL_JoystickDriver **driver, int *driver_index);
|
|
|
|
/* Function to return the device index for a joystick ID, or -1 if not found */
|
|
extern int SDL_JoystickGetDeviceIndexFromInstanceID(SDL_JoystickID instance_id);
|
|
|
|
/* Function to extract information from an SDL joystick GUID */
|
|
extern void SDL_GetJoystickGUIDInfo(SDL_JoystickGUID guid, Uint16 *vendor, Uint16 *product, Uint16 *version);
|
|
|
|
/* Function to standardize the name for a controller
|
|
This should be freed with SDL_free() when no longer needed
|
|
*/
|
|
extern char *SDL_CreateJoystickName(Uint16 vendor, Uint16 product, const char *vendor_name, const char *product_name);
|
|
|
|
/* Function to return the type of a controller */
|
|
extern SDL_GameControllerType SDL_GetJoystickGameControllerTypeFromGUID(SDL_JoystickGUID guid, const char *name);
|
|
extern SDL_GameControllerType SDL_GetJoystickGameControllerType(const char *name, Uint16 vendor, Uint16 product, int interface_number, int interface_class, int interface_subclass, int interface_protocol);
|
|
|
|
/* Function to return whether a joystick is a Nintendo Switch Pro controller */
|
|
extern SDL_bool SDL_IsJoystickNintendoSwitchProInputOnly(Uint16 vendor_id, Uint16 product_id);
|
|
|
|
/* Function to return whether a joystick is a Steam Controller */
|
|
extern SDL_bool SDL_IsJoystickSteamController(Uint16 vendor_id, Uint16 product_id);
|
|
|
|
/* Function to return whether a joystick guid comes from the XInput driver */
|
|
extern SDL_bool SDL_IsJoystickXInput(SDL_JoystickGUID guid);
|
|
|
|
/* Function to return whether a joystick guid comes from the HIDAPI driver */
|
|
extern SDL_bool SDL_IsJoystickHIDAPI(SDL_JoystickGUID guid);
|
|
|
|
/* Function to return whether a joystick guid comes from the RAWINPUT driver */
|
|
extern SDL_bool SDL_IsJoystickRAWINPUT(SDL_JoystickGUID guid);
|
|
|
|
/* Function to return whether a joystick guid comes from the Virtual driver */
|
|
extern SDL_bool SDL_IsJoystickVirtual(SDL_JoystickGUID guid);
|
|
|
|
/* Function to return whether a joystick should be ignored */
|
|
extern SDL_bool SDL_ShouldIgnoreJoystick(const char *name, SDL_JoystickGUID guid);
|
|
|
|
/* Function to return whether a joystick name and GUID is a game controller */
|
|
extern SDL_bool SDL_IsGameControllerNameAndGUID(const char *name, SDL_JoystickGUID guid);
|
|
|
|
/* Function to return whether a game controller should be ignored */
|
|
extern SDL_bool SDL_ShouldIgnoreGameController(const char *name, SDL_JoystickGUID guid);
|
|
|
|
/* Handle delayed guide button on a game controller */
|
|
extern void SDL_GameControllerHandleDelayedGuideButton(SDL_Joystick *joystick);
|
|
|
|
/* Internal event queueing functions */
|
|
extern void SDL_PrivateJoystickAdded(SDL_JoystickID device_instance);
|
|
extern void SDL_PrivateJoystickRemoved(SDL_JoystickID device_instance);
|
|
extern int SDL_PrivateJoystickAxis(SDL_Joystick * joystick,
|
|
Uint8 axis, Sint16 value);
|
|
extern int SDL_PrivateJoystickBall(SDL_Joystick * joystick,
|
|
Uint8 ball, Sint16 xrel, Sint16 yrel);
|
|
extern int SDL_PrivateJoystickHat(SDL_Joystick * joystick,
|
|
Uint8 hat, Uint8 value);
|
|
extern int SDL_PrivateJoystickButton(SDL_Joystick * joystick,
|
|
Uint8 button, Uint8 state);
|
|
extern void SDL_PrivateJoystickBatteryLevel(SDL_Joystick * joystick,
|
|
SDL_JoystickPowerLevel ePowerLevel);
|
|
|
|
/* Internal sanity checking functions */
|
|
extern SDL_bool SDL_PrivateJoystickValid(SDL_Joystick * joystick);
|
|
|
|
#endif /* SDL_joystick_c_h_ */
|
|
|
|
/* vi: set ts=4 sw=4 expandtab: */
|