Merge pull request #8015 from jordan-woyak/dinput-cursor-optimize

ControllerInterface/DInput: Optimize cursor position updating.
This commit is contained in:
Connor McLaughlin 2019-04-21 13:56:50 +10:00 committed by GitHub
commit ca55375d01
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 34 additions and 44 deletions

View File

@ -64,7 +64,7 @@ void PopulateDevices(HWND hwnd)
return; return;
} }
InitKeyboardMouse(idi8); InitKeyboardMouse(idi8, hwnd);
InitJoystick(idi8, hwnd); InitJoystick(idi8, hwnd);
idi8->Release(); idi8->Release();

View File

@ -32,7 +32,7 @@ static const struct
// Prevent duplicate keyboard/mouse devices. // Prevent duplicate keyboard/mouse devices.
static bool s_keyboard_mouse_exists = false; static bool s_keyboard_mouse_exists = false;
void InitKeyboardMouse(IDirectInput8* const idi8) void InitKeyboardMouse(IDirectInput8* const idi8, HWND hwnd)
{ {
if (s_keyboard_mouse_exists) if (s_keyboard_mouse_exists)
return; return;
@ -52,7 +52,7 @@ void InitKeyboardMouse(IDirectInput8* const idi8)
SUCCEEDED(mo_device->SetDataFormat(&c_dfDIMouse2)) && SUCCEEDED(mo_device->SetDataFormat(&c_dfDIMouse2)) &&
SUCCEEDED(mo_device->SetCooperativeLevel(nullptr, DISCL_BACKGROUND | DISCL_NONEXCLUSIVE))) SUCCEEDED(mo_device->SetCooperativeLevel(nullptr, DISCL_BACKGROUND | DISCL_NONEXCLUSIVE)))
{ {
g_controller_interface.AddDevice(std::make_shared<KeyboardMouse>(kb_device, mo_device)); g_controller_interface.AddDevice(std::make_shared<KeyboardMouse>(kb_device, mo_device, hwnd));
return; return;
} }
@ -75,27 +75,22 @@ KeyboardMouse::~KeyboardMouse()
} }
KeyboardMouse::KeyboardMouse(const LPDIRECTINPUTDEVICE8 kb_device, KeyboardMouse::KeyboardMouse(const LPDIRECTINPUTDEVICE8 kb_device,
const LPDIRECTINPUTDEVICE8 mo_device) const LPDIRECTINPUTDEVICE8 mo_device, HWND hwnd)
: m_kb_device(kb_device), m_mo_device(mo_device) : m_kb_device(kb_device), m_mo_device(mo_device), m_hwnd(hwnd), m_last_update(GetTickCount()),
m_state_in()
{ {
s_keyboard_mouse_exists = true; s_keyboard_mouse_exists = true;
m_kb_device->Acquire(); m_kb_device->Acquire();
m_mo_device->Acquire(); m_mo_device->Acquire();
m_last_update = GetTickCount();
ZeroMemory(&m_state_in, sizeof(m_state_in));
// KEYBOARD // KEYBOARD
// add keys // add keys
for (u8 i = 0; i < sizeof(named_keys) / sizeof(*named_keys); ++i) for (u8 i = 0; i < sizeof(named_keys) / sizeof(*named_keys); ++i)
AddInput(new Key(i, m_state_in.keyboard[named_keys[i].code])); AddInput(new Key(i, m_state_in.keyboard[named_keys[i].code]));
// MOUSE // MOUSE
// get caps DIDEVCAPS mouse_caps = {};
DIDEVCAPS mouse_caps;
ZeroMemory(&mouse_caps, sizeof(mouse_caps));
mouse_caps.dwSize = sizeof(mouse_caps); mouse_caps.dwSize = sizeof(mouse_caps);
m_mo_device->GetCapabilities(&mouse_caps); m_mo_device->GetCapabilities(&mouse_caps);
// mouse buttons // mouse buttons
@ -115,35 +110,26 @@ KeyboardMouse::KeyboardMouse(const LPDIRECTINPUTDEVICE8 kb_device,
AddInput(new Cursor(!!(i & 2), (&m_state_in.cursor.x)[i / 2], !!(i & 1))); AddInput(new Cursor(!!(i & 2), (&m_state_in.cursor.x)[i / 2], !!(i & 1)));
} }
void GetMousePos(ControlState* const x, ControlState* const y) void KeyboardMouse::UpdateCursorInput()
{ {
POINT point = {1, 1}; POINT point = {};
GetCursorPos(&point); GetCursorPos(&point);
// Get the cursor position relative to the upper left corner of the current window (separate or
// render to main) // Get the cursor position relative to the upper left corner of the current window
HWND hwnd = WindowFromPoint(point); // (separate or render to main)
DWORD processId; ScreenToClient(m_hwnd, &point);
GetWindowThreadProcessId(hwnd, &processId);
if (processId == GetCurrentProcessId())
{
ScreenToClient(hwnd, &point);
// Get the size of the current window. (In my case Rect.top and Rect.left was zero.) // Get the size of the current window. (In my case Rect.top and Rect.left was zero.)
RECT rect; RECT rect;
GetClientRect(hwnd, &rect); GetClientRect(m_hwnd, &rect);
// Width and height is the size of the rendering window
unsigned int win_width = rect.right - rect.left;
unsigned int win_height = rect.bottom - rect.top;
// Return the mouse position as a range from -1 to 1 // Width and height are the size of the rendering window.
*x = (ControlState)point.x / (ControlState)win_width * 2 - 1; const auto win_width = rect.right - rect.left;
*y = (ControlState)point.y / (ControlState)win_height * 2 - 1; const auto win_height = rect.bottom - rect.top;
}
else // Convert the cursor position to a range from -1 to 1.
{ m_state_in.cursor.x = ControlState(point.x) / win_width * 2 - 1;
*x = (ControlState)1; m_state_in.cursor.y = ControlState(point.y) / win_height * 2 - 1;
*y = (ControlState)1;
}
} }
void KeyboardMouse::UpdateInput() void KeyboardMouse::UpdateInput()
@ -155,7 +141,7 @@ void KeyboardMouse::UpdateInput()
if (cur_time - m_last_update > DROP_INPUT_TIME) if (cur_time - m_last_update > DROP_INPUT_TIME)
{ {
// set axes to zero // set axes to zero
ZeroMemory(&m_state_in.mouse, sizeof(m_state_in.mouse)); m_state_in.mouse = {};
// skip this input state // skip this input state
m_mo_device->GetDeviceState(sizeof(tmp_mouse), &tmp_mouse); m_mo_device->GetDeviceState(sizeof(tmp_mouse), &tmp_mouse);
} }
@ -180,8 +166,7 @@ void KeyboardMouse::UpdateInput()
// copy over the buttons // copy over the buttons
memcpy(m_state_in.mouse.rgbButtons, tmp_mouse.rgbButtons, sizeof(m_state_in.mouse.rgbButtons)); memcpy(m_state_in.mouse.rgbButtons, tmp_mouse.rgbButtons, sizeof(m_state_in.mouse.rgbButtons));
// update mouse cursor UpdateCursorInput();
GetMousePos(&m_state_in.cursor.x, &m_state_in.cursor.y);
} }
} }
@ -235,12 +220,12 @@ ControlState KeyboardMouse::Button::GetState() const
ControlState KeyboardMouse::Axis::GetState() const ControlState KeyboardMouse::Axis::GetState() const
{ {
return std::max(0.0, ControlState(m_axis) / m_range); return ControlState(m_axis) / m_range;
} }
ControlState KeyboardMouse::Cursor::GetState() const ControlState KeyboardMouse::Cursor::GetState() const
{ {
return std::max(0.0, ControlState(m_axis) / (m_positive ? 1.0 : -1.0)); return m_axis / (m_positive ? 1.0 : -1.0);
} }
} // namespace DInput } // namespace DInput
} // namespace ciface } // namespace ciface

