DolphinQt/Mapping: Disable relative input when "Mouse Controlled Pointing" button is pressed.

This commit is contained in:
Jordan Woyak 2024-04-15 14:51:06 -05:00
parent dbc7e03577
commit 31dc3477ad
4 changed files with 14 additions and 2 deletions

View File

@ -172,7 +172,9 @@ QGroupBox* MappingWidget::CreateGroupBox(const QString& name, ControllerEmu::Con
{
QPushButton* mouse_button = new QPushButton(tr("Use Mouse Controlled Pointing"));
form_layout->insertRow(2, mouse_button);
connect(mouse_button, &QCheckBox::clicked, [this, group] {
using ControllerEmu::Cursor;
connect(mouse_button, &QCheckBox::clicked, [this, group = static_cast<Cursor*>(group)] {
std::string default_device = g_controller_interface.GetDefaultDeviceString() + ":";
const std::string controller_device = GetController()->GetDefaultDevice().ToString() + ":";
if (default_device == controller_device)
@ -183,6 +185,9 @@ QGroupBox* MappingWidget::CreateGroupBox(const QString& name, ControllerEmu::Con
group->SetControlExpression(1, fmt::format("`{}Cursor Y+`", default_device));
group->SetControlExpression(2, fmt::format("`{}Cursor X-`", default_device));
group->SetControlExpression(3, fmt::format("`{}Cursor X+`", default_device));
group->SetRelativeInput(false);
emit ConfigChanged();
GetController()->UpdateReferences(g_controller_interface);
});

View File

@ -181,6 +181,11 @@ ControlState Cursor::GetVerticalOffset() const
return m_vertical_offset_setting.GetValue() / 100;
}
void Cursor::SetRelativeInput(bool value)
{
m_relative_setting.SetValue(value);
}
bool Cursor::StateData::IsVisible() const
{
return !std::isnan(x);

View File

@ -40,6 +40,8 @@ public:
// Vertical offset in meters.
ControlState GetVerticalOffset() const;
void SetRelativeInput(bool enabled);
private:
Cursor::StateData UpdateState(Cursor::ReshapeData input);

View File

@ -186,7 +186,6 @@ public:
bool IsSimpleValue() const { return m_input.GetExpression().empty(); }
private:
void SetValue(ValueType value)
{
m_value = value;
@ -195,6 +194,7 @@ private:
m_input.SetExpression("");
}
private:
// Values are R/W by both UI and CPU threads.
mutable std::atomic<ValueType> m_value = {};