Do 3D slider updating in the HID module

This commit is contained in:
xperia64 2019-01-17 23:48:50 -05:00
parent 81f4cef201
commit 6f2eb2a418
3 changed files with 13 additions and 0 deletions

View file

@ -121,6 +121,10 @@ void Handler::Set3DLed(u8 state) {
shared_page.ledstate_3d = state; shared_page.ledstate_3d = state;
} }
void Handler::Set3DSlider(float_le slidestate) {
shared_page.sliderstate_3d = slidestate;
}
SharedPageDef& Handler::GetSharedPage() { SharedPageDef& Handler::GetSharedPage() {
return shared_page; return shared_page;
} }

View file

@ -89,6 +89,8 @@ public:
void SetWifiLinkLevel(WifiLinkLevel); void SetWifiLinkLevel(WifiLinkLevel);
void Set3DSlider(float_le);
void Set3DLed(u8); void Set3DLed(u8);
SharedPageDef& GetSharedPage(); SharedPageDef& GetSharedPage();

View file

@ -12,6 +12,7 @@
#include "core/hle/kernel/event.h" #include "core/hle/kernel/event.h"
#include "core/hle/kernel/handle_table.h" #include "core/hle/kernel/handle_table.h"
#include "core/hle/kernel/shared_memory.h" #include "core/hle/kernel/shared_memory.h"
#include "core/hle/kernel/shared_page.h"
#include "core/hle/service/hid/hid.h" #include "core/hle/service/hid/hid.h"
#include "core/hle/service/hid/hid_spvr.h" #include "core/hle/service/hid/hid_spvr.h"
#include "core/hle/service/hid/hid_user.h" #include "core/hle/service/hid/hid_user.h"
@ -160,6 +161,12 @@ void Module::UpdatePadCallback(u64 userdata, s64 cycles_late) {
event_pad_or_touch_1->Signal(); event_pad_or_touch_1->Signal();
event_pad_or_touch_2->Signal(); event_pad_or_touch_2->Signal();
// TODO(xperia64): How the 3D Slider is updated by the HID module needs to be RE'd
// and possibly moved to its own Core::Timing event.
system.Kernel().GetSharedPageHandler().Set3DSlider(
Settings::values.toggle_3d ? static_cast<float_le>(Settings::values.factor_3d) / 100
: 0.0f);
// Reschedule recurrent event // Reschedule recurrent event
system.CoreTiming().ScheduleEvent(pad_update_ticks - cycles_late, pad_update_event); system.CoreTiming().ScheduleEvent(pad_update_ticks - cycles_late, pad_update_event);
} }