mirror of
https://git.suyu.dev/suyu/suyu.git
synced 2024-11-25 22:57:22 +00:00
configure_graphics: More complete reimplementation
This commit is contained in:
parent
3a7a5edcea
commit
9a844bbf0c
4 changed files with 113 additions and 345 deletions
|
@ -9,6 +9,7 @@
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QString>
|
#include <QString>
|
||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
|
#include <qcheckbox.h>
|
||||||
#include <qnamespace.h>
|
#include <qnamespace.h>
|
||||||
#include "common/settings.h"
|
#include "common/settings.h"
|
||||||
#include "yuzu/configuration/configuration_shared.h"
|
#include "yuzu/configuration/configuration_shared.h"
|
||||||
|
@ -57,7 +58,7 @@ static std::pair<QWidget*, std::function<void()>> CreateCheckBox(Settings::Basic
|
||||||
}
|
}
|
||||||
|
|
||||||
static std::tuple<QWidget*, void*, std::function<void()>> CreateCombobox(
|
static std::tuple<QWidget*, void*, std::function<void()>> CreateCombobox(
|
||||||
Settings::BasicSetting* setting, const QString& label, QWidget* parent) {
|
Settings::BasicSetting* setting, const QString& label, QWidget* parent, bool managed) {
|
||||||
const auto type = setting->TypeId();
|
const auto type = setting->TypeId();
|
||||||
|
|
||||||
QWidget* group = new QWidget(parent);
|
QWidget* group = new QWidget(parent);
|
||||||
|
@ -78,7 +79,7 @@ static std::tuple<QWidget*, void*, std::function<void()>> CreateCombobox(
|
||||||
combobox_layout->setSpacing(6);
|
combobox_layout->setSpacing(6);
|
||||||
combobox_layout->setContentsMargins(0, 0, 0, 0);
|
combobox_layout->setContentsMargins(0, 0, 0, 0);
|
||||||
|
|
||||||
if (setting->Switchable() && !Settings::IsConfiguringGlobal()) {
|
if (setting->Switchable() && !Settings::IsConfiguringGlobal() && managed) {
|
||||||
int current = std::stoi(setting->ToString());
|
int current = std::stoi(setting->ToString());
|
||||||
int global_value = std::stoi(setting->ToStringGlobal());
|
int global_value = std::stoi(setting->ToStringGlobal());
|
||||||
SetColoredComboBox(combobox, group, global_value);
|
SetColoredComboBox(combobox, group, global_value);
|
||||||
|
@ -92,23 +93,26 @@ static std::tuple<QWidget*, void*, std::function<void()>> CreateCombobox(
|
||||||
combobox->setCurrentIndex(std::stoi(setting->ToString()));
|
combobox->setCurrentIndex(std::stoi(setting->ToString()));
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto load_func = [combobox, setting]() {
|
std::function<void()> load_func = []() {};
|
||||||
if (Settings::IsConfiguringGlobal()) {
|
if (managed) {
|
||||||
setting->LoadString(std::to_string(combobox->currentIndex()));
|
load_func = [combobox, setting]() {
|
||||||
}
|
if (Settings::IsConfiguringGlobal()) {
|
||||||
|
setting->LoadString(std::to_string(combobox->currentIndex()));
|
||||||
|
}
|
||||||
|
|
||||||
if (Settings::IsConfiguringGlobal() || !setting->Switchable()) {
|
if (Settings::IsConfiguringGlobal() || !setting->Switchable()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool using_global = combobox->currentIndex() == USE_GLOBAL_INDEX;
|
bool using_global = combobox->currentIndex() == USE_GLOBAL_INDEX;
|
||||||
int index = combobox->currentIndex() - USE_GLOBAL_OFFSET;
|
int index = combobox->currentIndex() - USE_GLOBAL_OFFSET;
|
||||||
|
|
||||||
setting->SetGlobal(using_global);
|
setting->SetGlobal(using_global);
|
||||||
if (!using_global) {
|
if (!using_global) {
|
||||||
setting->LoadString(std::to_string(index));
|
setting->LoadString(std::to_string(index));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
}
|
||||||
|
|
||||||
return {group, combobox, load_func};
|
return {group, combobox, load_func};
|
||||||
}
|
}
|
||||||
|
@ -116,25 +120,68 @@ static std::tuple<QWidget*, void*, std::function<void()>> CreateCombobox(
|
||||||
static std::tuple<QWidget*, void*, std::function<void()>> CreateLineEdit(
|
static std::tuple<QWidget*, void*, std::function<void()>> CreateLineEdit(
|
||||||
Settings::BasicSetting* setting, const QString& label, QWidget* parent) {
|
Settings::BasicSetting* setting, const QString& label, QWidget* parent) {
|
||||||
QWidget* widget = new QWidget(parent);
|
QWidget* widget = new QWidget(parent);
|
||||||
|
widget->setObjectName(label);
|
||||||
|
|
||||||
QHBoxLayout* layout = new QHBoxLayout(widget);
|
QHBoxLayout* layout = new QHBoxLayout(widget);
|
||||||
|
QLineEdit* line_edit = new QLineEdit(parent);
|
||||||
|
|
||||||
QLabel* q_label = new QLabel(label, widget);
|
const QString text = QString::fromStdString(setting->ToString());
|
||||||
QLineEdit* line_edit = new QLineEdit(widget);
|
line_edit->setText(text);
|
||||||
|
|
||||||
|
std::function<void()> load_func;
|
||||||
|
|
||||||
|
// setSizePolicy lets widget expand and take an equal part of the space as the line edit
|
||||||
|
if (Settings::IsConfiguringGlobal()) {
|
||||||
|
QLabel* q_label = new QLabel(label, widget);
|
||||||
|
q_label->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Preferred);
|
||||||
|
layout->addWidget(q_label);
|
||||||
|
|
||||||
|
load_func = [&]() {
|
||||||
|
std::string load_text = line_edit->text().toStdString();
|
||||||
|
setting->LoadString(load_text);
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
QCheckBox* checkbox = new QCheckBox(label, parent);
|
||||||
|
checkbox->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Preferred);
|
||||||
|
layout->addWidget(checkbox);
|
||||||
|
|
||||||
|
const auto highlight_func = [widget, line_edit](int state) {
|
||||||
|
bool using_global = state != Qt::Checked;
|
||||||
|
SetHighlight(widget, !using_global);
|
||||||
|
line_edit->setEnabled(!using_global);
|
||||||
|
};
|
||||||
|
|
||||||
|
QObject::connect(checkbox, qOverload<int>(&QCheckBox::stateChanged), widget,
|
||||||
|
highlight_func);
|
||||||
|
|
||||||
|
checkbox->setCheckState(setting->UsingGlobal() ? Qt::Unchecked : Qt::Checked);
|
||||||
|
highlight_func(checkbox->checkState());
|
||||||
|
|
||||||
|
load_func = [&]() {
|
||||||
|
if (checkbox->checkState() == Qt::Checked) {
|
||||||
|
setting->SetGlobal(false);
|
||||||
|
|
||||||
|
std::string load_text = line_edit->text().toStdString();
|
||||||
|
setting->LoadString(load_text);
|
||||||
|
} else {
|
||||||
|
setting->SetGlobal(true);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
layout->addWidget(q_label);
|
|
||||||
layout->addStretch();
|
|
||||||
layout->addWidget(line_edit);
|
layout->addWidget(line_edit);
|
||||||
|
|
||||||
layout->setContentsMargins(0, 0, 0, 0);
|
layout->setContentsMargins(0, 0, 0, 0);
|
||||||
|
|
||||||
return {widget, line_edit, []() {}};
|
return {widget, line_edit, load_func};
|
||||||
}
|
}
|
||||||
|
|
||||||
std::pair<QWidget*, void*> CreateWidget(Settings::BasicSetting* setting,
|
std::pair<QWidget*, void*> CreateWidget(Settings::BasicSetting* setting,
|
||||||
const TranslationMap& translations, QWidget* parent,
|
const TranslationMap& translations, QWidget* parent,
|
||||||
bool runtime_lock,
|
bool runtime_lock,
|
||||||
std::forward_list<std::function<void(bool)>>& apply_funcs,
|
std::forward_list<std::function<void(bool)>>& apply_funcs,
|
||||||
std::list<CheckState>& trackers, RequestType request) {
|
std::list<CheckState>& trackers, RequestType request,
|
||||||
|
bool managed) {
|
||||||
const auto type = setting->TypeId();
|
const auto type = setting->TypeId();
|
||||||
const int id = setting->Id();
|
const int id = setting->Id();
|
||||||
QWidget* widget{nullptr};
|
QWidget* widget{nullptr};
|
||||||
|
@ -162,7 +209,7 @@ std::pair<QWidget*, void*> CreateWidget(Settings::BasicSetting* setting,
|
||||||
widget = pair.first;
|
widget = pair.first;
|
||||||
load_func = pair.second;
|
load_func = pair.second;
|
||||||
} else if (setting->IsEnum()) {
|
} else if (setting->IsEnum()) {
|
||||||
auto tuple = CreateCombobox(setting, label, parent);
|
auto tuple = CreateCombobox(setting, label, parent, managed);
|
||||||
widget = std::get<0>(tuple);
|
widget = std::get<0>(tuple);
|
||||||
extra = std::get<1>(tuple);
|
extra = std::get<1>(tuple);
|
||||||
load_func = std::get<2>(tuple);
|
load_func = std::get<2>(tuple);
|
||||||
|
@ -176,7 +223,7 @@ std::pair<QWidget*, void*> CreateWidget(Settings::BasicSetting* setting,
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case RequestType::ComboBox: {
|
case RequestType::ComboBox: {
|
||||||
auto tuple = CreateCombobox(setting, label, parent);
|
auto tuple = CreateCombobox(setting, label, parent, managed);
|
||||||
widget = std::get<0>(tuple);
|
widget = std::get<0>(tuple);
|
||||||
extra = std::get<1>(tuple);
|
extra = std::get<1>(tuple);
|
||||||
load_func = std::get<2>(tuple);
|
load_func = std::get<2>(tuple);
|
||||||
|
@ -201,9 +248,9 @@ std::pair<QWidget*, void*> CreateWidget(Settings::BasicSetting* setting,
|
||||||
});
|
});
|
||||||
|
|
||||||
bool enable = runtime_lock || setting->RuntimeModfiable();
|
bool enable = runtime_lock || setting->RuntimeModfiable();
|
||||||
enable &=
|
if (setting->Switchable() && Settings::IsConfiguringGlobal() && !runtime_lock) {
|
||||||
setting->Switchable() && !(Settings::IsConfiguringGlobal() && !setting->UsingGlobal());
|
enable &= !setting->UsingGlobal();
|
||||||
enable |= !setting->Switchable() && Settings::IsConfiguringGlobal() && runtime_lock;
|
}
|
||||||
widget->setEnabled(enable);
|
widget->setEnabled(enable);
|
||||||
|
|
||||||
widget->setVisible(Settings::IsConfiguringGlobal() || setting->Switchable());
|
widget->setVisible(Settings::IsConfiguringGlobal() || setting->Switchable());
|
||||||
|
|
|
@ -54,7 +54,8 @@ std::pair<QWidget*, void*> CreateWidget(Settings::BasicSetting* setting,
|
||||||
bool runtime_lock,
|
bool runtime_lock,
|
||||||
std::forward_list<std::function<void(bool)>>& apply_funcs,
|
std::forward_list<std::function<void(bool)>>& apply_funcs,
|
||||||
std::list<CheckState>& trackers,
|
std::list<CheckState>& trackers,
|
||||||
RequestType request = RequestType::Default);
|
RequestType request = RequestType::Default,
|
||||||
|
bool managed = true);
|
||||||
|
|
||||||
// Global-aware apply and set functions
|
// Global-aware apply and set functions
|
||||||
|
|
||||||
|
|
|
@ -55,20 +55,20 @@ static constexpr VkPresentModeKHR VSyncSettingToMode(Settings::VSyncMode mode) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// static constexpr Settings::VSyncMode PresentModeToSetting(VkPresentModeKHR mode) {
|
static constexpr Settings::VSyncMode PresentModeToSetting(VkPresentModeKHR mode) {
|
||||||
// switch (mode) {
|
switch (mode) {
|
||||||
// case VK_PRESENT_MODE_IMMEDIATE_KHR:
|
case VK_PRESENT_MODE_IMMEDIATE_KHR:
|
||||||
// return Settings::VSyncMode::Immediate;
|
return Settings::VSyncMode::Immediate;
|
||||||
// case VK_PRESENT_MODE_MAILBOX_KHR:
|
case VK_PRESENT_MODE_MAILBOX_KHR:
|
||||||
// return Settings::VSyncMode::Mailbox;
|
return Settings::VSyncMode::Mailbox;
|
||||||
// case VK_PRESENT_MODE_FIFO_KHR:
|
case VK_PRESENT_MODE_FIFO_KHR:
|
||||||
// return Settings::VSyncMode::FIFO;
|
return Settings::VSyncMode::FIFO;
|
||||||
// case VK_PRESENT_MODE_FIFO_RELAXED_KHR:
|
case VK_PRESENT_MODE_FIFO_RELAXED_KHR:
|
||||||
// return Settings::VSyncMode::FIFORelaxed;
|
return Settings::VSyncMode::FIFORelaxed;
|
||||||
// default:
|
default:
|
||||||
// return Settings::VSyncMode::FIFO;
|
return Settings::VSyncMode::FIFO;
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
|
|
||||||
ConfigureGraphics::ConfigureGraphics(
|
ConfigureGraphics::ConfigureGraphics(
|
||||||
const Core::System& system_, std::vector<VkDeviceInfo::Record>& records_,
|
const Core::System& system_, std::vector<VkDeviceInfo::Record>& records_,
|
||||||
|
@ -112,16 +112,9 @@ ConfigureGraphics::ConfigureGraphics(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SetupPerGameUI();
|
|
||||||
|
|
||||||
connect(api_combobox, qOverload<int>(&QComboBox::currentIndexChanged), this, [this] {
|
connect(api_combobox, qOverload<int>(&QComboBox::currentIndexChanged), this, [this] {
|
||||||
UpdateAPILayout();
|
UpdateAPILayout();
|
||||||
PopulateVSyncModeSelection();
|
PopulateVSyncModeSelection();
|
||||||
if (!Settings::IsConfiguringGlobal()) {
|
|
||||||
ConfigurationShared::SetHighlight(ui->api_widget,
|
|
||||||
api_combobox->currentIndex() !=
|
|
||||||
ConfigurationShared::USE_GLOBAL_INDEX);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
connect(vulkan_device_combobox, qOverload<int>(&QComboBox::activated), this,
|
connect(vulkan_device_combobox, qOverload<int>(&QComboBox::activated), this,
|
||||||
[this](int device) {
|
[this](int device) {
|
||||||
|
@ -215,18 +208,22 @@ void ConfigureGraphics::SetConfiguration() {
|
||||||
QLayout& graphics_layout = *ui->graphics_widget->layout();
|
QLayout& graphics_layout = *ui->graphics_widget->layout();
|
||||||
|
|
||||||
std::map<bool, std::map<std::string, QWidget*>> hold_graphics;
|
std::map<bool, std::map<std::string, QWidget*>> hold_graphics;
|
||||||
|
std::forward_list<QWidget*> hold_api;
|
||||||
|
|
||||||
for (const auto setting : Settings::values.linkage.by_category[Settings::Category::Renderer]) {
|
for (const auto setting : Settings::values.linkage.by_category[Settings::Category::Renderer]) {
|
||||||
const auto& setting_label = setting->GetLabel();
|
const auto& setting_label = setting->GetLabel();
|
||||||
|
|
||||||
auto [widget, extra] = [&]() {
|
auto [widget, extra] = [&]() {
|
||||||
if (setting->Id() == Settings::values.vulkan_device.Id()) {
|
if (setting->Id() == Settings::values.vulkan_device.Id() ||
|
||||||
|
setting->Id() == Settings::values.shader_backend.Id() ||
|
||||||
|
setting->Id() == Settings::values.vsync_mode.Id()) {
|
||||||
return ConfigurationShared::CreateWidget(
|
return ConfigurationShared::CreateWidget(
|
||||||
setting, translations, this, runtime_lock, apply_funcs, trackers,
|
setting, translations, this, runtime_lock, apply_funcs, trackers,
|
||||||
ConfigurationShared::RequestType::ComboBox);
|
ConfigurationShared::RequestType::ComboBox, false);
|
||||||
|
} else {
|
||||||
|
return ConfigurationShared::CreateWidget(setting, translations, this, runtime_lock,
|
||||||
|
apply_funcs, trackers);
|
||||||
}
|
}
|
||||||
return ConfigurationShared::CreateWidget(setting, translations, this, runtime_lock,
|
|
||||||
apply_funcs, trackers);
|
|
||||||
}();
|
}();
|
||||||
|
|
||||||
if (widget == nullptr) {
|
if (widget == nullptr) {
|
||||||
|
@ -237,11 +234,11 @@ void ConfigureGraphics::SetConfiguration() {
|
||||||
api_layout.addWidget(widget);
|
api_layout.addWidget(widget);
|
||||||
api_combobox = reinterpret_cast<QComboBox*>(extra);
|
api_combobox = reinterpret_cast<QComboBox*>(extra);
|
||||||
} else if (setting->Id() == Settings::values.vulkan_device.Id()) {
|
} else if (setting->Id() == Settings::values.vulkan_device.Id()) {
|
||||||
api_layout.addWidget(widget);
|
hold_api.push_front(widget);
|
||||||
vulkan_device_combobox = reinterpret_cast<QComboBox*>(extra);
|
vulkan_device_combobox = reinterpret_cast<QComboBox*>(extra);
|
||||||
vulkan_device_widget = widget;
|
vulkan_device_widget = widget;
|
||||||
} else if (setting->Id() == Settings::values.shader_backend.Id()) {
|
} else if (setting->Id() == Settings::values.shader_backend.Id()) {
|
||||||
api_layout.addWidget(widget);
|
hold_api.push_front(widget);
|
||||||
shader_backend_combobox = reinterpret_cast<QComboBox*>(extra);
|
shader_backend_combobox = reinterpret_cast<QComboBox*>(extra);
|
||||||
shader_backend_widget = widget;
|
shader_backend_widget = widget;
|
||||||
} else if (setting->Id() == Settings::values.vsync_mode.Id()) {
|
} else if (setting->Id() == Settings::values.vsync_mode.Id()) {
|
||||||
|
@ -258,86 +255,9 @@ void ConfigureGraphics::SetConfiguration() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// ui->api_widget->setEnabled(runtime_lock);
|
for (auto widget : hold_api) {
|
||||||
// ui->use_asynchronous_gpu_emulation->setEnabled(runtime_lock);
|
api_layout.addWidget(widget);
|
||||||
// ui->use_disk_shader_cache->setEnabled(runtime_lock);
|
}
|
||||||
// ui->nvdec_emulation_widget->setEnabled(runtime_lock);
|
|
||||||
// ui->resolution_combobox->setEnabled(runtime_lock);
|
|
||||||
// ui->astc_decode_mode_combobox->setEnabled(runtime_lock);
|
|
||||||
// ui->vsync_mode_layout->setEnabled(runtime_lock ||
|
|
||||||
// Settings::values.renderer_backend.GetValue() ==
|
|
||||||
// Settings::RendererBackend::Vulkan);
|
|
||||||
// ui->use_disk_shader_cache->setChecked(Settings::values.use_disk_shader_cache.GetValue());
|
|
||||||
// ui->use_asynchronous_gpu_emulation->setChecked(
|
|
||||||
// Settings::values.use_asynchronous_gpu_emulation.GetValue());
|
|
||||||
|
|
||||||
// if (Settings::IsConfiguringGlobal()) {
|
|
||||||
// api_combobox->setCurrentIndex(static_cast<int>(Settings::values.renderer_backend.GetValue()));
|
|
||||||
// ui->fullscreen_mode_combobox->setCurrentIndex(
|
|
||||||
// static_cast<int>(Settings::values.fullscreen_mode.GetValue()));
|
|
||||||
// ui->nvdec_emulation->setCurrentIndex(
|
|
||||||
// static_cast<int>(Settings::values.nvdec_emulation.GetValue()));
|
|
||||||
// ui->aspect_ratio_combobox->setCurrentIndex(Settings::values.aspect_ratio.GetValue());
|
|
||||||
// ui->resolution_combobox->setCurrentIndex(
|
|
||||||
// static_cast<int>(Settings::values.resolution_setup.GetValue()));
|
|
||||||
// ui->scaling_filter_combobox->setCurrentIndex(
|
|
||||||
// static_cast<int>(Settings::values.scaling_filter.GetValue()));
|
|
||||||
// ui->fsr_sharpening_slider->setValue(Settings::values.fsr_sharpening_slider.GetValue());
|
|
||||||
// ui->anti_aliasing_combobox->setCurrentIndex(
|
|
||||||
// static_cast<int>(Settings::values.anti_aliasing.GetValue()));
|
|
||||||
// } else {
|
|
||||||
// ConfigurationShared::SetPerGameSetting(api_combobox, &Settings::values.renderer_backend);
|
|
||||||
// ConfigurationShared::SetHighlight(ui->api_widget,
|
|
||||||
// !Settings::values.renderer_backend.UsingGlobal());
|
|
||||||
|
|
||||||
// ConfigurationShared::SetPerGameSetting(ui->astc_decode_mode_combobox,
|
|
||||||
// &Settings::values.accelerate_astc);
|
|
||||||
// ConfigurationShared::SetHighlight(ui->astc_decode_mode_layout,
|
|
||||||
// !Settings::values.accelerate_astc.UsingGlobal());
|
|
||||||
|
|
||||||
// ConfigurationShared::SetPerGameSetting(ui->nvdec_emulation,
|
|
||||||
// &Settings::values.nvdec_emulation);
|
|
||||||
// ConfigurationShared::SetHighlight(ui->nvdec_emulation_widget,
|
|
||||||
// !Settings::values.nvdec_emulation.UsingGlobal());
|
|
||||||
|
|
||||||
// ConfigurationShared::SetPerGameSetting(ui->fullscreen_mode_combobox,
|
|
||||||
// &Settings::values.fullscreen_mode);
|
|
||||||
// ConfigurationShared::SetHighlight(ui->fullscreen_mode_label,
|
|
||||||
// !Settings::values.fullscreen_mode.UsingGlobal());
|
|
||||||
|
|
||||||
// ConfigurationShared::SetPerGameSetting(ui->aspect_ratio_combobox,
|
|
||||||
// &Settings::values.aspect_ratio);
|
|
||||||
// ConfigurationShared::SetHighlight(ui->ar_label,
|
|
||||||
// !Settings::values.aspect_ratio.UsingGlobal());
|
|
||||||
|
|
||||||
// ConfigurationShared::SetPerGameSetting(ui->resolution_combobox,
|
|
||||||
// &Settings::values.resolution_setup);
|
|
||||||
// ConfigurationShared::SetHighlight(ui->resolution_label,
|
|
||||||
// !Settings::values.resolution_setup.UsingGlobal());
|
|
||||||
|
|
||||||
// ConfigurationShared::SetPerGameSetting(ui->scaling_filter_combobox,
|
|
||||||
// &Settings::values.scaling_filter);
|
|
||||||
// ConfigurationShared::SetHighlight(ui->scaling_filter_label,
|
|
||||||
// !Settings::values.scaling_filter.UsingGlobal());
|
|
||||||
|
|
||||||
// ConfigurationShared::SetPerGameSetting(ui->anti_aliasing_combobox,
|
|
||||||
// &Settings::values.anti_aliasing);
|
|
||||||
// ConfigurationShared::SetHighlight(ui->anti_aliasing_label,
|
|
||||||
// !Settings::values.anti_aliasing.UsingGlobal());
|
|
||||||
|
|
||||||
// ui->fsr_sharpening_combobox->setCurrentIndex(
|
|
||||||
// Settings::values.fsr_sharpening_slider.UsingGlobal() ? 0 : 1);
|
|
||||||
// ui->fsr_sharpening_slider->setEnabled(
|
|
||||||
// !Settings::values.fsr_sharpening_slider.UsingGlobal());
|
|
||||||
// ui->fsr_sharpening_value->setEnabled(!Settings::values.fsr_sharpening_slider.UsingGlobal());
|
|
||||||
// ConfigurationShared::SetHighlight(ui->fsr_sharpening_layout,
|
|
||||||
// !Settings::values.fsr_sharpening_slider.UsingGlobal());
|
|
||||||
// ui->fsr_sharpening_slider->setValue(Settings::values.fsr_sharpening_slider.GetValue());
|
|
||||||
|
|
||||||
// ui->bg_combobox->setCurrentIndex(Settings::values.bg_red.UsingGlobal() ? 0 : 1);
|
|
||||||
// ui->bg_button->setEnabled(!Settings::values.bg_red.UsingGlobal());
|
|
||||||
// ConfigurationShared::SetHighlight(ui->bg_layout, !Settings::values.bg_red.UsingGlobal());
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigureGraphics::SetFSRIndicatorText(int percentage) {
|
void ConfigureGraphics::SetFSRIndicatorText(int percentage) {
|
||||||
|
@ -367,134 +287,16 @@ const QString ConfigureGraphics::TranslateVSyncMode(VkPresentModeKHR mode,
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigureGraphics::ApplyConfiguration() {
|
void ConfigureGraphics::ApplyConfiguration() {
|
||||||
// const auto resolution_setup = static_cast<Settings::ResolutionSetup>(
|
const bool powered_on = system.IsPoweredOn();
|
||||||
// ui->resolution_combobox->currentIndex() -
|
for (const auto& func : apply_funcs) {
|
||||||
// ((Settings::IsConfiguringGlobal()) ? 0 : ConfigurationShared::USE_GLOBAL_OFFSET));
|
func(powered_on);
|
||||||
|
}
|
||||||
|
|
||||||
// const auto scaling_filter = static_cast<Settings::ScalingFilter>(
|
if (Settings::IsConfiguringGlobal()) {
|
||||||
// ui->scaling_filter_combobox->currentIndex() -
|
const auto mode = vsync_mode_combobox_enum_map[vsync_mode_combobox->currentIndex()];
|
||||||
// ((Settings::IsConfiguringGlobal()) ? 0 : ConfigurationShared::USE_GLOBAL_OFFSET));
|
const auto vsync_mode = PresentModeToSetting(mode);
|
||||||
|
Settings::values.vsync_mode.SetValue(vsync_mode);
|
||||||
// const auto anti_aliasing = static_cast<Settings::AntiAliasing>(
|
}
|
||||||
// ui->anti_aliasing_combobox->currentIndex() -
|
|
||||||
// ((Settings::IsConfiguringGlobal()) ? 0 : ConfigurationShared::USE_GLOBAL_OFFSET));
|
|
||||||
|
|
||||||
// ConfigurationShared::ApplyPerGameSetting(&Settings::values.fullscreen_mode,
|
|
||||||
// ui->fullscreen_mode_combobox);
|
|
||||||
// ConfigurationShared::ApplyPerGameSetting(&Settings::values.aspect_ratio,
|
|
||||||
// ui->aspect_ratio_combobox);
|
|
||||||
// ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_disk_shader_cache,
|
|
||||||
// ui->use_disk_shader_cache, use_disk_shader_cache);
|
|
||||||
// ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_asynchronous_gpu_emulation,
|
|
||||||
// ui->use_asynchronous_gpu_emulation,
|
|
||||||
// use_asynchronous_gpu_emulation);
|
|
||||||
// ConfigurationShared::ApplyPerGameSetting(&Settings::values.accelerate_astc,
|
|
||||||
// ui->astc_decode_mode_combobox);
|
|
||||||
|
|
||||||
// if (Settings::IsConfiguringGlobal()) {
|
|
||||||
// // Guard if during game and set to game-specific value
|
|
||||||
// if (Settings::values.renderer_backend.UsingGlobal()) {
|
|
||||||
// Settings::values.renderer_backend.SetValue(GetCurrentGraphicsBackend());
|
|
||||||
// }
|
|
||||||
// if (Settings::values.nvdec_emulation.UsingGlobal()) {
|
|
||||||
// Settings::values.nvdec_emulation.SetValue(GetCurrentNvdecEmulation());
|
|
||||||
// }
|
|
||||||
// if (Settings::values.shader_backend.UsingGlobal()) {
|
|
||||||
// Settings::values.shader_backend.SetValue(shader_backend);
|
|
||||||
// }
|
|
||||||
// if (Settings::values.vulkan_device.UsingGlobal()) {
|
|
||||||
// Settings::values.vulkan_device.SetValue(vulkan_device);
|
|
||||||
// }
|
|
||||||
// if (Settings::values.bg_red.UsingGlobal()) {
|
|
||||||
// Settings::values.bg_red.SetValue(static_cast<u8>(bg_color.red()));
|
|
||||||
// Settings::values.bg_green.SetValue(static_cast<u8>(bg_color.green()));
|
|
||||||
// Settings::values.bg_blue.SetValue(static_cast<u8>(bg_color.blue()));
|
|
||||||
// }
|
|
||||||
// if (Settings::values.resolution_setup.UsingGlobal()) {
|
|
||||||
// Settings::values.resolution_setup.SetValue(resolution_setup);
|
|
||||||
// }
|
|
||||||
// if (Settings::values.scaling_filter.UsingGlobal()) {
|
|
||||||
// Settings::values.scaling_filter.SetValue(scaling_filter);
|
|
||||||
// }
|
|
||||||
// if (Settings::values.anti_aliasing.UsingGlobal()) {
|
|
||||||
// Settings::values.anti_aliasing.SetValue(anti_aliasing);
|
|
||||||
// }
|
|
||||||
// Settings::values.fsr_sharpening_slider.SetValue(ui->fsr_sharpening_slider->value());
|
|
||||||
|
|
||||||
// const auto mode = vsync_mode_combobox_enum_map[vsync_mode_combobox->currentIndex()];
|
|
||||||
// const auto vsync_mode = PresentModeToSetting(mode);
|
|
||||||
// Settings::values.vsync_mode.SetValue(vsync_mode);
|
|
||||||
// } else {
|
|
||||||
// if (ui->resolution_combobox->currentIndex() == ConfigurationShared::USE_GLOBAL_INDEX) {
|
|
||||||
// Settings::values.resolution_setup.SetGlobal(true);
|
|
||||||
// } else {
|
|
||||||
// Settings::values.resolution_setup.SetGlobal(false);
|
|
||||||
// Settings::values.resolution_setup.SetValue(resolution_setup);
|
|
||||||
// }
|
|
||||||
// if (ui->scaling_filter_combobox->currentIndex() == ConfigurationShared::USE_GLOBAL_INDEX)
|
|
||||||
// {
|
|
||||||
// Settings::values.scaling_filter.SetGlobal(true);
|
|
||||||
// } else {
|
|
||||||
// Settings::values.scaling_filter.SetGlobal(false);
|
|
||||||
// Settings::values.scaling_filter.SetValue(scaling_filter);
|
|
||||||
// }
|
|
||||||
// if (ui->anti_aliasing_combobox->currentIndex() == ConfigurationShared::USE_GLOBAL_INDEX)
|
|
||||||
// {
|
|
||||||
// Settings::values.anti_aliasing.SetGlobal(true);
|
|
||||||
// } else {
|
|
||||||
// Settings::values.anti_aliasing.SetGlobal(false);
|
|
||||||
// Settings::values.anti_aliasing.SetValue(anti_aliasing);
|
|
||||||
// }
|
|
||||||
// if (api_combobox->currentIndex() == ConfigurationShared::USE_GLOBAL_INDEX) {
|
|
||||||
// Settings::values.renderer_backend.SetGlobal(true);
|
|
||||||
// Settings::values.shader_backend.SetGlobal(true);
|
|
||||||
// Settings::values.vulkan_device.SetGlobal(true);
|
|
||||||
// } else {
|
|
||||||
// Settings::values.renderer_backend.SetGlobal(false);
|
|
||||||
// Settings::values.renderer_backend.SetValue(GetCurrentGraphicsBackend());
|
|
||||||
// switch (GetCurrentGraphicsBackend()) {
|
|
||||||
// case Settings::RendererBackend::OpenGL:
|
|
||||||
// case Settings::RendererBackend::Null:
|
|
||||||
// Settings::values.shader_backend.SetGlobal(false);
|
|
||||||
// Settings::values.vulkan_device.SetGlobal(true);
|
|
||||||
// Settings::values.shader_backend.SetValue(shader_backend);
|
|
||||||
// break;
|
|
||||||
// case Settings::RendererBackend::Vulkan:
|
|
||||||
// Settings::values.shader_backend.SetGlobal(true);
|
|
||||||
// Settings::values.vulkan_device.SetGlobal(false);
|
|
||||||
// Settings::values.vulkan_device.SetValue(vulkan_device);
|
|
||||||
// break;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
|
|
||||||
// if (ui->nvdec_emulation->currentIndex() == ConfigurationShared::USE_GLOBAL_INDEX) {
|
|
||||||
// Settings::values.nvdec_emulation.SetGlobal(true);
|
|
||||||
// } else {
|
|
||||||
// Settings::values.nvdec_emulation.SetGlobal(false);
|
|
||||||
// Settings::values.nvdec_emulation.SetValue(GetCurrentNvdecEmulation());
|
|
||||||
// }
|
|
||||||
|
|
||||||
// if (ui->bg_combobox->currentIndex() == ConfigurationShared::USE_GLOBAL_INDEX) {
|
|
||||||
// Settings::values.bg_red.SetGlobal(true);
|
|
||||||
// Settings::values.bg_green.SetGlobal(true);
|
|
||||||
// Settings::values.bg_blue.SetGlobal(true);
|
|
||||||
// } else {
|
|
||||||
// Settings::values.bg_red.SetGlobal(false);
|
|
||||||
// Settings::values.bg_green.SetGlobal(false);
|
|
||||||
// Settings::values.bg_blue.SetGlobal(false);
|
|
||||||
// Settings::values.bg_red.SetValue(static_cast<u8>(bg_color.red()));
|
|
||||||
// Settings::values.bg_green.SetValue(static_cast<u8>(bg_color.green()));
|
|
||||||
// Settings::values.bg_blue.SetValue(static_cast<u8>(bg_color.blue()));
|
|
||||||
// }
|
|
||||||
|
|
||||||
// if (ui->fsr_sharpening_combobox->currentIndex() == ConfigurationShared::USE_GLOBAL_INDEX)
|
|
||||||
// {
|
|
||||||
// Settings::values.fsr_sharpening_slider.SetGlobal(true);
|
|
||||||
// } else {
|
|
||||||
// Settings::values.fsr_sharpening_slider.SetGlobal(false);
|
|
||||||
// Settings::values.fsr_sharpening_slider.SetValue(ui->fsr_sharpening_slider->value());
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigureGraphics::changeEvent(QEvent* event) {
|
void ConfigureGraphics::changeEvent(QEvent* event) {
|
||||||
|
@ -581,83 +383,3 @@ Settings::RendererBackend ConfigureGraphics::GetCurrentGraphicsBackend() const {
|
||||||
return static_cast<Settings::RendererBackend>(api_combobox->currentIndex() -
|
return static_cast<Settings::RendererBackend>(api_combobox->currentIndex() -
|
||||||
ConfigurationShared::USE_GLOBAL_OFFSET);
|
ConfigurationShared::USE_GLOBAL_OFFSET);
|
||||||
}
|
}
|
||||||
|
|
||||||
Settings::NvdecEmulation ConfigureGraphics::GetCurrentNvdecEmulation() const {
|
|
||||||
return Settings::NvdecEmulation::CPU;
|
|
||||||
// if (Settings::IsConfiguringGlobal()) {
|
|
||||||
// return static_cast<Settings::NvdecEmulation>(ui->nvdec_emulation->currentIndex());
|
|
||||||
// }
|
|
||||||
|
|
||||||
// if (ui->nvdec_emulation->currentIndex() == ConfigurationShared::USE_GLOBAL_INDEX) {
|
|
||||||
// Settings::values.nvdec_emulation.SetGlobal(true);
|
|
||||||
// return Settings::values.nvdec_emulation.GetValue();
|
|
||||||
// }
|
|
||||||
// Settings::values.nvdec_emulation.SetGlobal(false);
|
|
||||||
// return static_cast<Settings::NvdecEmulation>(ui->nvdec_emulation->currentIndex() -
|
|
||||||
// ConfigurationShared::USE_GLOBAL_OFFSET);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConfigureGraphics::SetupPerGameUI() {
|
|
||||||
// if (Settings::IsConfiguringGlobal()) {
|
|
||||||
// api_combobox->setEnabled(Settings::values.renderer_backend.UsingGlobal());
|
|
||||||
// vulkan_device_combobox->setEnabled(Settings::values.renderer_backend.UsingGlobal());
|
|
||||||
// ui->fullscreen_mode_combobox->setEnabled(Settings::values.fullscreen_mode.UsingGlobal());
|
|
||||||
// ui->aspect_ratio_combobox->setEnabled(Settings::values.aspect_ratio.UsingGlobal());
|
|
||||||
// ui->resolution_combobox->setEnabled(Settings::values.resolution_setup.UsingGlobal());
|
|
||||||
// ui->scaling_filter_combobox->setEnabled(Settings::values.scaling_filter.UsingGlobal());
|
|
||||||
// ui->fsr_sharpening_slider->setEnabled(Settings::values.fsr_sharpening_slider.UsingGlobal());
|
|
||||||
// ui->anti_aliasing_combobox->setEnabled(Settings::values.anti_aliasing.UsingGlobal());
|
|
||||||
// ui->use_asynchronous_gpu_emulation->setEnabled(
|
|
||||||
// Settings::values.use_asynchronous_gpu_emulation.UsingGlobal());
|
|
||||||
// ui->nvdec_emulation->setEnabled(Settings::values.nvdec_emulation.UsingGlobal());
|
|
||||||
// ui->astc_decode_mode_combobox->setEnabled(Settings::values.accelerate_astc.UsingGlobal());
|
|
||||||
// ui->use_disk_shader_cache->setEnabled(Settings::values.use_disk_shader_cache.UsingGlobal());
|
|
||||||
// ui->bg_button->setEnabled(Settings::values.bg_red.UsingGlobal());
|
|
||||||
// ui->fsr_slider_layout->setEnabled(Settings::values.fsr_sharpening_slider.UsingGlobal());
|
|
||||||
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
|
|
||||||
// connect(ui->bg_combobox, qOverload<int>(&QComboBox::activated), this, [this](int index) {
|
|
||||||
// ui->bg_button->setEnabled(index == 1);
|
|
||||||
// ConfigurationShared::SetHighlight(ui->bg_layout, index == 1);
|
|
||||||
// });
|
|
||||||
|
|
||||||
// connect(ui->fsr_sharpening_combobox, qOverload<int>(&QComboBox::activated), this,
|
|
||||||
// [this](int index) {
|
|
||||||
// ui->fsr_sharpening_slider->setEnabled(index == 1);
|
|
||||||
// ui->fsr_sharpening_value->setEnabled(index == 1);
|
|
||||||
// ConfigurationShared::SetHighlight(ui->fsr_sharpening_layout, index == 1);
|
|
||||||
// });
|
|
||||||
|
|
||||||
// ConfigurationShared::SetColoredTristate(
|
|
||||||
// ui->use_disk_shader_cache, Settings::values.use_disk_shader_cache,
|
|
||||||
// use_disk_shader_cache);
|
|
||||||
// ConfigurationShared::SetColoredTristate(ui->use_asynchronous_gpu_emulation,
|
|
||||||
// Settings::values.use_asynchronous_gpu_emulation,
|
|
||||||
// use_asynchronous_gpu_emulation);
|
|
||||||
|
|
||||||
// ConfigurationShared::SetColoredComboBox(ui->aspect_ratio_combobox, ui->ar_label,
|
|
||||||
// Settings::values.aspect_ratio.GetValue(true));
|
|
||||||
// ConfigurationShared::SetColoredComboBox(
|
|
||||||
// ui->fullscreen_mode_combobox, ui->fullscreen_mode_label,
|
|
||||||
// static_cast<int>(Settings::values.fullscreen_mode.GetValue(true)));
|
|
||||||
// ConfigurationShared::SetColoredComboBox(
|
|
||||||
// ui->resolution_combobox, ui->resolution_label,
|
|
||||||
// static_cast<int>(Settings::values.resolution_setup.GetValue(true)));
|
|
||||||
// ConfigurationShared::SetColoredComboBox(
|
|
||||||
// ui->scaling_filter_combobox, ui->scaling_filter_label,
|
|
||||||
// static_cast<int>(Settings::values.scaling_filter.GetValue(true)));
|
|
||||||
// ConfigurationShared::SetColoredComboBox(
|
|
||||||
// ui->anti_aliasing_combobox, ui->anti_aliasing_label,
|
|
||||||
// static_cast<int>(Settings::values.anti_aliasing.GetValue(true)));
|
|
||||||
// ConfigurationShared::SetColoredComboBox(
|
|
||||||
// ui->astc_decode_mode_combobox, ui->astc_decode_mode_label,
|
|
||||||
// static_cast<int>(Settings::values.accelerate_astc.GetValue(true)));
|
|
||||||
// ConfigurationShared::InsertGlobalItem(
|
|
||||||
// api_combobox, static_cast<int>(Settings::values.renderer_backend.GetValue(true)));
|
|
||||||
// ConfigurationShared::InsertGlobalItem(
|
|
||||||
// ui->nvdec_emulation, static_cast<int>(Settings::values.nvdec_emulation.GetValue(true)));
|
|
||||||
|
|
||||||
// ui->vsync_mode_layout->setVisible(false);
|
|
||||||
}
|
|
||||||
|
|
|
@ -64,10 +64,7 @@ private:
|
||||||
const QString TranslateVSyncMode(VkPresentModeKHR mode,
|
const QString TranslateVSyncMode(VkPresentModeKHR mode,
|
||||||
Settings::RendererBackend backend) const;
|
Settings::RendererBackend backend) const;
|
||||||
|
|
||||||
void SetupPerGameUI();
|
|
||||||
|
|
||||||
Settings::RendererBackend GetCurrentGraphicsBackend() const;
|
Settings::RendererBackend GetCurrentGraphicsBackend() const;
|
||||||
Settings::NvdecEmulation GetCurrentNvdecEmulation() const;
|
|
||||||
|
|
||||||
std::unique_ptr<Ui::ConfigureGraphics> ui;
|
std::unique_ptr<Ui::ConfigureGraphics> ui;
|
||||||
QColor bg_color;
|
QColor bg_color;
|
||||||
|
@ -93,5 +90,6 @@ private:
|
||||||
QComboBox* shader_backend_combobox;
|
QComboBox* shader_backend_combobox;
|
||||||
QComboBox* vsync_mode_combobox;
|
QComboBox* vsync_mode_combobox;
|
||||||
QWidget* vulkan_device_widget;
|
QWidget* vulkan_device_widget;
|
||||||
|
QWidget* api_widget;
|
||||||
QWidget* shader_backend_widget;
|
QWidget* shader_backend_widget;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue