mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-07-23 06:09:50 -06:00
InputCommon: Allow Wii remote extension to be set with an input expression.
This commit is contained in:
@ -83,6 +83,8 @@ MappingBool::MappingBool(MappingWidget* parent, ControllerEmu::NumericSetting<bo
|
||||
|
||||
connect(parent, &MappingWidget::ConfigChanged, this, &MappingBool::ConfigChanged);
|
||||
connect(parent, &MappingWidget::Update, this, &MappingBool::Update);
|
||||
|
||||
setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Ignored);
|
||||
}
|
||||
|
||||
void MappingBool::ConfigChanged()
|
||||
|
@ -9,7 +9,6 @@
|
||||
#include <QGroupBox>
|
||||
#include <QLabel>
|
||||
#include <QPushButton>
|
||||
#include <QTimer>
|
||||
|
||||
#include "DolphinQt/Config/Mapping/IOWindow.h"
|
||||
#include "DolphinQt/Config/Mapping/MappingButton.h"
|
||||
@ -29,14 +28,6 @@ MappingWidget::MappingWidget(MappingWindow* parent) : m_parent(parent)
|
||||
connect(parent, &MappingWindow::Update, this, &MappingWidget::Update);
|
||||
connect(parent, &MappingWindow::Save, this, &MappingWidget::SaveSettings);
|
||||
connect(parent, &MappingWindow::ConfigChanged, this, &MappingWidget::ConfigChanged);
|
||||
|
||||
const auto timer = new QTimer(this);
|
||||
connect(timer, &QTimer::timeout, this, [this] {
|
||||
const auto lock = m_parent->GetController()->GetStateLock();
|
||||
emit Update();
|
||||
});
|
||||
|
||||
timer->start(1000 / INDICATOR_UPDATE_FREQ);
|
||||
}
|
||||
|
||||
MappingWindow* MappingWidget::GetParent() const
|
||||
@ -139,31 +130,18 @@ QGroupBox* MappingWidget::CreateGroupBox(const QString& name, ControllerEmu::Con
|
||||
setting_widget =
|
||||
new MappingBool(this, static_cast<ControllerEmu::NumericSetting<bool>*>(setting.get()));
|
||||
break;
|
||||
|
||||
default:
|
||||
// FYI: Widgets for additional types can be implemented as needed.
|
||||
break;
|
||||
}
|
||||
|
||||
if (setting_widget)
|
||||
{
|
||||
const auto hbox = new QHBoxLayout;
|
||||
|
||||
hbox->addWidget(setting_widget);
|
||||
|
||||
const auto advanced_button = new QPushButton(tr("..."));
|
||||
advanced_button->setFixedWidth(
|
||||
QFontMetrics(font()).boundingRect(advanced_button->text()).width() * 2);
|
||||
|
||||
hbox->addWidget(advanced_button);
|
||||
|
||||
advanced_button->connect(
|
||||
advanced_button, &QPushButton::clicked, [this, &setting = *setting.get()]() {
|
||||
setting.SetExpressionFromValue();
|
||||
|
||||
IOWindow io(this, GetController(), &setting.GetInputReference(), IOWindow::Type::Input);
|
||||
io.exec();
|
||||
|
||||
setting.SimplifyIfPossible();
|
||||
|
||||
ConfigChanged();
|
||||
SaveSettings();
|
||||
});
|
||||
hbox->addWidget(CreateSettingAdvancedMappingButton(*setting));
|
||||
|
||||
form_layout->addRow(tr(setting->GetUIName()), hbox);
|
||||
}
|
||||
@ -198,3 +176,25 @@ ControllerEmu::EmulatedController* MappingWidget::GetController() const
|
||||
{
|
||||
return m_parent->GetController();
|
||||
}
|
||||
|
||||
QPushButton*
|
||||
MappingWidget::CreateSettingAdvancedMappingButton(ControllerEmu::NumericSettingBase& setting)
|
||||
{
|
||||
const auto button = new QPushButton(tr("..."));
|
||||
button->setFixedWidth(QFontMetrics(font()).boundingRect(button->text()).width() * 2);
|
||||
|
||||
button->connect(button, &QPushButton::clicked, [this, &setting]() {
|
||||
if (setting.IsSimpleValue())
|
||||
setting.SetExpressionFromValue();
|
||||
|
||||
IOWindow io(this, GetController(), &setting.GetInputReference(), IOWindow::Type::Input);
|
||||
io.exec();
|
||||
|
||||
setting.SimplifyIfPossible();
|
||||
|
||||
ConfigChanged();
|
||||
SaveSettings();
|
||||
});
|
||||
|
||||
return button;
|
||||
}
|
||||
|
@ -17,6 +17,7 @@ class InputConfig;
|
||||
class MappingButton;
|
||||
class MappingNumeric;
|
||||
class MappingWindow;
|
||||
class QPushButton;
|
||||
class QGroupBox;
|
||||
|
||||
namespace ControllerEmu
|
||||
@ -24,13 +25,9 @@ namespace ControllerEmu
|
||||
class Control;
|
||||
class ControlGroup;
|
||||
class EmulatedController;
|
||||
class NumericSettingBase;
|
||||
} // namespace ControllerEmu
|
||||
|
||||
namespace ciface::Core
|
||||
{
|
||||
class Device;
|
||||
} // namespace ciface::Core
|
||||
|
||||
constexpr int INDICATOR_UPDATE_FREQ = 30;
|
||||
|
||||
class MappingWidget : public QWidget
|
||||
@ -56,6 +53,7 @@ protected:
|
||||
|
||||
QGroupBox* CreateGroupBox(ControllerEmu::ControlGroup* group);
|
||||
QGroupBox* CreateGroupBox(const QString& name, ControllerEmu::ControlGroup* group);
|
||||
QPushButton* CreateSettingAdvancedMappingButton(ControllerEmu::NumericSettingBase& setting);
|
||||
|
||||
private:
|
||||
MappingWindow* m_parent;
|
||||
|
@ -11,6 +11,7 @@
|
||||
#include <QHBoxLayout>
|
||||
#include <QPushButton>
|
||||
#include <QTabWidget>
|
||||
#include <QTimer>
|
||||
#include <QVBoxLayout>
|
||||
|
||||
#include "Core/Core.h"
|
||||
@ -62,6 +63,15 @@ MappingWindow::MappingWindow(QWidget* parent, Type type, int port_num)
|
||||
ConnectWidgets();
|
||||
SetMappingType(type);
|
||||
|
||||
const auto timer = new QTimer(this);
|
||||
connect(timer, &QTimer::timeout, this, [this] {
|
||||
const auto lock = GetController()->GetStateLock();
|
||||
emit Update();
|
||||
});
|
||||
|
||||
timer->start(1000 / INDICATOR_UPDATE_FREQ);
|
||||
|
||||
GetController()->GetStateLock();
|
||||
emit ConfigChanged();
|
||||
}
|
||||
|
||||
@ -235,6 +245,7 @@ void MappingWindow::OnLoadProfilePressed()
|
||||
m_controller->LoadConfig(ini.GetOrCreateSection("Profile"));
|
||||
m_controller->UpdateReferences(g_controller_interface);
|
||||
|
||||
GetController()->GetStateLock();
|
||||
emit ConfigChanged();
|
||||
}
|
||||
|
||||
@ -426,6 +437,8 @@ void MappingWindow::OnDefaultFieldsPressed()
|
||||
{
|
||||
m_controller->LoadDefaults(g_controller_interface);
|
||||
m_controller->UpdateReferences(g_controller_interface);
|
||||
|
||||
GetController()->GetStateLock();
|
||||
emit ConfigChanged();
|
||||
emit Save();
|
||||
}
|
||||
@ -441,6 +454,8 @@ void MappingWindow::OnClearFieldsPressed()
|
||||
m_controller->SetDefaultDevice(default_device);
|
||||
|
||||
m_controller->UpdateReferences(g_controller_interface);
|
||||
|
||||
GetController()->GetStateLock();
|
||||
emit ConfigChanged();
|
||||
emit Save();
|
||||
}
|
||||
|
@ -8,6 +8,8 @@
|
||||
#include <QFormLayout>
|
||||
#include <QGridLayout>
|
||||
#include <QGroupBox>
|
||||
#include <QLabel>
|
||||
#include <QPushButton>
|
||||
|
||||
#include "Core/HW/Wiimote.h"
|
||||
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
||||
@ -22,7 +24,7 @@ WiimoteEmuGeneral::WiimoteEmuGeneral(MappingWindow* window, WiimoteEmuExtension*
|
||||
: MappingWidget(window), m_extension_widget(extension)
|
||||
{
|
||||
CreateMainLayout();
|
||||
Connect(window);
|
||||
Connect();
|
||||
}
|
||||
|
||||
void WiimoteEmuGeneral::CreateMainLayout()
|
||||
@ -45,14 +47,20 @@ void WiimoteEmuGeneral::CreateMainLayout()
|
||||
Wiimote::GetWiimoteGroup(GetPort(), WiimoteEmu::WiimoteGroup::Attachments);
|
||||
auto* extension = CreateGroupBox(tr("Extension"), extension_group);
|
||||
auto* ce_extension = static_cast<ControllerEmu::Attachments*>(extension_group);
|
||||
m_extension_combo = new QComboBox();
|
||||
|
||||
const auto combo_hbox = new QHBoxLayout;
|
||||
combo_hbox->addWidget(m_extension_combo = new QComboBox());
|
||||
combo_hbox->addWidget(m_extension_combo_dynamic_indicator = new QLabel(QString::fromUtf8("🎮")));
|
||||
combo_hbox->addWidget(CreateSettingAdvancedMappingButton(ce_extension->GetSelectionSetting()));
|
||||
|
||||
m_extension_combo_dynamic_indicator->setSizePolicy(QSizePolicy::Maximum, QSizePolicy::Ignored);
|
||||
|
||||
for (const auto& attachment : ce_extension->GetAttachmentList())
|
||||
m_extension_combo->addItem(tr(attachment->GetDisplayName().c_str()));
|
||||
|
||||
extension->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Fixed);
|
||||
|
||||
static_cast<QFormLayout*>(extension->layout())->insertRow(0, m_extension_combo);
|
||||
static_cast<QFormLayout*>(extension->layout())->insertRow(0, combo_hbox);
|
||||
|
||||
layout->addWidget(extension, 0, 3);
|
||||
layout->addWidget(CreateGroupBox(tr("Rumble"), Wiimote::GetWiimoteGroup(
|
||||
@ -67,11 +75,14 @@ void WiimoteEmuGeneral::CreateMainLayout()
|
||||
setLayout(layout);
|
||||
}
|
||||
|
||||
void WiimoteEmuGeneral::Connect(MappingWindow* window)
|
||||
void WiimoteEmuGeneral::Connect()
|
||||
{
|
||||
connect(m_extension_combo, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged),
|
||||
this, &WiimoteEmuGeneral::OnAttachmentChanged);
|
||||
connect(window, &MappingWindow::ConfigChanged, this, &WiimoteEmuGeneral::ConfigChanged);
|
||||
connect(m_extension_combo, QOverload<int>::of(&QComboBox::currentIndexChanged), this,
|
||||
&WiimoteEmuGeneral::OnAttachmentChanged);
|
||||
connect(m_extension_combo, QOverload<int>::of(&QComboBox::activated), this,
|
||||
&WiimoteEmuGeneral::OnAttachmentSelected);
|
||||
connect(this, &MappingWidget::ConfigChanged, this, &WiimoteEmuGeneral::ConfigChanged);
|
||||
connect(this, &MappingWidget::Update, this, &WiimoteEmuGeneral::Update);
|
||||
}
|
||||
|
||||
void WiimoteEmuGeneral::OnAttachmentChanged(int extension)
|
||||
@ -79,15 +90,31 @@ void WiimoteEmuGeneral::OnAttachmentChanged(int extension)
|
||||
GetParent()->ShowExtensionMotionTabs(extension == WiimoteEmu::ExtensionNumber::NUNCHUK);
|
||||
|
||||
m_extension_widget->ChangeExtensionType(extension);
|
||||
}
|
||||
|
||||
void WiimoteEmuGeneral::OnAttachmentSelected(int extension)
|
||||
{
|
||||
auto* ce_extension = static_cast<ControllerEmu::Attachments*>(
|
||||
Wiimote::GetWiimoteGroup(GetPort(), WiimoteEmu::WiimoteGroup::Attachments));
|
||||
|
||||
ce_extension->SetSelectedAttachment(extension);
|
||||
|
||||
ConfigChanged();
|
||||
SaveSettings();
|
||||
}
|
||||
|
||||
void WiimoteEmuGeneral::ConfigChanged()
|
||||
{
|
||||
auto* ce_extension = static_cast<ControllerEmu::Attachments*>(
|
||||
Wiimote::GetWiimoteGroup(GetPort(), WiimoteEmu::WiimoteGroup::Attachments));
|
||||
|
||||
m_extension_combo->setCurrentIndex(ce_extension->GetSelectedAttachment());
|
||||
|
||||
m_extension_combo_dynamic_indicator->setVisible(
|
||||
!ce_extension->GetSelectionSetting().IsSimpleValue());
|
||||
}
|
||||
|
||||
void WiimoteEmuGeneral::Update()
|
||||
{
|
||||
auto* ce_extension = static_cast<ControllerEmu::Attachments*>(
|
||||
Wiimote::GetWiimoteGroup(GetPort(), WiimoteEmu::WiimoteGroup::Attachments));
|
||||
|
@ -7,6 +7,7 @@
|
||||
#include "DolphinQt/Config/Mapping/MappingWidget.h"
|
||||
|
||||
class QComboBox;
|
||||
class QLabel;
|
||||
class WiimoteEmuExtension;
|
||||
|
||||
class WiimoteEmuGeneral final : public MappingWidget
|
||||
@ -21,12 +22,19 @@ private:
|
||||
void LoadSettings() override;
|
||||
void SaveSettings() override;
|
||||
void CreateMainLayout();
|
||||
void Connect(MappingWindow* window);
|
||||
void Connect();
|
||||
|
||||
// Index changed by code/expression.
|
||||
void OnAttachmentChanged(int index);
|
||||
// Selection chosen by user.
|
||||
void OnAttachmentSelected(int index);
|
||||
|
||||
void ConfigChanged();
|
||||
void Update();
|
||||
|
||||
// Extensions
|
||||
QComboBox* m_extension_combo;
|
||||
QLabel* m_extension_combo_dynamic_indicator;
|
||||
|
||||
WiimoteEmuExtension* m_extension_widget;
|
||||
};
|
||||
|
Reference in New Issue
Block a user