WiimoteEmu: Fix turntable effect dial mapping.

This commit is contained in:
Jordan Woyak 2019-02-24 19:46:01 -06:00
parent 83ff3aa691
commit 4b830ddc26
2 changed files with 22 additions and 13 deletions

View File

@ -75,9 +75,7 @@ Turntable::Turntable() : EncryptedExtension(_trans("Turntable"))
new ControllerEmu::OctagonAnalogStick(_trans("Stick"), gate_radius)); new ControllerEmu::OctagonAnalogStick(_trans("Stick"), gate_radius));
// effect dial // effect dial
groups.emplace_back(m_effect_dial = new ControllerEmu::Triggers(_trans("Effect"))); groups.emplace_back(m_effect_dial = new ControllerEmu::Slider(_trans("Effect")));
m_effect_dial->controls.emplace_back(
new ControllerEmu::Input(ControllerEmu::Translate, _trans("Dial")));
// crossfade // crossfade
groups.emplace_back(m_crossfade = new ControllerEmu::Slider(_trans("Crossfade"))); groups.emplace_back(m_crossfade = new ControllerEmu::Slider(_trans("Crossfade")));
@ -98,7 +96,7 @@ void Turntable::Update()
// left table // left table
{ {
const ControllerEmu::Slider::StateData lt = m_left_table->GetState(); const ControllerEmu::Slider::StateData lt = m_left_table->GetState();
const s8 tt = static_cast<s8>(lt.value * 0x1F); const s8 tt = static_cast<s8>(lt.value * TABLE_RANGE);
tt_data.ltable1 = tt; tt_data.ltable1 = tt;
tt_data.ltable2 = tt >> 5; tt_data.ltable2 = tt >> 5;
@ -107,7 +105,7 @@ void Turntable::Update()
// right table // right table
{ {
const ControllerEmu::Slider::StateData rt = m_right_table->GetState(); const ControllerEmu::Slider::StateData rt = m_right_table->GetState();
const s8 tt = static_cast<s8>(rt.value * 0x1F); const s8 tt = static_cast<s8>(rt.value * TABLE_RANGE);
tt_data.rtable1 = tt; tt_data.rtable1 = tt;
tt_data.rtable2 = tt >> 1; tt_data.rtable2 = tt >> 1;
@ -117,8 +115,8 @@ void Turntable::Update()
// effect dial // effect dial
{ {
const ControllerEmu::Triggers::StateData state = m_effect_dial->GetState(); const auto dial_state = m_effect_dial->GetState();
const u8 dial = static_cast<u8>(state.data[0] * 0x0F); const u8 dial = static_cast<u8>(dial_state.value * EFFECT_DIAL_RANGE) + EFFECT_DIAL_CENTER;
tt_data.dial1 = dial; tt_data.dial1 = dial;
tt_data.dial2 = dial >> 3; tt_data.dial2 = dial >> 3;
@ -128,7 +126,7 @@ void Turntable::Update()
{ {
const ControllerEmu::Slider::StateData cfs = m_crossfade->GetState(); const ControllerEmu::Slider::StateData cfs = m_crossfade->GetState();
tt_data.slider = static_cast<u8>((cfs.value * 0x07) + 0x08); tt_data.slider = static_cast<u8>((cfs.value * CROSSFADE_RANGE) + CROSSFADE_CENTER);
} }
// buttons // buttons

View File

@ -79,16 +79,27 @@ public:
BUTTON_PLUS = 0x04, BUTTON_PLUS = 0x04,
}; };
static const u8 STICK_CENTER = 0x20; static constexpr int STICK_BIT_COUNT = 6;
static const u8 STICK_RADIUS = 0x1f; static constexpr u8 STICK_CENTER = (1 << STICK_BIT_COUNT) / 2;
static constexpr u8 STICK_RADIUS = STICK_CENTER - 1;
// TODO: Test real hardware. Is this accurate? // TODO: Test real hardware. Is this accurate?
static const u8 STICK_GATE_RADIUS = 0x16; static constexpr u8 STICK_GATE_RADIUS = 0x16;
static constexpr int TABLE_BIT_COUNT = 6;
static constexpr u8 TABLE_RANGE = (1 << STICK_BIT_COUNT) / 2 - 1;
static constexpr int EFFECT_DIAL_BIT_COUNT = 5;
static constexpr u8 EFFECT_DIAL_CENTER = (1 << EFFECT_DIAL_BIT_COUNT) / 2;
static constexpr u8 EFFECT_DIAL_RANGE = EFFECT_DIAL_CENTER - 1;
static constexpr int CROSSFADE_BIT_COUNT = 4;
static constexpr u8 CROSSFADE_CENTER = (1 << CROSSFADE_BIT_COUNT) / 2;
static constexpr u8 CROSSFADE_RANGE = CROSSFADE_CENTER - 1;
private: private:
ControllerEmu::Buttons* m_buttons; ControllerEmu::Buttons* m_buttons;
ControllerEmu::AnalogStick* m_stick; ControllerEmu::AnalogStick* m_stick;
ControllerEmu::Triggers* m_effect_dial; ControllerEmu::Slider* m_effect_dial;
ControllerEmu::Slider* m_left_table; ControllerEmu::Slider* m_left_table;
ControllerEmu::Slider* m_right_table; ControllerEmu::Slider* m_right_table;
ControllerEmu::Slider* m_crossfade; ControllerEmu::Slider* m_crossfade;