Skip to content

Commit

Permalink
lime_qt: Add diagonal directional input bindings for circlepad and c-…
Browse files Browse the repository at this point in the history
…stick (#404)

Co-authored-by: OpenSauce04 <[email protected]>
  • Loading branch information
kleidis and OpenSauce04 authored Oct 29, 2024
1 parent da2912e commit 21aec70
Show file tree
Hide file tree
Showing 5 changed files with 382 additions and 132 deletions.
40 changes: 34 additions & 6 deletions src/input_common/analog_from_button.cpp
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
// Copyright 2017 Citra Emulator Project
// Copyright Citra Emulator Project / Lime3DS Emulator Project
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.

Expand All @@ -10,11 +10,12 @@ class Analog final : public Input::AnalogDevice {
public:
using Button = std::unique_ptr<Input::ButtonDevice>;

Analog(Button up_, Button down_, Button left_, Button right_, Button modifier_,
float modifier_scale_)
Analog(Button up_, Button down_, Button left_, Button right_, Button up_left_, Button up_right_,
Button down_left_, Button down_right_, Button modifier_, float modifier_scale_)
: up(std::move(up_)), down(std::move(down_)), left(std::move(left_)),
right(std::move(right_)), modifier(std::move(modifier_)),
modifier_scale(modifier_scale_) {}
right(std::move(right_)), up_left(std::move(up_left_)), up_right(std::move(up_right_)),
down_left(std::move(down_left_)), down_right(std::move(down_right_)),
modifier(std::move(modifier_)), modifier_scale(modifier_scale_) {}

std::tuple<float, float> GetStatus() const override {
constexpr float SQRT_HALF = 0.707106781f;
Expand All @@ -28,6 +29,22 @@ class Analog final : public Input::AnalogDevice {
++y;
if (down->GetStatus())
--y;
if (up_right->GetStatus()) {
++x;
++y;
}
if (up_left->GetStatus()) {
--x;
++y;
}
if (down_right->GetStatus()) {
++x;
--y;
}
if (down_left->GetStatus()) {
--x;
--y;
}

float coef = modifier->GetStatus() ? modifier_scale : 1.0f;
return std::make_tuple(x * coef * (y == 0 ? 1.0f : SQRT_HALF),
Expand All @@ -39,6 +56,10 @@ class Analog final : public Input::AnalogDevice {
Button down;
Button left;
Button right;
Button up_left;
Button up_right;
Button down_left;
Button down_right;
Button modifier;
float modifier_scale;
};
Expand All @@ -49,10 +70,17 @@ std::unique_ptr<Input::AnalogDevice> AnalogFromButton::Create(const Common::Para
auto down = Input::CreateDevice<Input::ButtonDevice>(params.Get("down", null_engine));
auto left = Input::CreateDevice<Input::ButtonDevice>(params.Get("left", null_engine));
auto right = Input::CreateDevice<Input::ButtonDevice>(params.Get("right", null_engine));
auto up_left = Input::CreateDevice<Input::ButtonDevice>(params.Get("up_left", null_engine));
auto up_right = Input::CreateDevice<Input::ButtonDevice>(params.Get("up_right", null_engine));
auto down_left = Input::CreateDevice<Input::ButtonDevice>(params.Get("down_left", null_engine));
auto down_right =
Input::CreateDevice<Input::ButtonDevice>(params.Get("down_right", null_engine));
auto modifier = Input::CreateDevice<Input::ButtonDevice>(params.Get("modifier", null_engine));
auto modifier_scale = params.Get("modifier_scale", 0.5f);
return std::make_unique<Analog>(std::move(up), std::move(down), std::move(left),
std::move(right), std::move(modifier), modifier_scale);
std::move(right), std::move(up_left), std::move(up_right),
std::move(down_left), std::move(down_right),
std::move(modifier), modifier_scale);
}

} // namespace InputCommon
9 changes: 5 additions & 4 deletions src/lime_qt/configuration/config.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -382,10 +382,11 @@ void QtConfig::ReadControlValues() {
std::string default_param = InputCommon::GenerateAnalogParamFromKeys(
default_analogs[i][0], default_analogs[i][1], default_analogs[i][2],
default_analogs[i][3], default_analogs[i][4], 0.5f);
profile.analogs[i] = ReadSetting(QString::fromUtf8(Settings::NativeAnalog::mapping[i]),
QString::fromStdString(default_param))
.toString()
.toStdString();
profile.analogs[i] =
ReadSetting(QString::fromStdString(Settings::NativeAnalog::mapping[i]),
QString::fromStdString(default_param))
.toString()
.toStdString();
if (profile.analogs[i].empty())
profile.analogs[i] = default_param;
}
Expand Down
28 changes: 21 additions & 7 deletions src/lime_qt/configuration/configure_input.cpp
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
// Copyright 2016 Citra Emulator Project
// Copyright Citra Emulator Project / Lime3DS Emulator Project
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.

Expand All @@ -25,6 +25,10 @@ const std::array<std::string, ConfigureInput::ANALOG_SUB_BUTTONS_NUM>
"down",
"left",
"right",
"up_left",
"up_right",
"down_left",
"down_right",
"modifier",
}};

Expand All @@ -33,6 +37,10 @@ enum class AnalogSubButtons {
down,
left,
right,
up_left,
up_right,
down_left,
down_right,
modifier,
};

Expand Down Expand Up @@ -172,13 +180,21 @@ ConfigureInput::ConfigureInput(Core::System& _system, QWidget* parent)
ui->buttonCircleDown,
ui->buttonCircleLeft,
ui->buttonCircleRight,
ui->buttonCircleUpLeft,
ui->buttonCircleUpRight,
ui->buttonCircleDownLeft,
ui->buttonCircleDownRight,
nullptr,
},
{
ui->buttonCStickUp,
ui->buttonCStickDown,
ui->buttonCStickLeft,
ui->buttonCStickRight,
ui->buttonCStickUpLeft,
ui->buttonCStickUpRight,
ui->buttonCStickDownLeft,
ui->buttonCStickDownRight,
nullptr,
},
}};
Expand Down Expand Up @@ -469,12 +485,10 @@ void ConfigureInput::RestoreDefaults() {
}

