configure_system: Implement with for loop
This commit is contained in:
parent
56960bf9f8
commit
8e15146026
|
@ -162,6 +162,7 @@ const char* TranslateCategory(Category category) {
|
||||||
case Category::RendererDebug:
|
case Category::RendererDebug:
|
||||||
return "Renderer";
|
return "Renderer";
|
||||||
case Category::System:
|
case Category::System:
|
||||||
|
case Category::SystemAudio:
|
||||||
return "System";
|
return "System";
|
||||||
case Category::DataStorage:
|
case Category::DataStorage:
|
||||||
return "Data Storage";
|
return "Data Storage";
|
||||||
|
|
|
@ -20,6 +20,86 @@
|
||||||
|
|
||||||
namespace Settings {
|
namespace Settings {
|
||||||
|
|
||||||
|
enum class Language : u32 {
|
||||||
|
Japanese,
|
||||||
|
EnglishAmerican,
|
||||||
|
French,
|
||||||
|
German,
|
||||||
|
Italian,
|
||||||
|
Spanish,
|
||||||
|
Chinese,
|
||||||
|
Korean,
|
||||||
|
Dutch,
|
||||||
|
Portuguese,
|
||||||
|
Russian,
|
||||||
|
Taiwanese,
|
||||||
|
EnglishBritish,
|
||||||
|
FrenchCanadian,
|
||||||
|
SpanishLatin,
|
||||||
|
ChineseSimplified,
|
||||||
|
ChineseTraditional,
|
||||||
|
PortugueseBrazilian,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum class Region : u32 {
|
||||||
|
Japan,
|
||||||
|
USA,
|
||||||
|
Europe,
|
||||||
|
Australia,
|
||||||
|
China,
|
||||||
|
Korea,
|
||||||
|
Taiwan,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum class TimeZone : u32 {
|
||||||
|
Auto,
|
||||||
|
Default,
|
||||||
|
CET,
|
||||||
|
CST6CDT,
|
||||||
|
Cuba,
|
||||||
|
EET,
|
||||||
|
Egypt,
|
||||||
|
Eire,
|
||||||
|
EST,
|
||||||
|
EST5EDT,
|
||||||
|
GB,
|
||||||
|
GBEire,
|
||||||
|
GMT,
|
||||||
|
GMTPlusZero,
|
||||||
|
GMTMinusZero,
|
||||||
|
GMTZero,
|
||||||
|
Greenwich,
|
||||||
|
Hongkong,
|
||||||
|
HST,
|
||||||
|
Iceland,
|
||||||
|
Iran,
|
||||||
|
Israel,
|
||||||
|
Jamaica,
|
||||||
|
Japan,
|
||||||
|
Kwajalein,
|
||||||
|
Libya,
|
||||||
|
MET,
|
||||||
|
MST,
|
||||||
|
MST7MDT,
|
||||||
|
Navajo,
|
||||||
|
NZ,
|
||||||
|
NZCHAT,
|
||||||
|
Poland,
|
||||||
|
Portugal,
|
||||||
|
PRC,
|
||||||
|
PST8PDT,
|
||||||
|
ROC,
|
||||||
|
ROK,
|
||||||
|
Singapore,
|
||||||
|
Turkey,
|
||||||
|
UCT,
|
||||||
|
Universal,
|
||||||
|
UTC,
|
||||||
|
W_SU,
|
||||||
|
WET,
|
||||||
|
Zulu,
|
||||||
|
};
|
||||||
|
|
||||||
enum class AnisotropyMode : u32 {
|
enum class AnisotropyMode : u32 {
|
||||||
Automatic = 0,
|
Automatic = 0,
|
||||||
Default = 1,
|
Default = 1,
|
||||||
|
@ -134,6 +214,7 @@ enum class Category : u32 {
|
||||||
RendererAdvanced,
|
RendererAdvanced,
|
||||||
RendererDebug,
|
RendererDebug,
|
||||||
System,
|
System,
|
||||||
|
SystemAudio,
|
||||||
DataStorage,
|
DataStorage,
|
||||||
Debugging,
|
Debugging,
|
||||||
DebuggingGraphics,
|
DebuggingGraphics,
|
||||||
|
@ -810,22 +891,31 @@ struct Values {
|
||||||
SwitchableSetting<u8, false> bg_blue{linkage, 0, "bg_blue", Category::Renderer, true, true};
|
SwitchableSetting<u8, false> bg_blue{linkage, 0, "bg_blue", Category::Renderer, true, true};
|
||||||
|
|
||||||
// System
|
// System
|
||||||
SwitchableSetting<bool> rng_seed_enabled{linkage, false, "rng_seed_enabled", Category::System};
|
SwitchableSetting<bool> rng_seed_enabled{linkage, false, "rng_seed_enabled",
|
||||||
SwitchableSetting<u32> rng_seed{linkage, 0, "rng_seed", Category::System};
|
Category::System, true, true};
|
||||||
Setting<std::string> device_name{linkage, "Yuzu", "device_name", Category::System};
|
SwitchableSetting<u32> rng_seed{linkage, 0, "rng_seed", Category::System, true, true};
|
||||||
|
Setting<std::string> device_name{linkage, "Yuzu", "device_name", Category::System, true, true};
|
||||||
// Measured in seconds since epoch
|
// Measured in seconds since epoch
|
||||||
Setting<bool> custom_rtc_enabled{linkage, false, "custom_rtc_enabled", Category::System};
|
SwitchableSetting<bool> custom_rtc_enabled{linkage, false, "custom_rtc_enabled",
|
||||||
Setting<s64> custom_rtc{linkage, 0, "custom_rtc", Category::System};
|
Category::System, true, true};
|
||||||
|
SwitchableSetting<s64> custom_rtc{linkage, 0, "custom_rtc", Category::System, true, true};
|
||||||
// Set on game boot, reset on stop. Seconds difference between current time and `custom_rtc`
|
// Set on game boot, reset on stop. Seconds difference between current time and `custom_rtc`
|
||||||
s64 custom_rtc_differential;
|
s64 custom_rtc_differential;
|
||||||
|
|
||||||
Setting<s32> current_user{linkage, 0, "current_user", Category::System};
|
Setting<s32> current_user{linkage, 0, "current_user", Category::System};
|
||||||
SwitchableSetting<s32, true> language_index{linkage, 1, 0, 17, "language_index",
|
SwitchableSetting<Language, true> language_index{linkage,
|
||||||
|
Language::EnglishAmerican,
|
||||||
|
Language::Japanese,
|
||||||
|
Language::PortugueseBrazilian,
|
||||||
|
"language_index",
|
||||||
Category::System};
|
Category::System};
|
||||||
SwitchableSetting<s32, true> region_index{linkage, 1, 0, 6, "region_index", Category::System};
|
SwitchableSetting<Region, true> region_index{linkage, Region::USA, Region::Japan,
|
||||||
SwitchableSetting<s32, true> time_zone_index{linkage, 0, 0, 45, "time_zone_index",
|
Region::Taiwan, "region_index", Category::System};
|
||||||
Category::System};
|
SwitchableSetting<TimeZone, true> time_zone_index{linkage, TimeZone::Auto,
|
||||||
SwitchableSetting<s32, true> sound_index{linkage, 1, 0, 2, "sound_index", Category::System};
|
TimeZone::Auto, TimeZone::Zulu,
|
||||||
|
"time_zone_index", Category::System};
|
||||||
|
SwitchableSetting<s32, true> sound_index{
|
||||||
|
linkage, 1, 0, 2, "sound_index", Category::SystemAudio};
|
||||||
|
|
||||||
SwitchableSetting<bool> use_docked_mode{linkage, true, "use_docked_mode", Category::System};
|
SwitchableSetting<bool> use_docked_mode{linkage, true, "use_docked_mode", Category::System};
|
||||||
|
|
||||||
|
|
|
@ -145,13 +145,7 @@ struct System::Impl {
|
||||||
core_timing.SetMulticore(is_multicore);
|
core_timing.SetMulticore(is_multicore);
|
||||||
core_timing.Initialize([&system]() { system.RegisterHostThread(); });
|
core_timing.Initialize([&system]() { system.RegisterHostThread(); });
|
||||||
|
|
||||||
const auto posix_time = std::chrono::system_clock::now().time_since_epoch();
|
RefreshTime();
|
||||||
const auto current_time =
|
|
||||||
std::chrono::duration_cast<std::chrono::seconds>(posix_time).count();
|
|
||||||
Settings::values.custom_rtc_differential =
|
|
||||||
(Settings::values.custom_rtc_enabled ? Settings::values.custom_rtc.GetValue()
|
|
||||||
: current_time) -
|
|
||||||
current_time;
|
|
||||||
|
|
||||||
// Create a default fs if one doesn't already exist.
|
// Create a default fs if one doesn't already exist.
|
||||||
if (virtual_filesystem == nullptr) {
|
if (virtual_filesystem == nullptr) {
|
||||||
|
@ -188,6 +182,16 @@ struct System::Impl {
|
||||||
Initialize(system);
|
Initialize(system);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void RefreshTime() {
|
||||||
|
const auto posix_time = std::chrono::system_clock::now().time_since_epoch();
|
||||||
|
const auto current_time =
|
||||||
|
std::chrono::duration_cast<std::chrono::seconds>(posix_time).count();
|
||||||
|
Settings::values.custom_rtc_differential =
|
||||||
|
(Settings::values.custom_rtc_enabled ? Settings::values.custom_rtc.GetValue()
|
||||||
|
: current_time) -
|
||||||
|
current_time;
|
||||||
|
}
|
||||||
|
|
||||||
void Run() {
|
void Run() {
|
||||||
std::unique_lock<std::mutex> lk(suspend_guard);
|
std::unique_lock<std::mutex> lk(suspend_guard);
|
||||||
|
|
||||||
|
@ -1022,6 +1026,8 @@ void System::Exit() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void System::ApplySettings() {
|
void System::ApplySettings() {
|
||||||
|
impl->RefreshTime();
|
||||||
|
|
||||||
if (IsPoweredOn()) {
|
if (IsPoweredOn()) {
|
||||||
Renderer().RefreshBaseSettings();
|
Renderer().RefreshBaseSettings();
|
||||||
}
|
}
|
||||||
|
|
|
@ -68,7 +68,8 @@ NACP::NACP(VirtualFile file) {
|
||||||
NACP::~NACP() = default;
|
NACP::~NACP() = default;
|
||||||
|
|
||||||
const LanguageEntry& NACP::GetLanguageEntry() const {
|
const LanguageEntry& NACP::GetLanguageEntry() const {
|
||||||
Language language = language_to_codes[Settings::values.language_index.GetValue()];
|
Language language =
|
||||||
|
language_to_codes[static_cast<s32>(Settings::values.language_index.GetValue())];
|
||||||
|
|
||||||
{
|
{
|
||||||
const auto& language_entry = raw.language_entries.at(static_cast<u8>(language));
|
const auto& language_entry = raw.language_entries.at(static_cast<u8>(language));
|
||||||
|
|
|
@ -626,8 +626,8 @@ PatchManager::Metadata PatchManager::ParseControlNCA(const NCA& nca) const {
|
||||||
auto nacp = nacp_file == nullptr ? nullptr : std::make_unique<NACP>(nacp_file);
|
auto nacp = nacp_file == nullptr ? nullptr : std::make_unique<NACP>(nacp_file);
|
||||||
|
|
||||||
// Get language code from settings
|
// Get language code from settings
|
||||||
const auto language_code =
|
const auto language_code = Service::Set::GetLanguageCodeFromIndex(
|
||||||
Service::Set::GetLanguageCodeFromIndex(Settings::values.language_index.GetValue());
|
static_cast<u32>(Settings::values.language_index.GetValue()));
|
||||||
|
|
||||||
// Convert to application language and get priority list
|
// Convert to application language and get priority list
|
||||||
const auto application_language =
|
const auto application_language =
|
||||||
|
|
|
@ -409,7 +409,7 @@ ResultVal<u8> IApplicationManagerInterface::GetApplicationDesiredLanguage(
|
||||||
|
|
||||||
// Get language code from settings
|
// Get language code from settings
|
||||||
const auto language_code =
|
const auto language_code =
|
||||||
Set::GetLanguageCodeFromIndex(Settings::values.language_index.GetValue());
|
Set::GetLanguageCodeFromIndex(static_cast<s32>(Settings::values.language_index.GetValue()));
|
||||||
|
|
||||||
// Convert to application language, get priority list
|
// Convert to application language, get priority list
|
||||||
const auto application_language = ConvertToApplicationLanguage(language_code);
|
const auto application_language = ConvertToApplicationLanguage(language_code);
|
||||||
|
|
|
@ -93,7 +93,8 @@ void GetAvailableLanguageCodesImpl(HLERequestContext& ctx, std::size_t max_entri
|
||||||
}
|
}
|
||||||
|
|
||||||
void GetKeyCodeMapImpl(HLERequestContext& ctx) {
|
void GetKeyCodeMapImpl(HLERequestContext& ctx) {
|
||||||
const auto language_code = available_language_codes[Settings::values.language_index.GetValue()];
|
const auto language_code =
|
||||||
|
available_language_codes[static_cast<s32>(Settings::values.language_index.GetValue())];
|
||||||
const auto key_code =
|
const auto key_code =
|
||||||
std::find_if(language_to_layout.cbegin(), language_to_layout.cend(),
|
std::find_if(language_to_layout.cbegin(), language_to_layout.cend(),
|
||||||
[=](const auto& element) { return element.first == language_code; });
|
[=](const auto& element) { return element.first == language_code; });
|
||||||
|
@ -162,7 +163,7 @@ void SET::GetQuestFlag(HLERequestContext& ctx) {
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 3};
|
IPC::ResponseBuilder rb{ctx, 3};
|
||||||
rb.Push(ResultSuccess);
|
rb.Push(ResultSuccess);
|
||||||
rb.Push(static_cast<u32>(Settings::values.quest_flag.GetValue()));
|
rb.Push(static_cast<s32>(Settings::values.quest_flag.GetValue()));
|
||||||
}
|
}
|
||||||
|
|
||||||
void SET::GetLanguageCode(HLERequestContext& ctx) {
|
void SET::GetLanguageCode(HLERequestContext& ctx) {
|
||||||
|
@ -170,7 +171,8 @@ void SET::GetLanguageCode(HLERequestContext& ctx) {
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 4};
|
IPC::ResponseBuilder rb{ctx, 4};
|
||||||
rb.Push(ResultSuccess);
|
rb.Push(ResultSuccess);
|
||||||
rb.PushEnum(available_language_codes[Settings::values.language_index.GetValue()]);
|
rb.PushEnum(
|
||||||
|
available_language_codes[static_cast<s32>(Settings::values.language_index.GetValue())]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SET::GetRegionCode(HLERequestContext& ctx) {
|
void SET::GetRegionCode(HLERequestContext& ctx) {
|
||||||
|
@ -178,7 +180,7 @@ void SET::GetRegionCode(HLERequestContext& ctx) {
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 3};
|
IPC::ResponseBuilder rb{ctx, 3};
|
||||||
rb.Push(ResultSuccess);
|
rb.Push(ResultSuccess);
|
||||||
rb.Push(Settings::values.region_index.GetValue());
|
rb.Push(static_cast<u32>(Settings::values.region_index.GetValue()));
|
||||||
}
|
}
|
||||||
|
|
||||||
void SET::GetKeyCodeMap(HLERequestContext& ctx) {
|
void SET::GetKeyCodeMap(HLERequestContext& ctx) {
|
||||||
|
|
|
@ -696,6 +696,7 @@ void Config::ReadSystemValues() {
|
||||||
qt_config->beginGroup(QStringLiteral("System"));
|
qt_config->beginGroup(QStringLiteral("System"));
|
||||||
|
|
||||||
ReadCategory(Settings::Category::System);
|
ReadCategory(Settings::Category::System);
|
||||||
|
ReadCategory(Settings::Category::SystemAudio);
|
||||||
|
|
||||||
qt_config->endGroup();
|
qt_config->endGroup();
|
||||||
}
|
}
|
||||||
|
@ -1134,6 +1135,7 @@ void Config::SaveSystemValues() {
|
||||||
qt_config->beginGroup(QStringLiteral("System"));
|
qt_config->beginGroup(QStringLiteral("System"));
|
||||||
|
|
||||||
WriteCategory(Settings::Category::System);
|
WriteCategory(Settings::Category::System);
|
||||||
|
WriteCategory(Settings::Category::SystemAudio);
|
||||||
|
|
||||||
qt_config->endGroup();
|
qt_config->endGroup();
|
||||||
}
|
}
|
||||||
|
|
|
@ -48,7 +48,7 @@ ConfigureDialog::ConfigureDialog(QWidget* parent, HotkeyRegistry& registry_,
|
||||||
input_tab{std::make_unique<ConfigureInput>(system_, this)},
|
input_tab{std::make_unique<ConfigureInput>(system_, this)},
|
||||||
network_tab{std::make_unique<ConfigureNetwork>(system_, this)},
|
network_tab{std::make_unique<ConfigureNetwork>(system_, this)},
|
||||||
profile_tab{std::make_unique<ConfigureProfileManager>(system_, this)},
|
profile_tab{std::make_unique<ConfigureProfileManager>(system_, this)},
|
||||||
system_tab{std::make_unique<ConfigureSystem>(system_, nullptr, this)},
|
system_tab{std::make_unique<ConfigureSystem>(system_, nullptr, *translations, this)},
|
||||||
ui_tab{std::make_unique<ConfigureUi>(system_, this)}, web_tab{std::make_unique<ConfigureWeb>(
|
ui_tab{std::make_unique<ConfigureUi>(system_, this)}, web_tab{std::make_unique<ConfigureWeb>(
|
||||||
this)} {
|
this)} {
|
||||||
Settings::SetConfiguringGlobal(true);
|
Settings::SetConfiguringGlobal(true);
|
||||||
|
|
|
@ -240,7 +240,7 @@ void ConfigureGraphics::Setup() {
|
||||||
return new ConfigurationShared::Widget(
|
return new ConfigurationShared::Widget(
|
||||||
setting, translations, this, runtime_lock, apply_funcs,
|
setting, translations, this, runtime_lock, apply_funcs,
|
||||||
ConfigurationShared::RequestType::SpinBox, true, 1.0f,
|
ConfigurationShared::RequestType::SpinBox, true, 1.0f,
|
||||||
&Settings::values.speed_limit, QStringLiteral("%"));
|
&Settings::values.speed_limit, "%");
|
||||||
} else {
|
} else {
|
||||||
return new ConfigurationShared::Widget(setting, translations, this, runtime_lock,
|
return new ConfigurationShared::Widget(setting, translations, this, runtime_lock,
|
||||||
apply_funcs);
|
apply_funcs);
|
||||||
|
|
|
@ -58,7 +58,7 @@ ConfigurePerGame::ConfigurePerGame(QWidget* parent, u64 title_id_, const std::st
|
||||||
system_, vk_device_records, [&]() { graphics_advanced_tab->ExposeComputeOption(); },
|
system_, vk_device_records, [&]() { graphics_advanced_tab->ExposeComputeOption(); },
|
||||||
tab_group, *translations, this);
|
tab_group, *translations, this);
|
||||||
input_tab = std::make_unique<ConfigureInputPerGame>(system_, game_config.get(), this);
|
input_tab = std::make_unique<ConfigureInputPerGame>(system_, game_config.get(), this);
|
||||||
system_tab = std::make_unique<ConfigureSystem>(system_, tab_group, this);
|
system_tab = std::make_unique<ConfigureSystem>(system_, tab_group, *translations, this);
|
||||||
|
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
|
|
||||||
|
|
|
@ -2,17 +2,22 @@
|
||||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
#include <chrono>
|
#include <chrono>
|
||||||
|
#include <forward_list>
|
||||||
#include <optional>
|
#include <optional>
|
||||||
|
|
||||||
|
#include <QDateTimeEdit>
|
||||||
#include <QFileDialog>
|
#include <QFileDialog>
|
||||||
#include <QGraphicsItem>
|
#include <QGraphicsItem>
|
||||||
|
#include <QLineEdit>
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include "common/settings.h"
|
#include "common/settings.h"
|
||||||
#include "core/core.h"
|
#include "core/core.h"
|
||||||
#include "core/hle/service/time/time_manager.h"
|
#include "core/hle/service/time/time_manager.h"
|
||||||
#include "ui_configure_system.h"
|
#include "ui_configure_system.h"
|
||||||
|
#include "yuzu/configuration/config.h"
|
||||||
#include "yuzu/configuration/configuration_shared.h"
|
#include "yuzu/configuration/configuration_shared.h"
|
||||||
#include "yuzu/configuration/configure_system.h"
|
#include "yuzu/configuration/configure_system.h"
|
||||||
|
#include "yuzu/configuration/shared_widget.h"
|
||||||
|
|
||||||
constexpr std::array<u32, 7> LOCALE_BLOCKLIST{
|
constexpr std::array<u32, 7> LOCALE_BLOCKLIST{
|
||||||
// pzzefezrpnkzeidfej
|
// pzzefezrpnkzeidfej
|
||||||
|
@ -39,44 +44,42 @@ static bool IsValidLocale(u32 region_index, u32 language_index) {
|
||||||
|
|
||||||
ConfigureSystem::ConfigureSystem(
|
ConfigureSystem::ConfigureSystem(
|
||||||
Core::System& system_, std::shared_ptr<std::forward_list<ConfigurationShared::Tab*>> group,
|
Core::System& system_, std::shared_ptr<std::forward_list<ConfigurationShared::Tab*>> group,
|
||||||
QWidget* parent)
|
ConfigurationShared::TranslationMap& translations_, QWidget* parent)
|
||||||
: Tab(group, parent), ui{std::make_unique<Ui::ConfigureSystem>()}, system{system_} {
|
: Tab(group, parent), ui{std::make_unique<Ui::ConfigureSystem>()}, system{system_},
|
||||||
|
translations{translations_} {
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
|
|
||||||
connect(ui->rng_seed_checkbox, &QCheckBox::stateChanged, this, [this](int state) {
|
Setup();
|
||||||
ui->rng_seed_edit->setEnabled(state == Qt::Checked);
|
|
||||||
|
connect(rng_seed_checkbox, &QCheckBox::stateChanged, this, [this](int state) {
|
||||||
|
rng_seed_edit->setEnabled(state == Qt::Checked);
|
||||||
if (state != Qt::Checked) {
|
if (state != Qt::Checked) {
|
||||||
ui->rng_seed_edit->setText(QStringLiteral("00000000"));
|
rng_seed_edit->setText(QStringLiteral("00000000"));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
connect(ui->custom_rtc_checkbox, &QCheckBox::stateChanged, this, [this](int state) {
|
connect(custom_rtc_checkbox, &QCheckBox::stateChanged, this, [this](int state) {
|
||||||
ui->custom_rtc_edit->setEnabled(state == Qt::Checked);
|
custom_rtc_edit->setEnabled(state == Qt::Checked);
|
||||||
if (state != Qt::Checked) {
|
if (state != Qt::Checked) {
|
||||||
ui->custom_rtc_edit->setDateTime(QDateTime::currentDateTime());
|
custom_rtc_edit->setDateTime(QDateTime::currentDateTime());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
const auto locale_check = [this](int index) {
|
const auto locale_check = [this](int index) {
|
||||||
const auto region_index = ConfigurationShared::GetComboboxIndex(
|
const auto region_index = combo_region->currentIndex();
|
||||||
Settings::values.region_index.GetValue(true), ui->combo_region);
|
const auto language_index = combo_language->currentIndex();
|
||||||
const auto language_index = ConfigurationShared::GetComboboxIndex(
|
|
||||||
Settings::values.language_index.GetValue(true), ui->combo_language);
|
|
||||||
const bool valid_locale = IsValidLocale(region_index, language_index);
|
const bool valid_locale = IsValidLocale(region_index, language_index);
|
||||||
ui->label_warn_invalid_locale->setVisible(!valid_locale);
|
ui->label_warn_invalid_locale->setVisible(!valid_locale);
|
||||||
if (!valid_locale) {
|
if (!valid_locale) {
|
||||||
ui->label_warn_invalid_locale->setText(
|
ui->label_warn_invalid_locale->setText(
|
||||||
tr("Warning: \"%1\" is not a valid language for region \"%2\"")
|
tr("Warning: \"%1\" is not a valid language for region \"%2\"")
|
||||||
.arg(ui->combo_language->currentText())
|
.arg(combo_language->currentText())
|
||||||
.arg(ui->combo_region->currentText()));
|
.arg(combo_region->currentText()));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
connect(ui->combo_language, qOverload<int>(&QComboBox::currentIndexChanged), this,
|
connect(combo_language, qOverload<int>(&QComboBox::currentIndexChanged), this, locale_check);
|
||||||
locale_check);
|
connect(combo_region, qOverload<int>(&QComboBox::currentIndexChanged), this, locale_check);
|
||||||
connect(ui->combo_region, qOverload<int>(&QComboBox::currentIndexChanged), this, locale_check);
|
|
||||||
|
|
||||||
SetupPerGameUI();
|
|
||||||
|
|
||||||
SetConfiguration();
|
SetConfiguration();
|
||||||
}
|
}
|
||||||
|
@ -95,137 +98,94 @@ void ConfigureSystem::RetranslateUI() {
|
||||||
ui->retranslateUi(this);
|
ui->retranslateUi(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigureSystem::SetConfiguration() {
|
void ConfigureSystem::Setup() {
|
||||||
enabled = !system.IsPoweredOn();
|
const bool runtime_lock = !system.IsPoweredOn();
|
||||||
const auto rng_seed = QStringLiteral("%1")
|
auto& core_layout = *ui->core_widget->layout();
|
||||||
.arg(Settings::values.rng_seed.GetValue(), 8, 16, QLatin1Char{'0'})
|
auto& system_layout = *ui->system_widget->layout();
|
||||||
.toUpper();
|
|
||||||
const auto rtc_time = Settings::values.custom_rtc_enabled
|
|
||||||
? Settings::values.custom_rtc.GetValue()
|
|
||||||
: QDateTime::currentSecsSinceEpoch();
|
|
||||||
|
|
||||||
ui->rng_seed_checkbox->setChecked(Settings::values.rng_seed_enabled.GetValue());
|
std::map<std::string, QWidget*> core_hold{};
|
||||||
ui->rng_seed_edit->setEnabled(Settings::values.rng_seed_enabled.GetValue() &&
|
std::map<bool, std::map<std::string, QWidget*>> system_hold{};
|
||||||
Settings::values.rng_seed.UsingGlobal());
|
|
||||||
ui->rng_seed_edit->setText(rng_seed);
|
|
||||||
|
|
||||||
ui->custom_rtc_checkbox->setChecked(Settings::values.custom_rtc_enabled.GetValue());
|
std::forward_list<Settings::BasicSetting*> settings;
|
||||||
ui->custom_rtc_edit->setEnabled(Settings::values.custom_rtc_enabled.GetValue());
|
auto push = [&settings](std::forward_list<Settings::BasicSetting*>& list) {
|
||||||
ui->custom_rtc_edit->setDateTime(QDateTime::fromSecsSinceEpoch(rtc_time));
|
for (auto setting : list) {
|
||||||
ui->device_name_edit->setText(
|
settings.push_front(setting);
|
||||||
QString::fromUtf8(Settings::values.device_name.GetValue().c_str()));
|
}
|
||||||
ui->use_unsafe_extended_memory_layout->setEnabled(enabled);
|
};
|
||||||
ui->use_unsafe_extended_memory_layout->setChecked(
|
|
||||||
Settings::values.use_unsafe_extended_memory_layout.GetValue());
|
|
||||||
|
|
||||||
if (Settings::IsConfiguringGlobal()) {
|
push(Settings::values.linkage.by_category[Settings::Category::Core]);
|
||||||
ui->combo_language->setCurrentIndex(Settings::values.language_index.GetValue());
|
push(Settings::values.linkage.by_category[Settings::Category::System]);
|
||||||
ui->combo_region->setCurrentIndex(Settings::values.region_index.GetValue());
|
|
||||||
ui->combo_time_zone->setCurrentIndex(Settings::values.time_zone_index.GetValue());
|
for (auto setting : settings) {
|
||||||
|
ConfigurationShared::Widget* widget = [=]() {
|
||||||
|
if (setting->Id() == Settings::values.custom_rtc_enabled.Id()) {
|
||||||
|
return new ConfigurationShared::Widget(
|
||||||
|
setting, translations, this, runtime_lock, apply_funcs,
|
||||||
|
ConfigurationShared::RequestType::DateTimeEdit, true, 1.0f,
|
||||||
|
&Settings::values.custom_rtc);
|
||||||
|
} else if (setting->Id() == Settings::values.rng_seed_enabled.Id()) {
|
||||||
|
return new ConfigurationShared::Widget(setting, translations, this, runtime_lock,
|
||||||
|
apply_funcs,
|
||||||
|
ConfigurationShared::RequestType::HexEdit,
|
||||||
|
true, 1.0f, &Settings::values.rng_seed);
|
||||||
} else {
|
} else {
|
||||||
ConfigurationShared::SetPerGameSetting(ui->combo_language,
|
return new ConfigurationShared::Widget(setting, translations, this, runtime_lock,
|
||||||
&Settings::values.language_index);
|
|
||||||
ConfigurationShared::SetPerGameSetting(ui->combo_region, &Settings::values.region_index);
|
|
||||||
ConfigurationShared::SetPerGameSetting(ui->combo_time_zone,
|
|
||||||
&Settings::values.time_zone_index);
|
|
||||||
|
|
||||||
ConfigurationShared::SetHighlight(ui->label_language,
|
apply_funcs);
|
||||||
!Settings::values.language_index.UsingGlobal());
|
}
|
||||||
ConfigurationShared::SetHighlight(ui->label_region,
|
}();
|
||||||
!Settings::values.region_index.UsingGlobal());
|
|
||||||
ConfigurationShared::SetHighlight(ui->label_timezone,
|
if (!widget->Valid()) {
|
||||||
!Settings::values.time_zone_index.UsingGlobal());
|
delete widget;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (setting->Id() == Settings::values.rng_seed_enabled.Id()) {
|
||||||
|
rng_seed_checkbox = widget->checkbox;
|
||||||
|
rng_seed_edit = widget->line_edit;
|
||||||
|
|
||||||
|
if (!Settings::values.rng_seed_enabled.GetValue()) {
|
||||||
|
rng_seed_edit->setEnabled(false);
|
||||||
|
}
|
||||||
|
} else if (setting->Id() == Settings::values.custom_rtc_enabled.Id()) {
|
||||||
|
custom_rtc_checkbox = widget->checkbox;
|
||||||
|
custom_rtc_edit = widget->date_time_edit;
|
||||||
|
|
||||||
|
custom_rtc_edit->setEnabled(Settings::values.custom_rtc_enabled.GetValue());
|
||||||
|
} else if (setting->Id() == Settings::values.region_index.Id()) {
|
||||||
|
|
||||||
|
combo_region = widget->combobox;
|
||||||
|
} else if (setting->Id() == Settings::values.language_index.Id()) {
|
||||||
|
combo_language = widget->combobox;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (setting->Category()) {
|
||||||
|
case Settings::Category::Core:
|
||||||
|
core_hold[setting->GetLabel()] = widget;
|
||||||
|
break;
|
||||||
|
case Settings::Category::System:
|
||||||
|
system_hold[setting->IsEnum()].insert(std::pair{setting->GetLabel(), widget});
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
delete widget;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (const auto& [label, widget] : core_hold) {
|
||||||
|
core_layout.addWidget(widget);
|
||||||
|
}
|
||||||
|
for (const auto& [label, widget] : system_hold[true]) {
|
||||||
|
system_layout.addWidget(widget);
|
||||||
|
}
|
||||||
|
for (const auto& [label, widget] : system_hold[false]) {
|
||||||
|
system_layout.addWidget(widget);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigureSystem::ReadSystemSettings() {}
|
void ConfigureSystem::SetConfiguration() {}
|
||||||
|
|
||||||
void ConfigureSystem::ApplyConfiguration() {
|
void ConfigureSystem::ApplyConfiguration() {
|
||||||
// Allow setting custom RTC even if system is powered on,
|
const bool powered_on = system.IsPoweredOn();
|
||||||
// to allow in-game time to be fast forwarded
|
for (const auto& func : apply_funcs) {
|
||||||
if (Settings::IsConfiguringGlobal()) {
|
func(powered_on);
|
||||||
if (ui->custom_rtc_checkbox->isChecked()) {
|
|
||||||
Settings::values.custom_rtc_enabled = true;
|
|
||||||
Settings::values.custom_rtc = ui->custom_rtc_edit->dateTime().toSecsSinceEpoch();
|
|
||||||
if (system.IsPoweredOn()) {
|
|
||||||
const s64 posix_time{Settings::values.custom_rtc.GetValue() +
|
|
||||||
Service::Time::TimeManager::GetExternalTimeZoneOffset()};
|
|
||||||
system.GetTimeManager().UpdateLocalSystemClockTime(posix_time);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
Settings::values.custom_rtc_enabled = false;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Settings::values.device_name = ui->device_name_edit->text().toStdString();
|
|
||||||
|
|
||||||
if (!enabled) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
ConfigurationShared::ApplyPerGameSetting(&Settings::values.language_index, ui->combo_language);
|
|
||||||
ConfigurationShared::ApplyPerGameSetting(&Settings::values.region_index, ui->combo_region);
|
|
||||||
ConfigurationShared::ApplyPerGameSetting(&Settings::values.time_zone_index,
|
|
||||||
ui->combo_time_zone);
|
|
||||||
ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_unsafe_extended_memory_layout,
|
|
||||||
ui->use_unsafe_extended_memory_layout,
|
|
||||||
use_unsafe_extended_memory_layout);
|
|
||||||
|
|
||||||
if (Settings::IsConfiguringGlobal()) {
|
|
||||||
// Guard if during game and set to game-specific value
|
|
||||||
if (Settings::values.rng_seed.UsingGlobal()) {
|
|
||||||
Settings::values.rng_seed_enabled = ui->rng_seed_checkbox->isChecked();
|
|
||||||
if (ui->rng_seed_checkbox->isChecked()) {
|
|
||||||
Settings::values.rng_seed.SetValue(ui->rng_seed_edit->text().toUInt(nullptr, 16));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
switch (use_rng_seed) {
|
|
||||||
case ConfigurationShared::CheckState::On:
|
|
||||||
case ConfigurationShared::CheckState::Off:
|
|
||||||
Settings::values.rng_seed_enabled.SetGlobal(false);
|
|
||||||
Settings::values.rng_seed.SetGlobal(false);
|
|
||||||
if (ui->rng_seed_checkbox->isChecked()) {
|
|
||||||
Settings::values.rng_seed.SetValue(ui->rng_seed_edit->text().toUInt(nullptr, 16));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case ConfigurationShared::CheckState::Global:
|
|
||||||
Settings::values.rng_seed_enabled.SetGlobal(true);
|
|
||||||
Settings::values.rng_seed.SetGlobal(true);
|
|
||||||
break;
|
|
||||||
case ConfigurationShared::CheckState::Count:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConfigureSystem::SetupPerGameUI() {
|
|
||||||
if (Settings::IsConfiguringGlobal()) {
|
|
||||||
ui->combo_language->setEnabled(Settings::values.language_index.UsingGlobal());
|
|
||||||
ui->combo_region->setEnabled(Settings::values.region_index.UsingGlobal());
|
|
||||||
ui->combo_time_zone->setEnabled(Settings::values.time_zone_index.UsingGlobal());
|
|
||||||
ui->rng_seed_checkbox->setEnabled(Settings::values.rng_seed.UsingGlobal());
|
|
||||||
ui->rng_seed_edit->setEnabled(Settings::values.rng_seed.UsingGlobal());
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
ConfigurationShared::SetColoredComboBox(ui->combo_language, ui->label_language,
|
|
||||||
Settings::values.language_index.GetValue(true));
|
|
||||||
ConfigurationShared::SetColoredComboBox(ui->combo_region, ui->label_region,
|
|
||||||
Settings::values.region_index.GetValue(true));
|
|
||||||
ConfigurationShared::SetColoredComboBox(ui->combo_time_zone, ui->label_timezone,
|
|
||||||
Settings::values.time_zone_index.GetValue(true));
|
|
||||||
|
|
||||||
ConfigurationShared::SetColoredTristate(
|
|
||||||
ui->rng_seed_checkbox, Settings::values.rng_seed.UsingGlobal(),
|
|
||||||
Settings::values.rng_seed_enabled.GetValue(),
|
|
||||||
Settings::values.rng_seed_enabled.GetValue(true), use_rng_seed);
|
|
||||||
|
|
||||||
ConfigurationShared::SetColoredTristate(ui->use_unsafe_extended_memory_layout,
|
|
||||||
Settings::values.use_unsafe_extended_memory_layout,
|
|
||||||
use_unsafe_extended_memory_layout);
|
|
||||||
|
|
||||||
ui->custom_rtc_checkbox->setVisible(false);
|
|
||||||
ui->custom_rtc_edit->setVisible(false);
|
|
||||||
}
|
|
||||||
|
|
|
@ -3,11 +3,15 @@
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include <forward_list>
|
||||||
|
#include <functional>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
#include "yuzu/configuration/configuration_shared.h"
|
#include "yuzu/configuration/configuration_shared.h"
|
||||||
|
|
||||||
|
class QDateTimeEdit;
|
||||||
|
|
||||||
namespace Core {
|
namespace Core {
|
||||||
class System;
|
class System;
|
||||||
}
|
}
|
||||||
|
@ -20,6 +24,7 @@ class ConfigureSystem : public ConfigurationShared::Tab {
|
||||||
public:
|
public:
|
||||||
explicit ConfigureSystem(Core::System& system_,
|
explicit ConfigureSystem(Core::System& system_,
|
||||||
std::shared_ptr<std::forward_list<ConfigurationShared::Tab*>> group,
|
std::shared_ptr<std::forward_list<ConfigurationShared::Tab*>> group,
|
||||||
|
ConfigurationShared::TranslationMap& translations,
|
||||||
QWidget* parent = nullptr);
|
QWidget* parent = nullptr);
|
||||||
~ConfigureSystem() override;
|
~ConfigureSystem() override;
|
||||||
|
|
||||||
|
@ -30,9 +35,9 @@ private:
|
||||||
void changeEvent(QEvent* event) override;
|
void changeEvent(QEvent* event) override;
|
||||||
void RetranslateUI();
|
void RetranslateUI();
|
||||||
|
|
||||||
void ReadSystemSettings();
|
void Setup();
|
||||||
|
|
||||||
void SetupPerGameUI();
|
std::forward_list<std::function<void(bool)>> apply_funcs{};
|
||||||
|
|
||||||
std::unique_ptr<Ui::ConfigureSystem> ui;
|
std::unique_ptr<Ui::ConfigureSystem> ui;
|
||||||
bool enabled = false;
|
bool enabled = false;
|
||||||
|
@ -41,4 +46,12 @@ private:
|
||||||
ConfigurationShared::CheckState use_unsafe_extended_memory_layout;
|
ConfigurationShared::CheckState use_unsafe_extended_memory_layout;
|
||||||
|
|
||||||
Core::System& system;
|
Core::System& system;
|
||||||
|
ConfigurationShared::TranslationMap& translations;
|
||||||
|
|
||||||
|
QCheckBox* rng_seed_checkbox;
|
||||||
|
QLineEdit* rng_seed_edit;
|
||||||
|
QCheckBox* custom_rtc_checkbox;
|
||||||
|
QDateTimeEdit* custom_rtc_edit;
|
||||||
|
QComboBox* combo_region;
|
||||||
|
QComboBox* combo_language;
|
||||||
};
|
};
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>366</width>
|
<width>605</width>
|
||||||
<height>483</height>
|
<height>483</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
|
@ -22,470 +22,53 @@
|
||||||
<item>
|
<item>
|
||||||
<widget class="QGroupBox" name="group_system_settings">
|
<widget class="QGroupBox" name="group_system_settings">
|
||||||
<property name="title">
|
<property name="title">
|
||||||
<string>System Settings</string>
|
<string>System</string>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_2">
|
<layout class="QVBoxLayout" name="verticalLayout_2">
|
||||||
<item>
|
<item>
|
||||||
<layout class="QGridLayout" name="gridLayout_2">
|
<widget class="QWidget" name="system_widget" native="true">
|
||||||
<item row="1" column="0">
|
<layout class="QVBoxLayout" name="verticalLayout_3">
|
||||||
<widget class="QLabel" name="label_region">
|
<property name="leftMargin">
|
||||||
<property name="text">
|
<number>0</number>
|
||||||
<string>Region:</string>
|
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
<property name="topMargin">
|
||||||
</item>
|
<number>0</number>
|
||||||
<item row="2" column="1">
|
|
||||||
<widget class="QComboBox" name="combo_time_zone">
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Auto</string>
|
|
||||||
</property>
|
</property>
|
||||||
</item>
|
<property name="rightMargin">
|
||||||
<item>
|
<number>0</number>
|
||||||
<property name="text">
|
|
||||||
<string>Default</string>
|
|
||||||
</property>
|
</property>
|
||||||
</item>
|
<property name="bottomMargin">
|
||||||
<item>
|
<number>0</number>
|
||||||
<property name="text">
|
|
||||||
<string>CET</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>CST6CDT</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Cuba</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>EET</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Egypt</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Eire</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>EST</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>EST5EDT</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>GB</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>GB-Eire</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>GMT</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>GMT+0</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>GMT-0</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>GMT0</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Greenwich</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Hongkong</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>HST</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Iceland</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Iran</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Israel</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Jamaica</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Japan</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Kwajalein</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Libya</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>MET</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>MST</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>MST7MDT</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Navajo</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>NZ</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>NZ-CHAT</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Poland</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Portugal</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>PRC</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>PST8PDT</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>ROC</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>ROK</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Singapore</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Turkey</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>UCT</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Universal</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>UTC</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>W-SU</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>WET</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Zulu</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="1" column="1">
|
|
||||||
<widget class="QComboBox" name="combo_region">
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Japan</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>USA</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Europe</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Australia</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>China</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Korea</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Taiwan</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="2" column="0">
|
|
||||||
<widget class="QLabel" name="label_timezone">
|
|
||||||
<property name="text">
|
|
||||||
<string>Time Zone:</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="0" column="1">
|
|
||||||
<widget class="QComboBox" name="combo_language">
|
|
||||||
<property name="toolTip">
|
|
||||||
<string>Note: this can be overridden when region setting is auto-select</string>
|
|
||||||
</property>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Japanese (日本語)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>American English</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>French (français)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>German (Deutsch)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Italian (italiano)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Spanish (español)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Chinese</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Korean (한국어)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Dutch (Nederlands)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Portuguese (português)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Russian (Русский)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Taiwanese</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>British English</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Canadian French</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Latin American Spanish</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Simplified Chinese</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Traditional Chinese (正體中文)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
<item>
|
|
||||||
<property name="text">
|
|
||||||
<string>Brazilian Portuguese (português do Brasil)</string>
|
|
||||||
</property>
|
|
||||||
</item>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="4" column="0">
|
|
||||||
<widget class="QCheckBox" name="custom_rtc_checkbox">
|
|
||||||
<property name="text">
|
|
||||||
<string>Custom RTC</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="0" column="0">
|
|
||||||
<widget class="QLabel" name="label_language">
|
|
||||||
<property name="text">
|
|
||||||
<string>Language</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="5" column="0">
|
|
||||||
<widget class="QCheckBox" name="rng_seed_checkbox">
|
|
||||||
<property name="text">
|
|
||||||
<string>RNG Seed</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="6" column="0">
|
|
||||||
<widget class="QLabel" name="device_name_label">
|
|
||||||
<property name="text">
|
|
||||||
<string>Device Name</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="4" column="1">
|
|
||||||
<widget class="QDateTimeEdit" name="custom_rtc_edit">
|
|
||||||
<property name="minimumDate">
|
|
||||||
<date>
|
|
||||||
<year>1970</year>
|
|
||||||
<month>1</month>
|
|
||||||
<day>1</day>
|
|
||||||
</date>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="6" column="1">
|
|
||||||
<widget class="QLineEdit" name="device_name_edit">
|
|
||||||
<property name="maxLength">
|
|
||||||
<number>128</number>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="5" column="1">
|
|
||||||
<widget class="QLineEdit" name="rng_seed_edit">
|
|
||||||
<property name="sizePolicy">
|
|
||||||
<sizepolicy hsizetype="Minimum" vsizetype="Fixed">
|
|
||||||
<horstretch>0</horstretch>
|
|
||||||
<verstretch>0</verstretch>
|
|
||||||
</sizepolicy>
|
|
||||||
</property>
|
|
||||||
<property name="font">
|
|
||||||
<font>
|
|
||||||
<family>Lucida Console</family>
|
|
||||||
</font>
|
|
||||||
</property>
|
|
||||||
<property name="inputMask">
|
|
||||||
<string notr="true">HHHHHHHH</string>
|
|
||||||
</property>
|
|
||||||
<property name="maxLength">
|
|
||||||
<number>8</number>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="7" column="0">
|
|
||||||
<widget class="QCheckBox" name="use_unsafe_extended_memory_layout">
|
|
||||||
<property name="text">
|
|
||||||
<string>Unsafe extended memory layout (8GB DRAM)</string>
|
|
||||||
</property>
|
</property>
|
||||||
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QGroupBox" name="groupBox">
|
||||||
|
<property name="title">
|
||||||
|
<string>Core</string>
|
||||||
|
</property>
|
||||||
|
<layout class="QVBoxLayout" name="verticalLayout_6">
|
||||||
|
<item>
|
||||||
|
<widget class="QWidget" name="core_widget" native="true">
|
||||||
|
<layout class="QVBoxLayout" name="verticalLayout_5">
|
||||||
|
<property name="leftMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="topMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="rightMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="bottomMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
|
@ -506,7 +89,7 @@
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="label_warn_invalid_locale">
|
<widget class="QLabel" name="label_warn_invalid_locale">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string></string>
|
<string/>
|
||||||
</property>
|
</property>
|
||||||
<property name="wordWrap">
|
<property name="wordWrap">
|
||||||
<bool>true</bool>
|
<bool>true</bool>
|
||||||
|
|
|
@ -109,15 +109,16 @@ std::unique_ptr<TranslationMap> InitializeTranslations(QWidget* parent) {
|
||||||
|
|
||||||
// System
|
// System
|
||||||
INSERT(Settings, rng_seed_enabled, "RNG Seed", "");
|
INSERT(Settings, rng_seed_enabled, "RNG Seed", "");
|
||||||
INSERT(Settings, rng_seed, "RNG Seed", "");
|
INSERT(Settings, rng_seed, "", "");
|
||||||
INSERT(Settings, device_name, "Device Name", "");
|
INSERT(Settings, device_name, "Device Name", "");
|
||||||
INSERT(Settings, custom_rtc_enabled, "Custom RTC", "");
|
INSERT(Settings, custom_rtc_enabled, "Custom RTC", "");
|
||||||
INSERT(Settings, custom_rtc, "Custom RTC", "");
|
INSERT(Settings, custom_rtc, "", "");
|
||||||
INSERT(Settings, language_index, "Language:", "");
|
INSERT(Settings, language_index, "Language:", "");
|
||||||
INSERT(Settings, region_index, "Region:", "");
|
INSERT(Settings, region_index, "Region:", "");
|
||||||
INSERT(Settings, time_zone_index, "Time Zone:", "");
|
INSERT(Settings, time_zone_index, "Time Zone:", "");
|
||||||
INSERT(Settings, sound_index, "Sound Output Mode:", "");
|
INSERT(Settings, sound_index, "Sound Output Mode:", "");
|
||||||
INSERT(Settings, use_docked_mode, "", "");
|
INSERT(Settings, use_docked_mode, "", "");
|
||||||
|
INSERT(Settings, current_user, "", "");
|
||||||
|
|
||||||
// Controls
|
// Controls
|
||||||
|
|
||||||
|
@ -231,6 +232,44 @@ std::forward_list<QString> ComboboxEnumeration(std::type_index type, QWidget* pa
|
||||||
return {
|
return {
|
||||||
tr("Automatic"), tr("Default"), tr("2x"), tr("4x"), tr("8x"), tr("16x"),
|
tr("Automatic"), tr("Default"), tr("2x"), tr("4x"), tr("8x"), tr("16x"),
|
||||||
};
|
};
|
||||||
|
} else if (type == typeid(Settings::Language)) {
|
||||||
|
return {
|
||||||
|
tr("Japanese (日本語)"),
|
||||||
|
tr("American English"),
|
||||||
|
tr("French (français)"),
|
||||||
|
tr("German (Deutsch)"),
|
||||||
|
tr("Italian (italiano)"),
|
||||||
|
tr("Spanish (español)"),
|
||||||
|
tr("Chinese"),
|
||||||
|
tr("Korean (한국어)"),
|
||||||
|
tr("Dutch (Nederlands)"),
|
||||||
|
tr("Portuguese (português)"),
|
||||||
|
tr("Russian (Русский)"),
|
||||||
|
tr("Taiwanese"),
|
||||||
|
tr("British English"),
|
||||||
|
tr("Canadian French"),
|
||||||
|
tr("Latin American Spanish"),
|
||||||
|
tr("Simplified Chinese"),
|
||||||
|
tr("Traditional Chinese (正體中文)"),
|
||||||
|
tr("Brazilian Portuguese (português do Brasil)"),
|
||||||
|
};
|
||||||
|
} else if (type == typeid(Settings::Region)) {
|
||||||
|
return {
|
||||||
|
tr("Japan"), tr("USA"), tr("Europe"), tr("Australia"),
|
||||||
|
tr("China"), tr("Korea"), tr("Taiwan"),
|
||||||
|
};
|
||||||
|
} else if (type == typeid(Settings::TimeZone)) {
|
||||||
|
return {
|
||||||
|
tr("Auto"), tr("Default"), tr("CET"), tr("CST6CDT"), tr("Cuba"),
|
||||||
|
tr("EET"), tr("Egypt"), tr("Eire"), tr("EST"), tr("EST5EDT"),
|
||||||
|
tr("GB"), tr("GB-Eire"), tr("GMT"), tr("GMT+0"), tr("GMT-0"),
|
||||||
|
tr("GMT0"), tr("Greenwich"), tr("Hongkong"), tr("HST"), tr("Iceland"),
|
||||||
|
tr("Iran"), tr("Israel"), tr("Jamaica"), tr("Kwajalein"), tr("Libya"),
|
||||||
|
tr("MET"), tr("MST"), tr("MST7MDT"), tr("Navajo"), tr("NZ"),
|
||||||
|
tr("NZ-CHAT"), tr("Poland"), tr("Portugal"), tr("PRC"), tr("PST8PDT"),
|
||||||
|
tr("ROC"), tr("ROK"), tr("Singapore"), tr("Turkey"), tr("UCT"),
|
||||||
|
tr("W-SU"), tr("WET"), tr("Zulu"),
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
return {};
|
return {};
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
#include <functional>
|
#include <functional>
|
||||||
|
#include <limits>
|
||||||
#include <QCheckBox>
|
#include <QCheckBox>
|
||||||
|
#include <QDateTimeEdit>
|
||||||
#include <QHBoxLayout>
|
#include <QHBoxLayout>
|
||||||
#include <QIcon>
|
#include <QIcon>
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
|
@ -9,6 +11,9 @@
|
||||||
#include <QSpinBox>
|
#include <QSpinBox>
|
||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
#include <qabstractbutton.h>
|
#include <qabstractbutton.h>
|
||||||
|
#include <qabstractspinbox.h>
|
||||||
|
#include <qnamespace.h>
|
||||||
|
#include <qvalidator.h>
|
||||||
#include "common/common_types.h"
|
#include "common/common_types.h"
|
||||||
#include "common/settings.h"
|
#include "common/settings.h"
|
||||||
#include "yuzu/configuration/configuration_shared.h"
|
#include "yuzu/configuration/configuration_shared.h"
|
||||||
|
@ -25,7 +30,7 @@ QPushButton* Widget::CreateRestoreGlobalButton(Settings::BasicSetting& setting,
|
||||||
QStyle* style = parent->style();
|
QStyle* style = parent->style();
|
||||||
QIcon* icon = new QIcon(style->standardIcon(QStyle::SP_DialogResetButton));
|
QIcon* icon = new QIcon(style->standardIcon(QStyle::SP_DialogResetButton));
|
||||||
QPushButton* restore_button = new QPushButton(*icon, QStringLiteral(""), parent);
|
QPushButton* restore_button = new QPushButton(*icon, QStringLiteral(""), parent);
|
||||||
restore_button->setSizePolicy(QSizePolicy::Maximum, QSizePolicy::Expanding);
|
restore_button->setSizePolicy(QSizePolicy::Maximum, QSizePolicy::Preferred);
|
||||||
|
|
||||||
QSizePolicy sp_retain = restore_button->sizePolicy();
|
QSizePolicy sp_retain = restore_button->sizePolicy();
|
||||||
sp_retain.setRetainSizeWhenHidden(true);
|
sp_retain.setRetainSizeWhenHidden(true);
|
||||||
|
@ -241,6 +246,67 @@ void Widget::CreateSlider(const QString& name, bool reversed, float multiplier,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Widget::CreateCheckBoxWithHexEdit(const QString& label, Settings::BasicSetting* other_setting,
|
||||||
|
std::function<void()>& load_func) {
|
||||||
|
if (other_setting == nullptr) {
|
||||||
|
LOG_WARNING(Frontend, "Extra setting is null or not an integer");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
created = true;
|
||||||
|
|
||||||
|
std::function<void()> checkbox_load_func;
|
||||||
|
CreateCheckBox(label, checkbox_load_func);
|
||||||
|
|
||||||
|
auto to_hex = [=](const std::string& input) {
|
||||||
|
return QString::fromStdString(fmt::format("{:08x}", std::stoi(input)));
|
||||||
|
};
|
||||||
|
|
||||||
|
QHBoxLayout* layout = reinterpret_cast<QHBoxLayout*>(this->layout());
|
||||||
|
const QString default_val = to_hex(other_setting->ToString());
|
||||||
|
|
||||||
|
line_edit = new QLineEdit(this);
|
||||||
|
line_edit->setText(default_val);
|
||||||
|
|
||||||
|
checkbox->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Preferred);
|
||||||
|
|
||||||
|
layout->insertWidget(1, line_edit);
|
||||||
|
|
||||||
|
line_edit->setMaxLength(8);
|
||||||
|
QRegExpValidator* regex =
|
||||||
|
new QRegExpValidator{QRegExp{QStringLiteral("^[0-9a-fA-F]{0,8}$")}, line_edit};
|
||||||
|
line_edit->setValidator(regex);
|
||||||
|
|
||||||
|
auto hex_to_dec = [=]() -> std::string {
|
||||||
|
return std::to_string(std::stoul(line_edit->text().toStdString(), nullptr, 16));
|
||||||
|
};
|
||||||
|
|
||||||
|
if (Settings::IsConfiguringGlobal()) {
|
||||||
|
load_func = [=]() {
|
||||||
|
checkbox_load_func();
|
||||||
|
other_setting->LoadString(hex_to_dec());
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
QObject::connect(restore_button, &QAbstractButton::clicked, [=](bool) {
|
||||||
|
line_edit->setText(to_hex(other_setting->ToStringGlobal()));
|
||||||
|
});
|
||||||
|
|
||||||
|
QObject::connect(line_edit, &QLineEdit::textEdited, [=](const QString&) {
|
||||||
|
restore_button->setEnabled(true);
|
||||||
|
restore_button->setVisible(true);
|
||||||
|
});
|
||||||
|
|
||||||
|
load_func = [=]() {
|
||||||
|
checkbox_load_func();
|
||||||
|
|
||||||
|
const bool using_global = !restore_button->isEnabled();
|
||||||
|
other_setting->SetGlobal(using_global);
|
||||||
|
if (!using_global) {
|
||||||
|
other_setting->LoadString(hex_to_dec());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void Widget::CreateCheckBoxWithLineEdit(const QString& label, Settings::BasicSetting* other_setting,
|
void Widget::CreateCheckBoxWithLineEdit(const QString& label, Settings::BasicSetting* other_setting,
|
||||||
std::function<void()>& load_func) {
|
std::function<void()>& load_func) {
|
||||||
if (other_setting == nullptr) {
|
if (other_setting == nullptr) {
|
||||||
|
@ -268,8 +334,9 @@ void Widget::CreateCheckBoxWithLineEdit(const QString& label, Settings::BasicSet
|
||||||
other_setting->LoadString(line_edit->text().toStdString());
|
other_setting->LoadString(line_edit->text().toStdString());
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
QObject::connect(restore_button, &QAbstractButton::clicked,
|
QObject::connect(restore_button, &QAbstractButton::clicked, [=](bool) {
|
||||||
[=](bool) { line_edit->setText(default_val); });
|
line_edit->setText(QString::fromStdString(other_setting->ToStringGlobal()));
|
||||||
|
});
|
||||||
|
|
||||||
QObject::connect(line_edit, &QLineEdit::textEdited, [=](const QString&) {
|
QObject::connect(line_edit, &QLineEdit::textEdited, [=](const QString&) {
|
||||||
restore_button->setEnabled(true);
|
restore_button->setEnabled(true);
|
||||||
|
@ -279,7 +346,7 @@ void Widget::CreateCheckBoxWithLineEdit(const QString& label, Settings::BasicSet
|
||||||
load_func = [=]() {
|
load_func = [=]() {
|
||||||
checkbox_load_func();
|
checkbox_load_func();
|
||||||
|
|
||||||
const bool using_global = !restore_button->isVisible();
|
const bool using_global = !restore_button->isEnabled();
|
||||||
other_setting->SetGlobal(using_global);
|
other_setting->SetGlobal(using_global);
|
||||||
if (!using_global) {
|
if (!using_global) {
|
||||||
other_setting->LoadString(line_edit->text().toStdString());
|
other_setting->LoadString(line_edit->text().toStdString());
|
||||||
|
@ -289,7 +356,8 @@ void Widget::CreateCheckBoxWithLineEdit(const QString& label, Settings::BasicSet
|
||||||
}
|
}
|
||||||
|
|
||||||
void Widget::CreateCheckBoxWithSpinBox(const QString& label, Settings::BasicSetting* other_setting,
|
void Widget::CreateCheckBoxWithSpinBox(const QString& label, Settings::BasicSetting* other_setting,
|
||||||
std::function<void()>& load_func, const QString& suffix) {
|
std::function<void()>& load_func,
|
||||||
|
const std::string& suffix) {
|
||||||
if (other_setting == nullptr && IsInt(other_setting->TypeId())) {
|
if (other_setting == nullptr && IsInt(other_setting->TypeId())) {
|
||||||
LOG_WARNING(Frontend, "Extra setting is null or not an integer");
|
LOG_WARNING(Frontend, "Extra setting is null or not an integer");
|
||||||
return;
|
return;
|
||||||
|
@ -308,7 +376,7 @@ void Widget::CreateCheckBoxWithSpinBox(const QString& label, Settings::BasicSett
|
||||||
const int default_val = std::stoi(other_setting->ToString());
|
const int default_val = std::stoi(other_setting->ToString());
|
||||||
spinbox->setRange(min_val, max_val);
|
spinbox->setRange(min_val, max_val);
|
||||||
spinbox->setValue(default_val);
|
spinbox->setValue(default_val);
|
||||||
spinbox->setSuffix(suffix);
|
spinbox->setSuffix(QString::fromStdString(suffix));
|
||||||
spinbox->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Preferred);
|
spinbox->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Preferred);
|
||||||
|
|
||||||
layout->insertWidget(1, spinbox);
|
layout->insertWidget(1, spinbox);
|
||||||
|
@ -320,7 +388,7 @@ void Widget::CreateCheckBoxWithSpinBox(const QString& label, Settings::BasicSett
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
QObject::connect(restore_button, &QAbstractButton::clicked, [this, other_setting](bool) {
|
QObject::connect(restore_button, &QAbstractButton::clicked, [this, other_setting](bool) {
|
||||||
spinbox->setValue(std::stoi(other_setting->ToString()));
|
spinbox->setValue(std::stoi(other_setting->ToStringGlobal()));
|
||||||
});
|
});
|
||||||
|
|
||||||
QObject::connect(spinbox, QOverload<int>::of(&QSpinBox::valueChanged), [this](int) {
|
QObject::connect(spinbox, QOverload<int>::of(&QSpinBox::valueChanged), [this](int) {
|
||||||
|
@ -331,7 +399,7 @@ void Widget::CreateCheckBoxWithSpinBox(const QString& label, Settings::BasicSett
|
||||||
load_func = [=]() {
|
load_func = [=]() {
|
||||||
checkbox_load_func();
|
checkbox_load_func();
|
||||||
|
|
||||||
const bool using_global = !restore_button->isVisible();
|
const bool using_global = !restore_button->isEnabled();
|
||||||
other_setting->SetGlobal(using_global);
|
other_setting->SetGlobal(using_global);
|
||||||
if (!using_global) {
|
if (!using_global) {
|
||||||
other_setting->LoadString(std::to_string(spinbox->value()));
|
other_setting->LoadString(std::to_string(spinbox->value()));
|
||||||
|
@ -340,6 +408,81 @@ void Widget::CreateCheckBoxWithSpinBox(const QString& label, Settings::BasicSett
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Currently tailored to custom_rtc
|
||||||
|
void Widget::CreateCheckBoxWithDateTimeEdit(const QString& label,
|
||||||
|
Settings::BasicSetting* other_setting,
|
||||||
|
std::function<void()>& load_func) {
|
||||||
|
if (other_setting == nullptr) {
|
||||||
|
LOG_WARNING(Frontend, "Extra setting is null or not an integer");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
created = true;
|
||||||
|
|
||||||
|
std::function<void()> checkbox_load_func;
|
||||||
|
CreateCheckBox(label, checkbox_load_func);
|
||||||
|
|
||||||
|
QHBoxLayout* layout = reinterpret_cast<QHBoxLayout*>(this->layout());
|
||||||
|
const bool disabled = setting.ToString() != "true";
|
||||||
|
const long long current_time = QDateTime::currentSecsSinceEpoch();
|
||||||
|
const s64 the_time = disabled ? current_time : std::stoll(other_setting->ToString());
|
||||||
|
const auto default_val = QDateTime::fromSecsSinceEpoch(the_time);
|
||||||
|
|
||||||
|
date_time_edit = new QDateTimeEdit(this);
|
||||||
|
date_time_edit->setDateTime(default_val);
|
||||||
|
|
||||||
|
date_time_edit->setMinimumDateTime(QDateTime::fromSecsSinceEpoch(0));
|
||||||
|
|
||||||
|
date_time_edit->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Preferred);
|
||||||
|
checkbox->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Preferred);
|
||||||
|
|
||||||
|
layout->insertWidget(1, date_time_edit);
|
||||||
|
|
||||||
|
if (Settings::IsConfiguringGlobal()) {
|
||||||
|
load_func = [=]() {
|
||||||
|
checkbox_load_func();
|
||||||
|
if (checkbox->checkState() == Qt::Unchecked) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
other_setting->LoadString(
|
||||||
|
std::to_string(date_time_edit->dateTime().toSecsSinceEpoch()));
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
auto get_clear_val = [=]() {
|
||||||
|
return QDateTime::fromSecsSinceEpoch([=]() {
|
||||||
|
if (checkbox->checkState() == Qt::Checked) {
|
||||||
|
return std::stoll(other_setting->ToStringGlobal());
|
||||||
|
}
|
||||||
|
return current_time;
|
||||||
|
}());
|
||||||
|
};
|
||||||
|
|
||||||
|
QObject::connect(restore_button, &QAbstractButton::clicked,
|
||||||
|
[=](bool) { date_time_edit->setDateTime(get_clear_val()); });
|
||||||
|
|
||||||
|
QObject::connect(date_time_edit, &QDateTimeEdit::editingFinished, [=]() {
|
||||||
|
if (date_time_edit->dateTime() != get_clear_val()) {
|
||||||
|
restore_button->setEnabled(true);
|
||||||
|
restore_button->setVisible(true);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
load_func = [=]() {
|
||||||
|
checkbox_load_func();
|
||||||
|
if (checkbox->checkState() == Qt::Unchecked) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const bool using_global = !restore_button->isEnabled();
|
||||||
|
other_setting->SetGlobal(using_global);
|
||||||
|
if (!using_global) {
|
||||||
|
other_setting->LoadString(
|
||||||
|
std::to_string(date_time_edit->dateTime().toSecsSinceEpoch()));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool Widget::Valid() {
|
bool Widget::Valid() {
|
||||||
return created;
|
return created;
|
||||||
}
|
}
|
||||||
|
@ -350,7 +493,7 @@ Widget::Widget(Settings::BasicSetting* setting_, const TranslationMap& translati
|
||||||
QWidget* parent_, bool runtime_lock,
|
QWidget* parent_, bool runtime_lock,
|
||||||
std::forward_list<std::function<void(bool)>>& apply_funcs, RequestType request,
|
std::forward_list<std::function<void(bool)>>& apply_funcs, RequestType request,
|
||||||
bool managed, float multiplier, Settings::BasicSetting* other_setting,
|
bool managed, float multiplier, Settings::BasicSetting* other_setting,
|
||||||
const QString& format)
|
const std::string& string)
|
||||||
: QWidget(parent_), parent{parent_}, translations{translations_}, setting{*setting_} {
|
: QWidget(parent_), parent{parent_}, translations{translations_}, setting{*setting_} {
|
||||||
if (!Settings::IsConfiguringGlobal() && !setting.Switchable()) {
|
if (!Settings::IsConfiguringGlobal() && !setting.Switchable()) {
|
||||||
LOG_DEBUG(Frontend, "\"{}\" is not switchable, skipping...", setting.GetLabel());
|
LOG_DEBUG(Frontend, "\"{}\" is not switchable, skipping...", setting.GetLabel());
|
||||||
|
@ -379,19 +522,26 @@ Widget::Widget(Settings::BasicSetting* setting_, const TranslationMap& translati
|
||||||
|
|
||||||
if (type == typeid(bool)) {
|
if (type == typeid(bool)) {
|
||||||
switch (request) {
|
switch (request) {
|
||||||
case RequestType::SpinBox:
|
|
||||||
CreateCheckBoxWithSpinBox(label, other_setting, load_func, format);
|
|
||||||
break;
|
|
||||||
case RequestType::Default:
|
case RequestType::Default:
|
||||||
CreateCheckBox(label, load_func);
|
CreateCheckBox(label, load_func);
|
||||||
break;
|
break;
|
||||||
|
case RequestType::SpinBox:
|
||||||
|
CreateCheckBoxWithSpinBox(label, other_setting, load_func, string);
|
||||||
|
break;
|
||||||
|
case RequestType::HexEdit:
|
||||||
|
CreateCheckBoxWithHexEdit(label, other_setting, load_func);
|
||||||
|
break;
|
||||||
case RequestType::LineEdit:
|
case RequestType::LineEdit:
|
||||||
CreateCheckBoxWithLineEdit(label, other_setting, load_func);
|
CreateCheckBoxWithLineEdit(label, other_setting, load_func);
|
||||||
break;
|
break;
|
||||||
|
case RequestType::DateTimeEdit:
|
||||||
|
CreateCheckBoxWithDateTimeEdit(label, other_setting, load_func);
|
||||||
|
break;
|
||||||
case RequestType::ComboBox:
|
case RequestType::ComboBox:
|
||||||
case RequestType::Slider:
|
case RequestType::Slider:
|
||||||
case RequestType::ReverseSlider:
|
case RequestType::ReverseSlider:
|
||||||
case RequestType::MaxEnum:
|
case RequestType::MaxEnum:
|
||||||
|
LOG_DEBUG(Frontend, "Requested widget is unimplemented.");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else if (setting.IsEnum()) {
|
} else if (setting.IsEnum()) {
|
||||||
|
@ -409,10 +559,15 @@ Widget::Widget(Settings::BasicSetting* setting_, const TranslationMap& translati
|
||||||
case RequestType::ComboBox:
|
case RequestType::ComboBox:
|
||||||
CreateCombobox(label, managed, load_func);
|
CreateCombobox(label, managed, load_func);
|
||||||
break;
|
break;
|
||||||
|
case RequestType::DateTimeEdit:
|
||||||
case RequestType::SpinBox:
|
case RequestType::SpinBox:
|
||||||
|
case RequestType::HexEdit:
|
||||||
case RequestType::MaxEnum:
|
case RequestType::MaxEnum:
|
||||||
|
LOG_DEBUG(Frontend, "Requested widget is unimplemented.");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
} else if (type == typeid(std::string)) {
|
||||||
|
CreateLineEdit(label, managed, load_func);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!created) {
|
if (!created) {
|
||||||
|
|
|
@ -9,6 +9,7 @@ class QComboBox;
|
||||||
class QLineEdit;
|
class QLineEdit;
|
||||||
class QSlider;
|
class QSlider;
|
||||||
class QCheckBox;
|
class QCheckBox;
|
||||||
|
class QDateTimeEdit;
|
||||||
|
|
||||||
namespace Settings {
|
namespace Settings {
|
||||||
class BasicSetting;
|
class BasicSetting;
|
||||||
|
@ -23,6 +24,8 @@ enum class RequestType {
|
||||||
Slider,
|
Slider,
|
||||||
ReverseSlider,
|
ReverseSlider,
|
||||||
LineEdit,
|
LineEdit,
|
||||||
|
HexEdit,
|
||||||
|
DateTimeEdit,
|
||||||
MaxEnum,
|
MaxEnum,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -33,8 +36,7 @@ public:
|
||||||
Widget(Settings::BasicSetting* setting, const TranslationMap& translations, QWidget* parent,
|
Widget(Settings::BasicSetting* setting, const TranslationMap& translations, QWidget* parent,
|
||||||
bool runtime_lock, std::forward_list<std::function<void(bool)>>& apply_funcs,
|
bool runtime_lock, std::forward_list<std::function<void(bool)>>& apply_funcs,
|
||||||
RequestType request = RequestType::Default, bool managed = true, float multiplier = 1.0f,
|
RequestType request = RequestType::Default, bool managed = true, float multiplier = 1.0f,
|
||||||
Settings::BasicSetting* other_setting = nullptr,
|
Settings::BasicSetting* other_setting = nullptr, const std::string& format = "");
|
||||||
const QString& format = QStringLiteral(""));
|
|
||||||
virtual ~Widget();
|
virtual ~Widget();
|
||||||
|
|
||||||
bool Valid();
|
bool Valid();
|
||||||
|
@ -48,13 +50,18 @@ public:
|
||||||
QCheckBox* checkbox{};
|
QCheckBox* checkbox{};
|
||||||
QSlider* slider{};
|
QSlider* slider{};
|
||||||
QComboBox* combobox{};
|
QComboBox* combobox{};
|
||||||
|
QDateTimeEdit* date_time_edit{};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void CreateCheckBox(const QString& label, std::function<void()>& load_func);
|
void CreateCheckBox(const QString& label, std::function<void()>& load_func);
|
||||||
void CreateCheckBoxWithLineEdit(const QString& label, Settings::BasicSetting* other_setting,
|
void CreateCheckBoxWithLineEdit(const QString& label, Settings::BasicSetting* other_setting,
|
||||||
std::function<void()>& load_func);
|
std::function<void()>& load_func);
|
||||||
|
void CreateCheckBoxWithHexEdit(const QString& label, Settings::BasicSetting* other_setting,
|
||||||
|
std::function<void()>& load_func);
|
||||||
void CreateCheckBoxWithSpinBox(const QString& label, Settings::BasicSetting* other_setting,
|
void CreateCheckBoxWithSpinBox(const QString& label, Settings::BasicSetting* other_setting,
|
||||||
std::function<void()>& load_func, const QString& suffix);
|
std::function<void()>& load_func, const std::string& suffix);
|
||||||
|
void CreateCheckBoxWithDateTimeEdit(const QString& label, Settings::BasicSetting* other_setting,
|
||||||
|
std::function<void()>& load_func);
|
||||||
void CreateCombobox(const QString& label, bool managed, std::function<void()>& load_func);
|
void CreateCombobox(const QString& label, bool managed, std::function<void()>& load_func);
|
||||||
void CreateLineEdit(const QString& label, bool managed, std::function<void()>& load_func);
|
void CreateLineEdit(const QString& label, bool managed, std::function<void()>& load_func);
|
||||||
void CreateSlider(const QString& label, bool reversed, float multiplier,
|
void CreateSlider(const QString& label, bool reversed, float multiplier,
|
||||||
|
|
|
@ -229,6 +229,7 @@ void Config::ReadValues() {
|
||||||
ReadCategory(Settings::Category::RendererAdvanced);
|
ReadCategory(Settings::Category::RendererAdvanced);
|
||||||
ReadCategory(Settings::Category::RendererDebug);
|
ReadCategory(Settings::Category::RendererDebug);
|
||||||
ReadCategory(Settings::Category::System);
|
ReadCategory(Settings::Category::System);
|
||||||
|
ReadCategory(Settings::Category::SystemAudio);
|
||||||
ReadCategory(Settings::Category::DataStorage);
|
ReadCategory(Settings::Category::DataStorage);
|
||||||
ReadCategory(Settings::Category::Debugging);
|
ReadCategory(Settings::Category::Debugging);
|
||||||
ReadCategory(Settings::Category::DebuggingGraphics);
|
ReadCategory(Settings::Category::DebuggingGraphics);
|
||||||
|
|
Loading…
Reference in New Issue