diff options
Diffstat (limited to 'src/core/frontend/emu_window.h')
| -rw-r--r-- | src/core/frontend/emu_window.h | 54 |
1 files changed, 0 insertions, 54 deletions
diff --git a/src/core/frontend/emu_window.h b/src/core/frontend/emu_window.h index 1ba64c92b..36f2667fa 100644 --- a/src/core/frontend/emu_window.h +++ b/src/core/frontend/emu_window.h | |||
| @@ -10,7 +10,6 @@ | |||
| 10 | #include "common/common_types.h" | 10 | #include "common/common_types.h" |
| 11 | #include "common/framebuffer_layout.h" | 11 | #include "common/framebuffer_layout.h" |
| 12 | #include "common/math_util.h" | 12 | #include "common/math_util.h" |
| 13 | #include "core/hle/service/hid/hid.h" | ||
| 14 | 13 | ||
| 15 | /** | 14 | /** |
| 16 | * Abstraction class used to provide an interface between emulation code and the frontend | 15 | * Abstraction class used to provide an interface between emulation code and the frontend |
| @@ -52,30 +51,6 @@ public: | |||
| 52 | /// Releases (dunno if this is the "right" word) the GLFW context from the caller thread | 51 | /// Releases (dunno if this is the "right" word) the GLFW context from the caller thread |
| 53 | virtual void DoneCurrent() = 0; | 52 | virtual void DoneCurrent() = 0; |
| 54 | 53 | ||
| 55 | virtual void ReloadSetKeymaps() = 0; | ||
| 56 | |||
| 57 | /** | ||
| 58 | * Signals a button press action to the HID module. | ||
| 59 | * @param pad_state indicates which button to press | ||
| 60 | * @note only handles real buttons (A/B/X/Y/...), excluding analog inputs like the circle pad. | ||
| 61 | */ | ||
| 62 | void ButtonPressed(Service::HID::PadState pad_state); | ||
| 63 | |||
| 64 | /** | ||
| 65 | * Signals a button release action to the HID module. | ||
| 66 | * @param pad_state indicates which button to press | ||
| 67 | * @note only handles real buttons (A/B/X/Y/...), excluding analog inputs like the circle pad. | ||
| 68 | */ | ||
| 69 | void ButtonReleased(Service::HID::PadState pad_state); | ||
| 70 | |||
| 71 | /** | ||
| 72 | * Signals a circle pad change action to the HID module. | ||
| 73 | * @param x new x-coordinate of the circle pad, in the range [-1.0, 1.0] | ||
| 74 | * @param y new y-coordinate of the circle pad, in the range [-1.0, 1.0] | ||
| 75 | * @note the coordinates will be normalized if the radius is larger than 1 | ||
| 76 | */ | ||
| 77 | void CirclePadUpdated(float x, float y); | ||
| 78 | |||
| 79 | /** | 54 | /** |
| 80 | * Signal that a touch pressed event has occurred (e.g. mouse click pressed) | 55 | * Signal that a touch pressed event has occurred (e.g. mouse click pressed) |
| 81 | * @param framebuffer_x Framebuffer x-coordinate that was pressed | 56 | * @param framebuffer_x Framebuffer x-coordinate that was pressed |
| @@ -115,27 +90,6 @@ public: | |||
| 115 | void GyroscopeChanged(float x, float y, float z); | 90 | void GyroscopeChanged(float x, float y, float z); |
| 116 | 91 | ||
| 117 | /** | 92 | /** |
| 118 | * Gets the current pad state (which buttons are pressed). | ||
| 119 | * @note This should be called by the core emu thread to get a state set by the window thread. | ||
| 120 | * @note This doesn't include analog input like circle pad direction | ||
| 121 | * @todo Fix this function to be thread-safe. | ||
| 122 | * @return PadState object indicating the current pad state | ||
| 123 | */ | ||
| 124 | Service::HID::PadState GetPadState() const { | ||
| 125 | return pad_state; | ||
| 126 | } | ||
| 127 | |||
| 128 | /** | ||
| 129 | * Gets the current circle pad state. | ||
| 130 | * @note This should be called by the core emu thread to get a state set by the window thread. | ||
| 131 | * @todo Fix this function to be thread-safe. | ||
| 132 | * @return std::tuple of (x, y), where `x` and `y` are the circle pad coordinates | ||
| 133 | */ | ||
| 134 | std::tuple<s16, s16> GetCirclePadState() const { | ||
| 135 | return std::make_tuple(circle_pad_x, circle_pad_y); | ||
| 136 | } | ||
| 137 | |||
| 138 | /** | ||
| 139 | * Gets the current touch screen state (touch X/Y coordinates and whether or not it is pressed). | 93 | * Gets the current touch screen state (touch X/Y coordinates and whether or not it is pressed). |
| 140 | * @note This should be called by the core emu thread to get a state set by the window thread. | 94 | * @note This should be called by the core emu thread to get a state set by the window thread. |
| 141 | * @todo Fix this function to be thread-safe. | 95 | * @todo Fix this function to be thread-safe. |
| @@ -230,11 +184,8 @@ protected: | |||
| 230 | // TODO: Find a better place to set this. | 184 | // TODO: Find a better place to set this. |
| 231 | config.min_client_area_size = std::make_pair(400u, 480u); | 185 | config.min_client_area_size = std::make_pair(400u, 480u); |
| 232 | active_config = config; | 186 | active_config = config; |
| 233 | pad_state.hex = 0; | ||
| 234 | touch_x = 0; | 187 | touch_x = 0; |
| 235 | touch_y = 0; | 188 | touch_y = 0; |
| 236 | circle_pad_x = 0; | ||
| 237 | circle_pad_y = 0; | ||
| 238 | touch_pressed = false; | 189 | touch_pressed = false; |
| 239 | accel_x = 0; | 190 | accel_x = 0; |
| 240 | accel_y = -512; | 191 | accel_y = -512; |
| @@ -304,9 +255,6 @@ private: | |||
| 304 | u16 touch_x; ///< Touchpad X-position in native 3DS pixel coordinates (0-320) | 255 | u16 touch_x; ///< Touchpad X-position in native 3DS pixel coordinates (0-320) |
| 305 | u16 touch_y; ///< Touchpad Y-position in native 3DS pixel coordinates (0-240) | 256 | u16 touch_y; ///< Touchpad Y-position in native 3DS pixel coordinates (0-240) |
| 306 | 257 | ||
| 307 | s16 circle_pad_x; ///< Circle pad X-position in native 3DS pixel coordinates (-156 - 156) | ||
| 308 | s16 circle_pad_y; ///< Circle pad Y-position in native 3DS pixel coordinates (-156 - 156) | ||
| 309 | |||
| 310 | std::mutex accel_mutex; | 258 | std::mutex accel_mutex; |
| 311 | s16 accel_x; ///< Accelerometer X-axis value in native 3DS units | 259 | s16 accel_x; ///< Accelerometer X-axis value in native 3DS units |
| 312 | s16 accel_y; ///< Accelerometer Y-axis value in native 3DS units | 260 | s16 accel_y; ///< Accelerometer Y-axis value in native 3DS units |
| @@ -321,6 +269,4 @@ private: | |||
| 321 | * Clip the provided coordinates to be inside the touchscreen area. | 269 | * Clip the provided coordinates to be inside the touchscreen area. |
| 322 | */ | 270 | */ |
| 323 | std::tuple<unsigned, unsigned> ClipToTouchScreen(unsigned new_x, unsigned new_y); | 271 | std::tuple<unsigned, unsigned> ClipToTouchScreen(unsigned new_x, unsigned new_y); |
| 324 | |||
| 325 | Service::HID::PadState pad_state; | ||
| 326 | }; | 272 | }; |