Add auto-hide option to Wii IR pointer
This commit is contained in:
parent
8fce18e4ff
commit
ab02499ce7
|
@ -36,6 +36,7 @@ Cursor::Cursor(const std::string& name_) : ControlGroup(name_, GroupType::Cursor
|
||||||
numeric_settings.emplace_back(std::make_unique<NumericSetting>(_trans("Height"), 0.5));
|
numeric_settings.emplace_back(std::make_unique<NumericSetting>(_trans("Height"), 0.5));
|
||||||
numeric_settings.emplace_back(std::make_unique<NumericSetting>(_trans("Dead Zone"), 0, 0, 20));
|
numeric_settings.emplace_back(std::make_unique<NumericSetting>(_trans("Dead Zone"), 0, 0, 20));
|
||||||
boolean_settings.emplace_back(std::make_unique<BooleanSetting>(_trans("Relative Input"), false));
|
boolean_settings.emplace_back(std::make_unique<BooleanSetting>(_trans("Relative Input"), false));
|
||||||
|
boolean_settings.emplace_back(std::make_unique<BooleanSetting>(_trans("Auto-Hide"), false));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Cursor::GetState(ControlState* const x, ControlState* const y, ControlState* const z,
|
void Cursor::GetState(ControlState* const x, ControlState* const y, ControlState* const z,
|
||||||
|
@ -51,17 +52,31 @@ void Cursor::GetState(ControlState* const x, ControlState* const y, ControlState
|
||||||
|
|
||||||
*z = m_z;
|
*z = m_z;
|
||||||
|
|
||||||
|
if (m_autohide_timer > -1)
|
||||||
|
{
|
||||||
|
--m_autohide_timer;
|
||||||
|
}
|
||||||
|
|
||||||
|
ControlState yy = controls[0]->control_ref->State() - controls[1]->control_ref->State();
|
||||||
|
ControlState xx = controls[3]->control_ref->State() - controls[2]->control_ref->State();
|
||||||
|
|
||||||
|
const ControlState deadzone = numeric_settings[3]->GetValue();
|
||||||
|
|
||||||
|
// reset auto-hide timer
|
||||||
|
if (std::abs(m_prev_xx - xx) > deadzone || std::abs(m_prev_yy - yy) > deadzone)
|
||||||
|
{
|
||||||
|
m_autohide_timer = TIMER_VALUE;
|
||||||
|
}
|
||||||
|
|
||||||
// hide
|
// hide
|
||||||
if (controls[6]->control_ref->State() > 0.5)
|
bool autohide = boolean_settings[1]->GetValue() && m_autohide_timer < 0;
|
||||||
|
if (controls[6]->control_ref->State() > 0.5 || autohide)
|
||||||
{
|
{
|
||||||
*x = 10000;
|
*x = 10000;
|
||||||
*y = 0;
|
*y = 0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ControlState yy = controls[0]->control_ref->State() - controls[1]->control_ref->State();
|
|
||||||
ControlState xx = controls[3]->control_ref->State() - controls[2]->control_ref->State();
|
|
||||||
|
|
||||||
// adjust cursor according to settings
|
// adjust cursor according to settings
|
||||||
if (adjusted)
|
if (adjusted)
|
||||||
{
|
{
|
||||||
|
@ -73,7 +88,6 @@ void Cursor::GetState(ControlState* const x, ControlState* const y, ControlState
|
||||||
// relative input
|
// relative input
|
||||||
if (boolean_settings[0]->GetValue())
|
if (boolean_settings[0]->GetValue())
|
||||||
{
|
{
|
||||||
const ControlState deadzone = numeric_settings[3]->GetValue();
|
|
||||||
// deadzone to avoid the cursor slowly drifting
|
// deadzone to avoid the cursor slowly drifting
|
||||||
if (std::abs(xx) > deadzone)
|
if (std::abs(xx) > deadzone)
|
||||||
m_x = MathUtil::Clamp(m_x + xx * SPEED_MULTIPLIER, -1.0, 1.0);
|
m_x = MathUtil::Clamp(m_x + xx * SPEED_MULTIPLIER, -1.0, 1.0);
|
||||||
|
@ -96,5 +110,8 @@ void Cursor::GetState(ControlState* const x, ControlState* const y, ControlState
|
||||||
*x = m_x;
|
*x = m_x;
|
||||||
*y = m_y;
|
*y = m_y;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m_prev_xx = xx;
|
||||||
|
m_prev_yy = yy;
|
||||||
}
|
}
|
||||||
} // namespace ControllerEmu
|
} // namespace ControllerEmu
|
||||||
|
|
|
@ -22,8 +22,15 @@ private:
|
||||||
// to something that makes sense with the default range.
|
// to something that makes sense with the default range.
|
||||||
static constexpr double SPEED_MULTIPLIER = 0.04;
|
static constexpr double SPEED_MULTIPLIER = 0.04;
|
||||||
|
|
||||||
|
// Sets the length for the auto-hide timer
|
||||||
|
static constexpr int TIMER_VALUE = 500;
|
||||||
|
|
||||||
ControlState m_x = 0.0;
|
ControlState m_x = 0.0;
|
||||||
ControlState m_y = 0.0;
|
ControlState m_y = 0.0;
|
||||||
ControlState m_z = 0.0;
|
ControlState m_z = 0.0;
|
||||||
|
|
||||||
|
int m_autohide_timer = TIMER_VALUE;
|
||||||
|
ControlState m_prev_xx;
|
||||||
|
ControlState m_prev_yy;
|
||||||
};
|
};
|
||||||
} // namespace ControllerEmu
|
} // namespace ControllerEmu
|
||||||
|
|
Loading…
Reference in New Issue