From c14ec39de999df939a9f53e81577a61093a3d702 Mon Sep 17 00:00:00 2001 From: georgemoralis Date: Fri, 9 Aug 2024 15:44:49 +0300 Subject: [PATCH] intial work on creating a device interface --- CMakeLists.txt | 2 ++ src/input/controller.cpp | 1 + src/input/controller.h | 2 ++ src/input/devices/devices.h | 41 ++++++++++++++++++++++++++++++ src/input/devices/sdl_keyboard.cpp | 19 ++++++++++++++ 5 files changed, 65 insertions(+) create mode 100644 src/input/devices/devices.h create mode 100644 src/input/devices/sdl_keyboard.cpp diff --git a/CMakeLists.txt b/CMakeLists.txt index 04cb3ea7..a74671e9 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -619,6 +619,8 @@ set(IMGUI src/imgui/imgui_config.h set(INPUT src/input/controller.cpp src/input/controller.h + src/input/devices/devices.h + src/input/devices/sdl_keyboard.cpp ) set(EMULATOR src/emulator.cpp diff --git a/src/input/controller.cpp b/src/input/controller.cpp index 4de6d83b..60a06aa6 100644 --- a/src/input/controller.cpp +++ b/src/input/controller.cpp @@ -11,6 +11,7 @@ namespace Input { GameController::GameController() { m_states_num = 0; m_last_state = State(); + m_device = std::make_unique(); } void GameController::ReadState(State* state, bool* isConnected, int* connectedCount) { diff --git a/src/input/controller.h b/src/input/controller.h index 0a0d663a..096b7af0 100644 --- a/src/input/controller.h +++ b/src/input/controller.h @@ -5,6 +5,7 @@ #include #include "common/types.h" +#include "devices/devices.h" struct SDL_Gamepad; @@ -71,6 +72,7 @@ private: std::array m_states; std::array m_private; + std::unique_ptr m_device; SDL_Gamepad* m_sdl_gamepad = nullptr; }; diff --git a/src/input/devices/devices.h b/src/input/devices/devices.h new file mode 100644 index 00000000..bc54aed8 --- /dev/null +++ b/src/input/devices/devices.h @@ -0,0 +1,41 @@ +// SPDX-FileCopyrightText: Copyright 2024 shadPS4 Emulator Project +// SPDX-License-Identifier: GPL-2.0-or-later + +#pragma once + +#include +#include + +namespace Input { + +struct InputMappings { + using Scancode = u32; + using Container = std::unordered_map; + + u32 getMapping(Scancode scancode) const { + auto it = container.find(scancode); + return it != container.end() ? it->second : -1; + } + + void setMapping(Scancode scancode, u32 key) { + container[scancode] = key; + } + +private: + Container container; +}; + +class InputDevices { + +public: + virtual ~InputDevices() = default; + virtual InputMappings GetMappings() = 0; +}; + +class SDLKeyboard : public InputDevices { +public: + virtual ~SDLKeyboard(); + virtual InputMappings GetMappings() override; +}; + +} // namespace Input \ No newline at end of file diff --git a/src/input/devices/sdl_keyboard.cpp b/src/input/devices/sdl_keyboard.cpp new file mode 100644 index 00000000..5bd6855b --- /dev/null +++ b/src/input/devices/sdl_keyboard.cpp @@ -0,0 +1,19 @@ +// SPDX-FileCopyrightText: Copyright 2024 shadPS4 Emulator Project +// SPDX-License-Identifier: GPL-2.0-or-later + +#include +#include "core/libraries/pad/pad.h" +#include "devices.h" + +namespace Input { + +SDLKeyboard::~SDLKeyboard() {} + +InputMappings SDLKeyboard::GetMappings() { + using Libraries::Pad::OrbisPadButtonDataOffset; + InputMappings mappings; + mappings.setMapping(SDLK_UP, OrbisPadButtonDataOffset::ORBIS_PAD_BUTTON_UP); + // TODO the rest + return mappings; +} +} // namespace Input \ No newline at end of file