WiimoteEmu: Fix turntable effect dial mapping.
This commit is contained in:
parent
83ff3aa691
commit
4b830ddc26
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in New Issue