Skip to content

Commit

Permalink
Merge pull request #18491 from hrydgard/autoconfigure-pad-nonwindows
Browse files Browse the repository at this point in the history
SDL: Filter duplicate axis events. Fix autoconfigure to not use Xinput on non-Windows
  • Loading branch information
hrydgard committed Dec 8, 2023
2 parents 89c320f + e8c5456 commit c9d5b72
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 9 deletions.
8 changes: 6 additions & 2 deletions Core/KeyMap.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -822,8 +822,12 @@ void AutoConfForPad(const std::string &name) {
SetDefaultKeyMap(DEFAULT_MAPPING_ANDROID_PAD, false);
}
#else
// TODO: Should actually check for XInput?
if (name.find("Xbox") != std::string::npos) {
#if PPSSPP_PLATFORM(WINDOWS)
const bool platformSupportsXinput = true;
#else
const bool platformSupportsXinput = false;
#endif
if (platformSupportsXinput && name.find("Xbox") != std::string::npos) {
SetDefaultKeyMap(DEFAULT_MAPPING_XINPUT, false);
} else {
SetDefaultKeyMap(DEFAULT_MAPPING_PAD, false);
Expand Down
15 changes: 8 additions & 7 deletions Windows/DinputDevice.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -204,12 +204,13 @@ DinputDevice::~DinputDevice() {
}

void SendNativeAxis(InputDeviceID deviceId, int value, int &lastValue, InputAxis axisId) {
AxisInput axis;
axis.deviceId = deviceId;
axis.axisId = axisId;
axis.value = (float)value * (1.0f / 10000.0f); // Convert axis to normalised float
NativeAxis(&axis, 1);

if (value != lastValue) {
AxisInput axis;
axis.deviceId = deviceId;
axis.axisId = axisId;
axis.value = (float)value * (1.0f / 10000.0f); // Convert axis to normalised float
NativeAxis(&axis, 1);
}
lastValue = value;
}

Expand Down Expand Up @@ -286,7 +287,7 @@ void DinputDevice::ApplyButtons(DIJOYSTATE2 &state) {

// Now the POV hat, which can technically go in any degree but usually does not.
if (LOWORD(state.rgdwPOV[0]) != lastPOV_[0]) {
KeyInput dpad[4];
KeyInput dpad[4]{};
for (int i = 0; i < 4; ++i) {
dpad[i].deviceId = DEVICE_ID_PAD_0 + pDevNum;
dpad[i].flags = KEY_UP;
Expand Down

0 comments on commit c9d5b72

Please sign in to comment.