for (int analog_id = 0; analog_id < Settings::NativeAnalog::NumAnalogs; analog_id++) {
for (int sub_button_id = 0; sub_button_id < ANALOG_SUB_BUTTONS_NUM; sub_button_id++) {
Common::ParamPackage params{InputCommon::GenerateKeyboardParam(
QtConfig::default_analogs[analog_id][sub_button_id])};
SetAnalogButton(params, analogs_param[analog_id], analog_sub_buttons[sub_button_id]);
}
analogs_param[analog_id].Set("modifier_scale", 0.5f);
analogs_param[analog_id] = Common::ParamPackage{InputCommon::GenerateAnalogParamFromKeys(
QtConfig::default_analogs[analog_id][0], QtConfig::default_analogs[analog_id][1],
QtConfig::default_analogs[analog_id][2], QtConfig::default_analogs[analog_id][3],
QtConfig::default_analogs[analog_id][4], 0.5f)};
}
UpdateButtonLabels();

Expand Down
4 changes: 2 additions & 2 deletions src/lime_qt/configuration/configure_input.h
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
// Copyright 2016 Citra Emulator Project
// Copyright Citra Emulator Project / Lime3DS Emulator Project
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.

Expand Down Expand Up @@ -62,7 +62,7 @@ public slots:
std::array<Common::ParamPackage, Settings::NativeButton::NumButtons> buttons_param;
std::array<Common::ParamPackage, Settings::NativeAnalog::NumAnalogs> analogs_param;

static constexpr int ANALOG_SUB_BUTTONS_NUM = 5;
static constexpr int ANALOG_SUB_BUTTONS_NUM = 9;

/// Each button input is represented by a QPushButton.
std::array<QPushButton*, Settings::NativeButton::NumButtons> button_map;
Expand Down
Loading

0 comments on commit 21aec70

Please sign in to comment.