diff options
author | bunnei <bunneidev@gmail.com> | 2018-10-18 02:25:17 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-10-18 02:25:17 +0200 |
commit | 7dee60d7d24dabcc2c52c8c2135f1c89adb57ff6 (patch) | |
tree | 042bae044e7b1f05eb5a561eefe37d847e0417cf /src/core/hle/service/hid/controllers/mouse.h | |
parent | Merge pull request #1489 from FernandoS27/fix-tlds (diff) | |
parent | Using dual joycons as the default controller (diff) | |
download | yuzu-7dee60d7d24dabcc2c52c8c2135f1c89adb57ff6.tar yuzu-7dee60d7d24dabcc2c52c8c2135f1c89adb57ff6.tar.gz yuzu-7dee60d7d24dabcc2c52c8c2135f1c89adb57ff6.tar.bz2 yuzu-7dee60d7d24dabcc2c52c8c2135f1c89adb57ff6.tar.lz yuzu-7dee60d7d24dabcc2c52c8c2135f1c89adb57ff6.tar.xz yuzu-7dee60d7d24dabcc2c52c8c2135f1c89adb57ff6.tar.zst yuzu-7dee60d7d24dabcc2c52c8c2135f1c89adb57ff6.zip |
Diffstat (limited to '')
-rw-r--r-- | src/core/hle/service/hid/controllers/mouse.h | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/src/core/hle/service/hid/controllers/mouse.h b/src/core/hle/service/hid/controllers/mouse.h new file mode 100644 index 000000000..05358a4f5 --- /dev/null +++ b/src/core/hle/service/hid/controllers/mouse.h @@ -0,0 +1,49 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#pragma once + +#include <array> +#include "common/common_types.h" +#include "common/swap.h" +#include "core/hle/service/hid/controllers/controller_base.h" + +namespace Service::HID { +class Controller_Mouse final : public ControllerBase { +public: + Controller_Mouse(); + + // Called when the controller is initialized + void OnInit() override; + + // When the controller is released + void OnRelease() override; + + // When the controller is requesting an update for the shared memory + void OnUpdate(u8* data, std::size_t size) override; + + // Called when input devices should be loaded + void OnLoadInputDevices() override; + +private: + struct MouseState { + s64_le sampling_number; + s64_le sampling_number2; + s32_le x; + s32_le y; + s32_le delta_x; + s32_le delta_y; + s32_le mouse_wheel; + s32_le button; + s32_le attribute; + }; + static_assert(sizeof(MouseState) == 0x30, "MouseState is an invalid size"); + + struct SharedMemory { + CommonHeader header; + std::array<MouseState, 17> mouse_states; + }; + SharedMemory shared_memory{}; +}; +} // namespace Service::HID |