aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorRay <raysan5@gmail.com>2019-04-28 18:12:36 +0200
committerGitHub <noreply@github.com>2019-04-28 18:12:36 +0200
commitfc6186a6323029d24ae37b9838fbb509b5aa01f9 (patch)
tree43d9489e5c3d2eb248920819090fca454014f0ee /src
parent40940f439860b3345198dc44cd493f0c0dc12f7c (diff)
parenta51f3be38fe8dea4b3220e4071ebd826a2090c1c (diff)
downloadraylib-fc6186a6323029d24ae37b9838fbb509b5aa01f9.tar.gz
raylib-fc6186a6323029d24ae37b9838fbb509b5aa01f9.zip
Merge pull request #821 from NerdThings/gamepad-rework
Gamepad Rework
Diffstat (limited to 'src')
-rw-r--r--src/core.c141
-rw-r--r--src/raylib.h128
2 files changed, 172 insertions, 97 deletions
diff --git a/src/core.c b/src/core.c
index 1273a057..8bff8245 100644
--- a/src/core.c
+++ b/src/core.c
@@ -3081,6 +3081,97 @@ static bool GetMouseButtonStatus(int button)
#endif
}
+static GamepadButton GetGamepadButton(int button)
+{
+ GamepadButton b = GAMEPAD_BUTTON_UNKNOWN;
+#if defined(PLATFORM_DESKTOP)
+ switch (button)
+ {
+ case GLFW_GAMEPAD_BUTTON_Y: b = GAMEPAD_BUTTON_RIGHT_FACE_UP; break;
+ case GLFW_GAMEPAD_BUTTON_B: b = GAMEPAD_BUTTON_RIGHT_FACE_RIGHT; break;
+ case GLFW_GAMEPAD_BUTTON_A: b = GAMEPAD_BUTTON_RIGHT_FACE_DOWN; break;
+ case GLFW_GAMEPAD_BUTTON_X: b = GAMEPAD_BUTTON_RIGHT_FACE_LEFT; break;
+
+ case GLFW_GAMEPAD_BUTTON_LEFT_BUMPER: b = GAMEPAD_BUTTON_LEFT_TRIGGER_1; break;
+ case GLFW_GAMEPAD_BUTTON_RIGHT_BUMPER: b = GAMEPAD_BUTTON_RIGHT_TRIGGER_1; break;
+
+ case GLFW_GAMEPAD_BUTTON_BACK: b = GAMEPAD_BUTTON_MIDDLE_LEFT; break;
+ case GLFW_GAMEPAD_BUTTON_GUIDE: b = GAMEPAD_BUTTON_MIDDLE; break;
+ case GLFW_GAMEPAD_BUTTON_START: b = GAMEPAD_BUTTON_MIDDLE_RIGHT; break;
+
+ case GLFW_GAMEPAD_BUTTON_DPAD_UP: b = GAMEPAD_BUTTON_LEFT_FACE_UP; break;
+ case GLFW_GAMEPAD_BUTTON_DPAD_RIGHT: b = GAMEPAD_BUTTON_LEFT_FACE_RIGHT; break;
+ case GLFW_GAMEPAD_BUTTON_DPAD_DOWN: b = GAMEPAD_BUTTON_LEFT_FACE_DOWN; break;
+ case GLFW_GAMEPAD_BUTTON_DPAD_LEFT: b = GAMEPAD_BUTTON_LEFT_FACE_LEFT; break;
+
+ case GLFW_GAMEPAD_BUTTON_LEFT_THUMB: b = GAMEPAD_BUTTON_LEFT_THUMB; break;
+ case GLFW_GAMEPAD_BUTTON_RIGHT_THUMB: b = GAMEPAD_BUTTON_RIGHT_THUMB; break;
+ }
+#endif
+
+#if defined(PLATFORM_UWP)
+ b = button; // UWP will provide the correct button
+#endif
+
+#if defined(PLATFORM_WEB)
+ // https://www.w3.org/TR/gamepad/#gamepad-interface
+ switch (button)
+ {
+ case 0: b = GAMEPAD_BUTTON_RIGHT_FACE_DOWN; break;
+ case 1: b = GAMEPAD_BUTTON_RIGHT_FACE_RIGHT; break;
+ case 2: b = GAMEPAD_BUTTON_RIGHT_FACE_LEFT; break;
+ case 3: b = GAMEPAD_BUTTON_RIGHT_FACE_UP; break;
+ case 4: b = GAMEPAD_BUTTON_LEFT_TRIGGER_1; break;
+ case 5: b = GAMEPAD_BUTTON_RIGHT_TRIGGER_1; break;
+ case 6: b = GAMEPAD_BUTTON_LEFT_TRIGGER_2; break;
+ case 7: b = GAMEPAD_BUTTON_RIGHT_TRIGGER_2; break;
+ case 8: b = GAMEPAD_BUTTON_MIDDLE_LEFT; break;
+ case 9: b = GAMEPAD_BUTTON_MIDDLE_RIGHT; break;
+ case 10: b = GAMEPAD_BUTTON_LEFT_THUMB; break;
+ case 11: b = GAMEPAD_BUTTON_RIGHT_THUMB; break;
+ case 12: b = GAMEPAD_BUTTON_LEFT_FACE_UP; break;
+ case 13: b = GAMEPAD_BUTTON_LEFT_FACE_DOWN; break;
+ case 14: b = GAMEPAD_BUTTON_LEFT_FACE_LEFT; break;
+ case 15: b = GAMEPAD_BUTTON_LEFT_FACE_RIGHT; break;
+ }
+#endif
+
+ return b;
+}
+
+static GamepadAxis GetGamepadAxis(int axis)
+{
+ GamepadAxis a = GAMEPAD_AXIS_UNKNOWN;
+#if defined(PLATFORM_DESKTOP)
+ switch(axis)
+ {
+ case GLFW_GAMEPAD_AXIS_LEFT_X: a = GAMEPAD_AXIS_LEFT_X; break;
+ case GLFW_GAMEPAD_AXIS_LEFT_Y: a = GAMEPAD_AXIS_LEFT_Y; break;
+ case GLFW_GAMEPAD_AXIS_RIGHT_X: a = GAMEPAD_AXIS_RIGHT_X; break;
+ case GLFW_GAMEPAD_AXIS_RIGHT_Y: a = GAMEPAD_AXIS_RIGHT_Y; break;
+ case GLFW_GAMEPAD_AXIS_LEFT_TRIGGER: a = GAMEPAD_AXIS_LEFT_TRIGGER; break;
+ case GLFW_GAMEPAD_AXIS_RIGHT_TRIGGER: a = GAMEPAD_AXIS_RIGHT_TRIGGER; break;
+ }
+#endif
+
+#if defined(PLATFORM_UWP)
+ a = axis; // UWP will provide the correct axis
+#endif
+
+#if defined(PLATFORM_WEB)
+ // https://www.w3.org/TR/gamepad/#gamepad-interface
+ switch(axis)
+ {
+ case 0: a = GAMEPAD_AXIS_LEFT_X;
+ case 1: a = GAMEPAD_AXIS_LEFT_Y;
+ case 2: a = GAMEPAD_AXIS_RIGHT_X;
+ case 3: a = GAMEPAD_AXIS_RIGHT_X;
+ }
+#endif
+
+ return a;
+}
+
// Poll (store) all input events
static void PollInputEvents(void)
{
@@ -3232,6 +3323,10 @@ static void PollInputEvents(void)
case UWP_MSG_SET_GAMEPAD_AXIS:
{
if ((msg->paramInt0 < MAX_GAMEPADS) && (msg->paramInt1 < MAX_GAMEPAD_AXIS)) gamepadAxisState[msg->paramInt0][msg->paramInt1] = msg->paramFloat0;
+
+ // Register buttons for 2nd triggers
+ currentGamepadState[msg->paramInt0][GAMEPAD_BUTTON_LEFT_TRIGGER_2] = (char)(gamepadAxisState[msg->paramInt0][GAMEPAD_AXIS_LEFT_TRIGGER] > 0.1);
+ currentGamepadState[msg->paramInt0][GAMEPAD_BUTTON_RIGHT_TRIGGER_2] = (char)(gamepadAxisState[msg->paramInt0][GAMEPAD_AXIS_RIGHT_TRIGGER] > 0.1);
} break;
case UWP_MSG_SET_DISPLAY_DIMS:
{
@@ -3295,7 +3390,7 @@ static void PollInputEvents(void)
#if defined(PLATFORM_DESKTOP)
// Check if gamepads are ready
- // NOTE: We do it here in case of disconection
+ // NOTE: We do it here in case of disconnection
for (int i = 0; i < MAX_GAMEPADS; i++)
{
if (glfwJoystickPresent(i)) gamepadReady[i] = true;
@@ -3312,33 +3407,37 @@ static void PollInputEvents(void)
// Get current gamepad state
// NOTE: There is no callback available, so we get it manually
- const unsigned char *buttons;
- int buttonsCount;
-
- buttons = glfwGetJoystickButtons(i, &buttonsCount);
+ // Get remapped buttons
+ GLFWgamepadstate state;
+ glfwGetGamepadState(i, &state); // This remapps all gamepads so they have their buttons mapped like an xbox controller
+ const unsigned char *buttons = state.buttons;
- for (int k = 0; (buttons != NULL) && (k < buttonsCount) && (buttonsCount < MAX_GAMEPAD_BUTTONS); k++)
+ for (int k = 0; (buttons != NULL) && (k < GLFW_GAMEPAD_BUTTON_DPAD_LEFT + 1) && (k < MAX_GAMEPAD_BUTTONS); k++)
{
+ const GamepadButton button = GetGamepadButton(k);
+
if (buttons[k] == GLFW_PRESS)
{
- currentGamepadState[i][k] = 1;
- lastGamepadButtonPressed = k;
+ currentGamepadState[i][button] = 1;
+ lastGamepadButtonPressed = button;
}
- else currentGamepadState[i][k] = 0;
+ else currentGamepadState[i][button] = 0;
}
// Get current axis state
- const float *axes;
- int axisCount = 0;
+ const float *axes = state.axes;
- axes = glfwGetJoystickAxes(i, &axisCount);
-
- for (int k = 0; (axes != NULL) && (k < axisCount) && (k < MAX_GAMEPAD_AXIS); k++)
+ for (int k = 0; (axes != NULL) && (k < GLFW_GAMEPAD_AXIS_LAST + 1) && (k < MAX_GAMEPAD_AXIS); k++)
{
- gamepadAxisState[i][k] = axes[k];
+ const GamepadAxis axis = GetGamepadAxis(k);
+ gamepadAxisState[i][axis] = axes[k];
}
- gamepadAxisCount = axisCount;
+ // Register buttons for 2nd triggers (because GLFW doesn't count these as buttons but rather axis)
+ currentGamepadState[i][GAMEPAD_BUTTON_LEFT_TRIGGER_2] = (char)(gamepadAxisState[i][GAMEPAD_AXIS_LEFT_TRIGGER] > 0.1);
+ currentGamepadState[i][GAMEPAD_BUTTON_RIGHT_TRIGGER_2] = (char)(gamepadAxisState[i][GAMEPAD_AXIS_RIGHT_TRIGGER] > 0.1);
+
+ gamepadAxisCount = GLFW_GAMEPAD_AXIS_LAST;
}
}
@@ -3372,12 +3471,13 @@ static void PollInputEvents(void)
// Register buttons data for every connected gamepad
for (int j = 0; (j < gamepadState.numButtons) && (j < MAX_GAMEPAD_BUTTONS); j++)
{
+ const GamepadButton button = GetGamepadButton(j);
if (gamepadState.digitalButton[j] == 1)
{
- currentGamepadState[i][j] = 1;
- lastGamepadButtonPressed = j;
+ currentGamepadState[i][button] = 1;
+ lastGamepadButtonPressed = button;
}
- else currentGamepadState[i][j] = 0;
+ else currentGamepadState[i][button] = 0;
//TraceLog(LOG_DEBUG, "Gamepad %d, button %d: Digital: %d, Analog: %g", gamepadState.index, j, gamepadState.digitalButton[j], gamepadState.analogButton[j]);
}
@@ -3385,7 +3485,8 @@ static void PollInputEvents(void)
// Register axis data for every connected gamepad
for (int j = 0; (j < gamepadState.numAxes) && (j < MAX_GAMEPAD_AXIS); j++)
{
- gamepadAxisState[i][j] = gamepadState.axis[j];
+ const GamepadAxis axis = GetGamepadAxis(j);
+ gamepadAxisState[i][axis] = gamepadState.axis[j];
}
gamepadAxisCount = gamepadState.numAxes;
diff --git a/src/raylib.h b/src/raylib.h
index c1cebdc8..dfbebf90 100644
--- a/src/raylib.h
+++ b/src/raylib.h
@@ -619,83 +619,57 @@ typedef enum {
GAMEPAD_PLAYER4 = 3
} GamepadNumber;
-// PS3 USB Controller Buttons
-// TODO: Provide a generic way to list gamepad controls schemes,
-// defining specific controls schemes is not a good option
-typedef enum {
- GAMEPAD_PS3_BUTTON_TRIANGLE = 0,
- GAMEPAD_PS3_BUTTON_CIRCLE = 1,
- GAMEPAD_PS3_BUTTON_CROSS = 2,
- GAMEPAD_PS3_BUTTON_SQUARE = 3,
- GAMEPAD_PS3_BUTTON_L1 = 6,
- GAMEPAD_PS3_BUTTON_R1 = 7,
- GAMEPAD_PS3_BUTTON_L2 = 4,
- GAMEPAD_PS3_BUTTON_R2 = 5,
- GAMEPAD_PS3_BUTTON_START = 8,
- GAMEPAD_PS3_BUTTON_SELECT = 9,
- GAMEPAD_PS3_BUTTON_PS = 12,
- GAMEPAD_PS3_BUTTON_UP = 24,
- GAMEPAD_PS3_BUTTON_RIGHT = 25,
- GAMEPAD_PS3_BUTTON_DOWN = 26,
- GAMEPAD_PS3_BUTTON_LEFT = 27
-} GamepadPS3Button;
-
-// PS3 USB Controller Axis
-typedef enum {
- GAMEPAD_PS3_AXIS_LEFT_X = 0,
- GAMEPAD_PS3_AXIS_LEFT_Y = 1,
- GAMEPAD_PS3_AXIS_RIGHT_X = 2,
- GAMEPAD_PS3_AXIS_RIGHT_Y = 5,
- GAMEPAD_PS3_AXIS_L2 = 3, // [1..-1] (pressure-level)
- GAMEPAD_PS3_AXIS_R2 = 4 // [1..-1] (pressure-level)
-} GamepadPS3Axis;
-
-// Xbox360 USB Controller Buttons
-typedef enum {
- GAMEPAD_XBOX_BUTTON_A = 0,
- GAMEPAD_XBOX_BUTTON_B = 1,
- GAMEPAD_XBOX_BUTTON_X = 2,
- GAMEPAD_XBOX_BUTTON_Y = 3,
- GAMEPAD_XBOX_BUTTON_LB = 4,
- GAMEPAD_XBOX_BUTTON_RB = 5,
- GAMEPAD_XBOX_BUTTON_SELECT = 6,
- GAMEPAD_XBOX_BUTTON_START = 7,
- GAMEPAD_XBOX_BUTTON_HOME = 8,
- GAMEPAD_XBOX_BUTTON_UP = 10,
- GAMEPAD_XBOX_BUTTON_RIGHT = 11,
- GAMEPAD_XBOX_BUTTON_DOWN = 12,
- GAMEPAD_XBOX_BUTTON_LEFT = 13
-} GamepadXbox360Button;
-
-// Xbox360 USB Controller Axis,
-// NOTE: For Raspberry Pi, axis must be reconfigured
-typedef enum {
- GAMEPAD_XBOX_AXIS_LEFT_X = 0, // [-1..1] (left->right)
- GAMEPAD_XBOX_AXIS_LEFT_Y = 1, // [1..-1] (up->down)
- GAMEPAD_XBOX_AXIS_RIGHT_X = 2, // [-1..1] (left->right)
- GAMEPAD_XBOX_AXIS_RIGHT_Y = 3, // [1..-1] (up->down)
- GAMEPAD_XBOX_AXIS_LT = 4, // [-1..1] (pressure-level)
- GAMEPAD_XBOX_AXIS_RT = 5 // [-1..1] (pressure-level)
-} GamepadXbox360Axis;
-
-// Android Gamepad Controller (SNES CLASSIC)
-typedef enum {
- GAMEPAD_ANDROID_DPAD_UP = 19,
- GAMEPAD_ANDROID_DPAD_DOWN = 20,
- GAMEPAD_ANDROID_DPAD_LEFT = 21,
- GAMEPAD_ANDROID_DPAD_RIGHT = 22,
- GAMEPAD_ANDROID_DPAD_CENTER = 23,
- GAMEPAD_ANDROID_BUTTON_A = 96,
- GAMEPAD_ANDROID_BUTTON_B = 97,
- GAMEPAD_ANDROID_BUTTON_C = 98,
- GAMEPAD_ANDROID_BUTTON_X = 99,
- GAMEPAD_ANDROID_BUTTON_Y = 100,
- GAMEPAD_ANDROID_BUTTON_Z = 101,
- GAMEPAD_ANDROID_BUTTON_L1 = 102,
- GAMEPAD_ANDROID_BUTTON_R1 = 103,
- GAMEPAD_ANDROID_BUTTON_L2 = 104,
- GAMEPAD_ANDROID_BUTTON_R2 = 105
-} GamepadAndroid;
+// Gamepad Buttons
+typedef enum
+{
+ // This is here just for error checking
+ GAMEPAD_BUTTON_UNKNOWN = 0,
+
+ // This is normally ABXY/Circle, Triangle, Square, Cross. No support for 6 button controllers though..
+ GAMEPAD_BUTTON_LEFT_FACE_UP,
+ GAMEPAD_BUTTON_LEFT_FACE_RIGHT,
+ GAMEPAD_BUTTON_LEFT_FACE_DOWN,
+ GAMEPAD_BUTTON_LEFT_FACE_LEFT,
+
+ // This is normally a DPAD
+ GAMEPAD_BUTTON_RIGHT_FACE_UP,
+ GAMEPAD_BUTTON_RIGHT_FACE_RIGHT,
+ GAMEPAD_BUTTON_RIGHT_FACE_DOWN,
+ GAMEPAD_BUTTON_RIGHT_FACE_LEFT,
+
+ // Triggers
+ GAMEPAD_BUTTON_LEFT_TRIGGER_1,
+ GAMEPAD_BUTTON_LEFT_TRIGGER_2,
+ GAMEPAD_BUTTON_RIGHT_TRIGGER_1,
+ GAMEPAD_BUTTON_RIGHT_TRIGGER_2,
+
+ // These are buttons in the center of the gamepad
+ GAMEPAD_BUTTON_MIDDLE_LEFT, //PS3 Select
+ GAMEPAD_BUTTON_MIDDLE, //PS Button/XBOX Button
+ GAMEPAD_BUTTON_MIDDLE_RIGHT, //PS3 Start
+
+ // These are the joystick press in buttons
+ GAMEPAD_BUTTON_LEFT_THUMB,
+ GAMEPAD_BUTTON_RIGHT_THUMB
+} GamepadButton;
+
+typedef enum
+{
+ // This is here just for error checking
+ GAMEPAD_AXIS_UNKNOWN = 0,
+
+ // Left stick
+ GAMEPAD_AXIS_LEFT_X,
+ GAMEPAD_AXIS_LEFT_Y,
+
+ // Right stick
+ GAMEPAD_AXIS_RIGHT_X,
+ GAMEPAD_AXIS_RIGHT_Y,
+
+ // Pressure levels for the back triggers
+ GAMEPAD_AXIS_LEFT_TRIGGER, // [1..-1] (pressure-level)
+ GAMEPAD_AXIS_RIGHT_TRIGGER // [1..-1] (pressure-level)
+} GamepadAxis;
// Shader location point type
typedef enum {