mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-12 09:09:12 +01:00
fcd5170cff
Disclaimer: I can't test if this works on xbox one controllers, i don't have one. But i have conformed that this UpdateMotors() is related to rumble for emulated wiimotes. This partially reverts commit "XInput: Apply immediately as well" (1958a10b6f5ba8348268b077f6410dadb2a20c8f) from pr # https://github.com/dolphin-emu/dolphin/pull/1560 Hopefully this fixes the xbox one controller rumble issue: https://bugs.dolphin-emu.org/issues/9071 And in theory it might reduce the used usb bandwidth, as it was originally intended before pr 1560. @JMC47: Please do a good amount of testing, to see if this breaks rumble for wiimotes or gamecube controllers emulated with xinput devices.
102 lines
2.4 KiB
C++
102 lines
2.4 KiB
C++
// Copyright 2010 Dolphin Emulator Project
|
|
// Licensed under GPLv2+
|
|
// Refer to the license.txt file included.
|
|
|
|
// XInput suffers a similar issue as XAudio2. Since Win8, it is part of the OS.
|
|
// However, unlike XAudio2 they have not made the API incompatible - so we just
|
|
// compile against the latest version and fall back to dynamically loading the
|
|
// old DLL.
|
|
|
|
#pragma once
|
|
|
|
#include <windows.h>
|
|
#include <XInput.h>
|
|
|
|
#include "InputCommon/ControllerInterface/Device.h"
|
|
|
|
#ifndef XINPUT_DEVSUBTYPE_FLIGHT_STICK
|
|
#error You are building this module against the wrong version of DirectX. You probably need to remove DXSDK_DIR from your include path and/or _WIN32_WINNT is wrong.
|
|
#endif
|
|
|
|
namespace ciface
|
|
{
|
|
namespace XInput
|
|
{
|
|
|
|
void Init(std::vector<Core::Device*>& devices);
|
|
void DeInit();
|
|
|
|
class Device : public Core::Device
|
|
{
|
|
private:
|
|
class Button : public Core::Device::Input
|
|
{
|
|
public:
|
|
Button(u8 index, const WORD& buttons) : m_buttons(buttons), m_index(index) {}
|
|
std::string GetName() const override;
|
|
ControlState GetState() const override;
|
|
private:
|
|
const WORD& m_buttons;
|
|
u8 m_index;
|
|
};
|
|
|
|
class Axis : public Core::Device::Input
|
|
{
|
|
public:
|
|
Axis(u8 index, const SHORT& axis, SHORT range) : m_axis(axis), m_range(range), m_index(index) {}
|
|
std::string GetName() const override;
|
|
ControlState GetState() const override;
|
|
private:
|
|
const SHORT& m_axis;
|
|
const SHORT m_range;
|
|
const u8 m_index;
|
|
};
|
|
|
|
class Trigger : public Core::Device::Input
|
|
{
|
|
public:
|
|
Trigger(u8 index, const BYTE& trigger, BYTE range) : m_trigger(trigger), m_range(range), m_index(index) {}
|
|
std::string GetName() const override;
|
|
ControlState GetState() const override;
|
|
private:
|
|
const BYTE& m_trigger;
|
|
const BYTE m_range;
|
|
const u8 m_index;
|
|
};
|
|
|
|
class Motor : public Core::Device::Output
|
|
{
|
|
public:
|
|
Motor(u8 index, Device* parent, WORD &motor, WORD range) : m_motor(motor), m_range(range), m_index(index), m_parent(parent) {}
|
|
std::string GetName() const override;
|
|
void SetState(ControlState state) override;
|
|
private:
|
|
WORD& m_motor;
|
|
const WORD m_range;
|
|
const u8 m_index;
|
|
Device* m_parent;
|
|
};
|
|
|
|
public:
|
|
void UpdateInput() override;
|
|
|
|
Device(const XINPUT_CAPABILITIES& capabilities, u8 index);
|
|
|
|
std::string GetName() const override;
|
|
int GetId() const override;
|
|
std::string GetSource() const override;
|
|
|
|
void UpdateMotors();
|
|
|
|
private:
|
|
XINPUT_STATE m_state_in;
|
|
XINPUT_VIBRATION m_state_out{};
|
|
XINPUT_VIBRATION m_current_state_out{};
|
|
const BYTE m_subtype;
|
|
const u8 m_index;
|
|
};
|
|
|
|
|
|
}
|
|
}
|