View File

@ -13,7 +13,7 @@ namespace ciface
{ {
namespace DInput namespace DInput
{ {
void InitKeyboardMouse(IDirectInput8* const idi8); void InitKeyboardMouse(IDirectInput8* const idi8, HWND hwnd);
class KeyboardMouse : public Core::Device class KeyboardMouse : public Core::Device
{ {
@ -85,16 +85,21 @@ private:
public: public:
void UpdateInput() override; void UpdateInput() override;
KeyboardMouse(const LPDIRECTINPUTDEVICE8 kb_device, const LPDIRECTINPUTDEVICE8 mo_device); KeyboardMouse(const LPDIRECTINPUTDEVICE8 kb_device, const LPDIRECTINPUTDEVICE8 mo_device,
HWND hwnd);
~KeyboardMouse(); ~KeyboardMouse();
std::string GetName() const override; std::string GetName() const override;
std::string GetSource() const override; std::string GetSource() const override;
private: private:
void UpdateCursorInput();
const LPDIRECTINPUTDEVICE8 m_kb_device; const LPDIRECTINPUTDEVICE8 m_kb_device;
const LPDIRECTINPUTDEVICE8 m_mo_device; const LPDIRECTINPUTDEVICE8 m_mo_device;
const HWND m_hwnd;
DWORD m_last_update; DWORD m_last_update;
State m_state_in; State m_state_in;
}; };