ControllerEmu: Clean up the code that applies the modifier

This makes it more clear and pretty much the analog stick code bog standard.
This commit is contained in:
Jasper St. Pierre 2014-07-11 08:11:33 -04:00
parent c29d5ff989
commit 0d11081a3b
1 changed files with 8 additions and 16 deletions

View File

@ -124,8 +124,6 @@ public:
template <typename C> template <typename C>
void GetState(C* const x, C* const y, const unsigned int base, const unsigned int range) void GetState(C* const x, C* const y, const unsigned int base, const unsigned int range)
{ {
// this is all a mess
ControlState yy = controls[0]->control_ref->State() - controls[1]->control_ref->State(); ControlState yy = controls[0]->control_ref->State() - controls[1]->control_ref->State();
ControlState xx = controls[3]->control_ref->State() - controls[2]->control_ref->State(); ControlState xx = controls[3]->control_ref->State() - controls[2]->control_ref->State();
@ -133,13 +131,6 @@ public:
ControlState deadzone = settings[SETTING_DEADZONE]->value; ControlState deadzone = settings[SETTING_DEADZONE]->value;
ControlState m = controls[4]->control_ref->State(); ControlState m = controls[4]->control_ref->State();
// modifier code
if (m)
{
yy = (fabsf(yy)>deadzone) * sign(yy) * (m + deadzone/2);
xx = (fabsf(xx)>deadzone) * sign(xx) * (m + deadzone/2);
}
ControlState ang = atan2(yy, xx); ControlState ang = atan2(yy, xx);
ControlState ang_sin = sin(ang); ControlState ang_sin = sin(ang);
ControlState ang_cos = cos(ang); ControlState ang_cos = cos(ang);
@ -153,6 +144,11 @@ public:
// radius // radius
dist *= radius; dist *= radius;
// The modifier halves the distance by 50%, which is useful
// for keyboard controls.
if (m)
dist *= 0.5;
yy = std::max(-1.0f, std::min(1.0f, ang_sin * dist)); yy = std::max(-1.0f, std::min(1.0f, ang_sin * dist));
xx = std::max(-1.0f, std::min(1.0f, ang_cos * dist)); xx = std::max(-1.0f, std::min(1.0f, ang_cos * dist));
@ -281,13 +277,6 @@ public:
auto const angle = settings[2]->value / 1.8f; auto const angle = settings[2]->value / 1.8f;
ControlState m = controls[4]->control_ref->State(); ControlState m = controls[4]->control_ref->State();
// modifier code
if (m)
{
yy = (fabsf(yy)>deadzone) * sign(yy) * (m + deadzone/2);
xx = (fabsf(xx)>deadzone) * sign(xx) * (m + deadzone/2);
}
// deadzone / circle stick code // deadzone / circle stick code
// this section might be all wrong, but its working good enough, I think // this section might be all wrong, but its working good enough, I think
@ -312,6 +301,9 @@ public:
ControlState amt = dist / stick_full; ControlState amt = dist / stick_full;
dist += (square_full - 1) * amt * circle; dist += (square_full - 1) * amt * circle;
if (m)
dist *= 0.5;
yy = std::max(-1.0f, std::min(1.0f, ang_sin * dist)); yy = std::max(-1.0f, std::min(1.0f, ang_sin * dist));
xx = std::max(-1.0f, std::min(1.0f, ang_cos * dist)); xx = std::max(-1.0f, std::min(1.0f, ang_cos * dist));