summaryrefslogtreecommitdiffstats
path: root/src/core/hid/emulated_controller.cpp
diff options
context:
space:
mode:
authorgerman77 <juangerman-13@hotmail.com>2023-05-08 00:38:41 +0200
committergerman77 <juangerman-13@hotmail.com>2023-05-08 01:01:57 +0200
commitcf023aa8ec93193d4827b3034c9e7d35a0edfc2a (patch)
tree66c90375ec6d8a8f1bae96e8c6fc9194b8407756 /src/core/hid/emulated_controller.cpp
parentMerge pull request #10097 from german77/nfp_full (diff)
downloadyuzu-cf023aa8ec93193d4827b3034c9e7d35a0edfc2a.tar
yuzu-cf023aa8ec93193d4827b3034c9e7d35a0edfc2a.tar.gz
yuzu-cf023aa8ec93193d4827b3034c9e7d35a0edfc2a.tar.bz2
yuzu-cf023aa8ec93193d4827b3034c9e7d35a0edfc2a.tar.lz
yuzu-cf023aa8ec93193d4827b3034c9e7d35a0edfc2a.tar.xz
yuzu-cf023aa8ec93193d4827b3034c9e7d35a0edfc2a.tar.zst
yuzu-cf023aa8ec93193d4827b3034c9e7d35a0edfc2a.zip
Diffstat (limited to '')
-rw-r--r--src/core/hid/emulated_controller.cpp29
1 files changed, 14 insertions, 15 deletions
diff --git a/src/core/hid/emulated_controller.cpp b/src/core/hid/emulated_controller.cpp
index ecab85893..c7f0af71f 100644
--- a/src/core/hid/emulated_controller.cpp
+++ b/src/core/hid/emulated_controller.cpp
@@ -979,7 +979,6 @@ void EmulatedController::SetMotion(const Common::Input::CallbackStatus& callback
emulated.SetUserGyroThreshold(raw_status.gyro.x.properties.threshold);
emulated.UpdateRotation(raw_status.delta_timestamp);
emulated.UpdateOrientation(raw_status.delta_timestamp);
- force_update_motion = raw_status.force_update;
auto& motion = controller.motion_state[index];
motion.accel = emulated.GetAcceleration();
@@ -1618,19 +1617,6 @@ NpadGcTriggerState EmulatedController::GetTriggers() const {
MotionState EmulatedController::GetMotions() const {
std::unique_lock lock{mutex};
-
- // Some drivers like mouse motion need constant refreshing
- if (force_update_motion) {
- for (auto& device : motion_devices) {
- if (!device) {
- continue;
- }
- lock.unlock();
- device->ForceUpdate();
- lock.lock();
- }
- }
-
return controller.motion_state;
}
@@ -1696,8 +1682,21 @@ void EmulatedController::DeleteCallback(int key) {
callback_list.erase(iterator);
}
-void EmulatedController::TurboButtonUpdate() {
+void EmulatedController::StatusUpdate() {
turbo_button_state = (turbo_button_state + 1) % (TURBO_BUTTON_DELAY * 2);
+
+ // Some drivers like key motion need constant refreshing
+ for (std::size_t index = 0; index < motion_devices.size(); ++index) {
+ const auto& raw_status = controller.motion_values[index].raw_status;
+ auto& device = motion_devices[index];
+ if (!raw_status.force_update) {
+ continue;
+ }
+ if (!device) {
+ continue;
+ }
+ device->ForceUpdate();
+ }
}
NpadButton EmulatedController::GetTurboButtonMask() const {