forked from suyu/suyu
general: add default configurations for applet mode
This commit is contained in:
parent
78aac6b403
commit
fa12384350
14 changed files with 334 additions and 8 deletions
|
@ -30,6 +30,7 @@ namespace Settings {
|
||||||
#define SETTING(TYPE, RANGED) template class Setting<TYPE, RANGED>
|
#define SETTING(TYPE, RANGED) template class Setting<TYPE, RANGED>
|
||||||
#define SWITCHABLE(TYPE, RANGED) template class SwitchableSetting<TYPE, RANGED>
|
#define SWITCHABLE(TYPE, RANGED) template class SwitchableSetting<TYPE, RANGED>
|
||||||
|
|
||||||
|
SETTING(AppletMode, false);
|
||||||
SETTING(AudioEngine, false);
|
SETTING(AudioEngine, false);
|
||||||
SETTING(bool, false);
|
SETTING(bool, false);
|
||||||
SETTING(int, false);
|
SETTING(int, false);
|
||||||
|
@ -215,6 +216,8 @@ const char* TranslateCategory(Category category) {
|
||||||
return "Debugging";
|
return "Debugging";
|
||||||
case Category::GpuDriver:
|
case Category::GpuDriver:
|
||||||
return "GpuDriver";
|
return "GpuDriver";
|
||||||
|
case Category::LibraryApplet:
|
||||||
|
return "LibraryApplet";
|
||||||
case Category::Miscellaneous:
|
case Category::Miscellaneous:
|
||||||
return "Miscellaneous";
|
return "Miscellaneous";
|
||||||
case Category::Network:
|
case Category::Network:
|
||||||
|
|
|
@ -133,6 +133,38 @@ struct TouchFromButtonMap {
|
||||||
struct Values {
|
struct Values {
|
||||||
Linkage linkage{};
|
Linkage linkage{};
|
||||||
|
|
||||||
|
// Applet
|
||||||
|
Setting<AppletMode> cabinet_applet_mode{linkage, AppletMode::LLE, "cabinet_applet_mode",
|
||||||
|
Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> controller_applet_mode{linkage, AppletMode::HLE, "controller_applet_mode",
|
||||||
|
Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> data_erase_applet_mode{linkage, AppletMode::HLE, "data_erase_applet_mode",
|
||||||
|
Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> error_applet_mode{linkage, AppletMode::HLE, "error_applet_mode",
|
||||||
|
Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> net_connect_applet_mode{linkage, AppletMode::HLE, "net_connect_applet_mode",
|
||||||
|
Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> player_select_applet_mode{
|
||||||
|
linkage, AppletMode::HLE, "player_select_applet_mode", Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> swkbd_applet_mode{linkage, AppletMode::LLE, "swkbd_applet_mode",
|
||||||
|
Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> mii_edit_applet_mode{linkage, AppletMode::LLE, "mii_edit_applet_mode",
|
||||||
|
Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> web_applet_mode{linkage, AppletMode::HLE, "web_applet_mode",
|
||||||
|
Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> shop_applet_mode{linkage, AppletMode::HLE, "shop_applet_mode",
|
||||||
|
Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> photo_viewer_applet_mode{
|
||||||
|
linkage, AppletMode::LLE, "photo_viewer_applet_mode", Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> offline_web_applet_mode{linkage, AppletMode::LLE, "offline_web_applet_mode",
|
||||||
|
Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> login_share_applet_mode{linkage, AppletMode::HLE, "login_share_applet_mode",
|
||||||
|
Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> wifi_web_auth_applet_mode{
|
||||||
|
linkage, AppletMode::HLE, "wifi_web_auth_applet_mode", Category::LibraryApplet};
|
||||||
|
Setting<AppletMode> my_page_applet_mode{linkage, AppletMode::LLE, "my_page_applet_mode",
|
||||||
|
Category::LibraryApplet};
|
||||||
|
|
||||||
// Audio
|
// Audio
|
||||||
SwitchableSetting<AudioEngine> sink_id{linkage, AudioEngine::Auto, "output_engine",
|
SwitchableSetting<AudioEngine> sink_id{linkage, AudioEngine::Auto, "output_engine",
|
||||||
Category::Audio, Specialization::RuntimeList};
|
Category::Audio, Specialization::RuntimeList};
|
||||||
|
|
|
@ -44,6 +44,7 @@ enum class Category : u32 {
|
||||||
Services,
|
Services,
|
||||||
Paths,
|
Paths,
|
||||||
Linux,
|
Linux,
|
||||||
|
LibraryApplet,
|
||||||
MaxEnum,
|
MaxEnum,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -151,6 +151,8 @@ ENUM(AspectRatio, R16_9, R4_3, R21_9, R16_10, Stretch);
|
||||||
|
|
||||||
ENUM(ConsoleMode, Handheld, Docked);
|
ENUM(ConsoleMode, Handheld, Docked);
|
||||||
|
|
||||||
|
ENUM(AppletMode, HLE, LLE);
|
||||||
|
|
||||||
template <typename Type>
|
template <typename Type>
|
||||||
inline std::string CanonicalizeEnum(Type id) {
|
inline std::string CanonicalizeEnum(Type id) {
|
||||||
const auto group = EnumMetadata<Type>::Canonicalizations();
|
const auto group = EnumMetadata<Type>::Canonicalizations();
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
|
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
|
||||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#include "common/settings.h"
|
||||||
#include "core/hle/kernel/k_transfer_memory.h"
|
#include "core/hle/kernel/k_transfer_memory.h"
|
||||||
#include "core/hle/service/am/applet_data_broker.h"
|
#include "core/hle/service/am/applet_data_broker.h"
|
||||||
#include "core/hle/service/am/applet_manager.h"
|
#include "core/hle/service/am/applet_manager.h"
|
||||||
|
@ -16,6 +17,34 @@ namespace Service::AM {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
bool ShouldCreateGuestApplet(AppletId applet_id) {
|
||||||
|
#define X(Name, name) \
|
||||||
|
if (applet_id == AppletId::Name && \
|
||||||
|
Settings::values.name##_applet_mode.GetValue() != Settings::AppletMode::LLE) { \
|
||||||
|
return false; \
|
||||||
|
}
|
||||||
|
|
||||||
|
X(Cabinet, cabinet)
|
||||||
|
X(Controller, controller)
|
||||||
|
X(DataErase, data_erase)
|
||||||
|
X(Error, error)
|
||||||
|
X(NetConnect, net_connect)
|
||||||
|
X(ProfileSelect, player_select)
|
||||||
|
X(SoftwareKeyboard, swkbd)
|
||||||
|
X(MiiEdit, mii_edit)
|
||||||
|
X(Web, web)
|
||||||
|
X(Shop, shop)
|
||||||
|
X(PhotoViewer, photo_viewer)
|
||||||
|
X(OfflineWeb, offline_web)
|
||||||
|
X(LoginShare, login_share)
|
||||||
|
X(WebAuth, wifi_web_auth)
|
||||||
|
X(MyPage, my_page)
|
||||||
|
|
||||||
|
#undef X
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
AppletProgramId AppletIdToProgramId(AppletId applet_id) {
|
AppletProgramId AppletIdToProgramId(AppletId applet_id) {
|
||||||
switch (applet_id) {
|
switch (applet_id) {
|
||||||
case AppletId::OverlayDisplay:
|
case AppletId::OverlayDisplay:
|
||||||
|
@ -63,9 +92,10 @@ AppletProgramId AppletIdToProgramId(AppletId applet_id) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[[maybe_unused]] std::shared_ptr<ILibraryAppletAccessor> CreateGuestApplet(
|
std::shared_ptr<ILibraryAppletAccessor> CreateGuestApplet(Core::System& system,
|
||||||
Core::System& system, std::shared_ptr<Applet> caller_applet, AppletId applet_id,
|
std::shared_ptr<Applet> caller_applet,
|
||||||
LibraryAppletMode mode) {
|
AppletId applet_id,
|
||||||
|
LibraryAppletMode mode) {
|
||||||
const auto program_id = static_cast<u64>(AppletIdToProgramId(applet_id));
|
const auto program_id = static_cast<u64>(AppletIdToProgramId(applet_id));
|
||||||
if (program_id == 0) {
|
if (program_id == 0) {
|
||||||
// Unknown applet
|
// Unknown applet
|
||||||
|
@ -117,9 +147,10 @@ AppletProgramId AppletIdToProgramId(AppletId applet_id) {
|
||||||
return std::make_shared<ILibraryAppletAccessor>(system, broker, applet);
|
return std::make_shared<ILibraryAppletAccessor>(system, broker, applet);
|
||||||
}
|
}
|
||||||
|
|
||||||
[[maybe_unused]] std::shared_ptr<ILibraryAppletAccessor> CreateFrontendApplet(
|
std::shared_ptr<ILibraryAppletAccessor> CreateFrontendApplet(Core::System& system,
|
||||||
Core::System& system, std::shared_ptr<Applet> caller_applet, AppletId applet_id,
|
std::shared_ptr<Applet> caller_applet,
|
||||||
LibraryAppletMode mode) {
|
AppletId applet_id,
|
||||||
|
LibraryAppletMode mode) {
|
||||||
const auto program_id = static_cast<u64>(AppletIdToProgramId(applet_id));
|
const auto program_id = static_cast<u64>(AppletIdToProgramId(applet_id));
|
||||||
|
|
||||||
auto process = std::make_unique<Process>(system);
|
auto process = std::make_unique<Process>(system);
|
||||||
|
@ -163,7 +194,13 @@ void ILibraryAppletCreator::CreateLibraryApplet(HLERequestContext& ctx) {
|
||||||
LOG_DEBUG(Service_AM, "called with applet_id={:08X}, applet_mode={:08X}", applet_id,
|
LOG_DEBUG(Service_AM, "called with applet_id={:08X}, applet_mode={:08X}", applet_id,
|
||||||
applet_mode);
|
applet_mode);
|
||||||
|
|
||||||
auto library_applet = CreateFrontendApplet(system, applet, applet_id, applet_mode);
|
std::shared_ptr<ILibraryAppletAccessor> library_applet;
|
||||||
|
if (ShouldCreateGuestApplet(applet_id)) {
|
||||||
|
library_applet = CreateGuestApplet(system, applet, applet_id, applet_mode);
|
||||||
|
}
|
||||||
|
if (!library_applet) {
|
||||||
|
library_applet = CreateFrontendApplet(system, applet, applet_id, applet_mode);
|
||||||
|
}
|
||||||
if (!library_applet) {
|
if (!library_applet) {
|
||||||
LOG_ERROR(Service_AM, "Applet doesn't exist! applet_id={}", applet_id);
|
LOG_ERROR(Service_AM, "Applet doesn't exist! applet_id={}", applet_id);
|
||||||
|
|
||||||
|
|
|
@ -401,6 +401,14 @@ void Config::ReadNetworkValues() {
|
||||||
EndGroup();
|
EndGroup();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Config::ReadLibraryAppletValues() {
|
||||||
|
BeginGroup(Settings::TranslateCategory(Settings::Category::LibraryApplet));
|
||||||
|
|
||||||
|
ReadCategory(Settings::Category::LibraryApplet);
|
||||||
|
|
||||||
|
EndGroup();
|
||||||
|
}
|
||||||
|
|
||||||
void Config::ReadValues() {
|
void Config::ReadValues() {
|
||||||
if (global) {
|
if (global) {
|
||||||
ReadDataStorageValues();
|
ReadDataStorageValues();
|
||||||
|
@ -410,6 +418,7 @@ void Config::ReadValues() {
|
||||||
ReadServiceValues();
|
ReadServiceValues();
|
||||||
ReadWebServiceValues();
|
ReadWebServiceValues();
|
||||||
ReadMiscellaneousValues();
|
ReadMiscellaneousValues();
|
||||||
|
ReadLibraryAppletValues();
|
||||||
}
|
}
|
||||||
ReadControlValues();
|
ReadControlValues();
|
||||||
ReadCoreValues();
|
ReadCoreValues();
|
||||||
|
@ -511,6 +520,7 @@ void Config::SaveValues() {
|
||||||
SaveNetworkValues();
|
SaveNetworkValues();
|
||||||
SaveWebServiceValues();
|
SaveWebServiceValues();
|
||||||
SaveMiscellaneousValues();
|
SaveMiscellaneousValues();
|
||||||
|
SaveLibraryAppletValues();
|
||||||
} else {
|
} else {
|
||||||
LOG_DEBUG(Config, "Saving only generic configuration values");
|
LOG_DEBUG(Config, "Saving only generic configuration values");
|
||||||
}
|
}
|
||||||
|
@ -691,6 +701,14 @@ void Config::SaveWebServiceValues() {
|
||||||
EndGroup();
|
EndGroup();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Config::SaveLibraryAppletValues() {
|
||||||
|
BeginGroup(Settings::TranslateCategory(Settings::Category::LibraryApplet));
|
||||||
|
|
||||||
|
WriteCategory(Settings::Category::LibraryApplet);
|
||||||
|
|
||||||
|
EndGroup();
|
||||||
|
}
|
||||||
|
|
||||||
bool Config::ReadBooleanSetting(const std::string& key, const std::optional<bool> default_value) {
|
bool Config::ReadBooleanSetting(const std::string& key, const std::optional<bool> default_value) {
|
||||||
std::string full_key = GetFullKey(key, false);
|
std::string full_key = GetFullKey(key, false);
|
||||||
if (!default_value.has_value()) {
|
if (!default_value.has_value()) {
|
||||||
|
|
|
@ -88,6 +88,7 @@ protected:
|
||||||
void ReadSystemValues();
|
void ReadSystemValues();
|
||||||
void ReadWebServiceValues();
|
void ReadWebServiceValues();
|
||||||
void ReadNetworkValues();
|
void ReadNetworkValues();
|
||||||
|
void ReadLibraryAppletValues();
|
||||||
|
|
||||||
// Read platform specific sections
|
// Read platform specific sections
|
||||||
virtual void ReadHidbusValues() = 0;
|
virtual void ReadHidbusValues() = 0;
|
||||||
|
@ -121,6 +122,7 @@ protected:
|
||||||
void SaveScreenshotValues();
|
void SaveScreenshotValues();
|
||||||
void SaveSystemValues();
|
void SaveSystemValues();
|
||||||
void SaveWebServiceValues();
|
void SaveWebServiceValues();
|
||||||
|
void SaveLibraryAppletValues();
|
||||||
|
|
||||||
// Save platform specific sections
|
// Save platform specific sections
|
||||||
virtual void SaveHidbusValues() = 0;
|
virtual void SaveHidbusValues() = 0;
|
||||||
|
|
|
@ -41,6 +41,9 @@ add_executable(yuzu
|
||||||
configuration/configuration_shared.cpp
|
configuration/configuration_shared.cpp
|
||||||
configuration/configuration_shared.h
|
configuration/configuration_shared.h
|
||||||
configuration/configure.ui
|
configuration/configure.ui
|
||||||
|
configuration/configure_applets.cpp
|
||||||
|
configuration/configure_applets.h
|
||||||
|
configuration/configure_applets.ui
|
||||||
configuration/configure_audio.cpp
|
configuration/configure_audio.cpp
|
||||||
configuration/configure_audio.h
|
configuration/configure_audio.h
|
||||||
configuration/configure_audio.ui
|
configuration/configure_audio.ui
|
||||||
|
|
86
src/yuzu/configuration/configure_applets.cpp
Normal file
86
src/yuzu/configuration/configure_applets.cpp
Normal file
|
@ -0,0 +1,86 @@
|
||||||
|
// SPDX-FileCopyrightText: 2024 yuzu Emulator Project
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#include "common/settings.h"
|
||||||
|
#include "core/core.h"
|
||||||
|
#include "ui_configure_applets.h"
|
||||||
|
#include "yuzu/configuration/configuration_shared.h"
|
||||||
|
#include "yuzu/configuration/configure_applets.h"
|
||||||
|
#include "yuzu/configuration/shared_widget.h"
|
||||||
|
|
||||||
|
ConfigureApplets::ConfigureApplets(Core::System& system_,
|
||||||
|
std::shared_ptr<std::vector<ConfigurationShared::Tab*>> group_,
|
||||||
|
const ConfigurationShared::Builder& builder, QWidget* parent)
|
||||||
|
: Tab(group_, parent), ui{std::make_unique<Ui::ConfigureApplets>()}, system{system_} {
|
||||||
|
ui->setupUi(this);
|
||||||
|
|
||||||
|
Setup(builder);
|
||||||
|
|
||||||
|
SetConfiguration();
|
||||||
|
}
|
||||||
|
|
||||||
|
ConfigureApplets::~ConfigureApplets() = default;
|
||||||
|
|
||||||
|
void ConfigureApplets::changeEvent(QEvent* event) {
|
||||||
|
if (event->type() == QEvent::LanguageChange) {
|
||||||
|
RetranslateUI();
|
||||||
|
}
|
||||||
|
|
||||||
|
QWidget::changeEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ConfigureApplets::RetranslateUI() {
|
||||||
|
ui->retranslateUi(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ConfigureApplets::Setup(const ConfigurationShared::Builder& builder) {
|
||||||
|
auto& library_applets_layout = *ui->group_library_applet_modes->layout();
|
||||||
|
std::map<u32, QWidget*> applets_hold{};
|
||||||
|
|
||||||
|
std::vector<Settings::BasicSetting*> settings;
|
||||||
|
auto push = [&settings](auto& list) {
|
||||||
|
for (auto setting : list) {
|
||||||
|
settings.push_back(setting);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
push(Settings::values.linkage.by_category[Settings::Category::LibraryApplet]);
|
||||||
|
|
||||||
|
for (auto setting : settings) {
|
||||||
|
ConfigurationShared::Widget* widget = builder.BuildWidget(setting, apply_funcs);
|
||||||
|
|
||||||
|
if (widget == nullptr) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (!widget->Valid()) {
|
||||||
|
widget->deleteLater();
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Untested applets
|
||||||
|
if (setting->Id() == Settings::values.data_erase_applet_mode.Id() ||
|
||||||
|
setting->Id() == Settings::values.error_applet_mode.Id() ||
|
||||||
|
setting->Id() == Settings::values.net_connect_applet_mode.Id() ||
|
||||||
|
setting->Id() == Settings::values.web_applet_mode.Id() ||
|
||||||
|
setting->Id() == Settings::values.shop_applet_mode.Id() ||
|
||||||
|
setting->Id() == Settings::values.login_share_applet_mode.Id() ||
|
||||||
|
setting->Id() == Settings::values.wifi_web_auth_applet_mode.Id() ||
|
||||||
|
setting->Id() == Settings::values.my_page_applet_mode.Id()) {
|
||||||
|
widget->setHidden(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
applets_hold.emplace(setting->Id(), widget);
|
||||||
|
}
|
||||||
|
for (const auto& [label, widget] : applets_hold) {
|
||||||
|
library_applets_layout.addWidget(widget);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void ConfigureApplets::SetConfiguration() {}
|
||||||
|
|
||||||
|
void ConfigureApplets::ApplyConfiguration() {
|
||||||
|
const bool powered_on = system.IsPoweredOn();
|
||||||
|
for (const auto& func : apply_funcs) {
|
||||||
|
func(powered_on);
|
||||||
|
}
|
||||||
|
}
|
48
src/yuzu/configuration/configure_applets.h
Normal file
48
src/yuzu/configuration/configure_applets.h
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
// SPDX-FileCopyrightText: 2024 yuzu Emulator Project
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <QWidget>
|
||||||
|
#include "yuzu/configuration/configuration_shared.h"
|
||||||
|
|
||||||
|
class QCheckBox;
|
||||||
|
class QLineEdit;
|
||||||
|
class QComboBox;
|
||||||
|
class QDateTimeEdit;
|
||||||
|
namespace Core {
|
||||||
|
class System;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace Ui {
|
||||||
|
class ConfigureApplets;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace ConfigurationShared {
|
||||||
|
class Builder;
|
||||||
|
}
|
||||||
|
|
||||||
|
class ConfigureApplets : public ConfigurationShared::Tab {
|
||||||
|
public:
|
||||||
|
explicit ConfigureApplets(Core::System& system_,
|
||||||
|
std::shared_ptr<std::vector<ConfigurationShared::Tab*>> group,
|
||||||
|
const ConfigurationShared::Builder& builder,
|
||||||
|
QWidget* parent = nullptr);
|
||||||
|
~ConfigureApplets() override;
|
||||||
|
|
||||||
|
void ApplyConfiguration() override;
|
||||||
|
void SetConfiguration() override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
void changeEvent(QEvent* event) override;
|
||||||
|
void RetranslateUI();
|
||||||
|
|
||||||
|
void Setup(const ConfigurationShared::Builder& builder);
|
||||||
|
|
||||||
|
std::vector<std::function<void(bool)>> apply_funcs{};
|
||||||
|
|
||||||
|
std::unique_ptr<Ui::ConfigureApplets> ui;
|
||||||
|
bool enabled = false;
|
||||||
|
|
||||||
|
Core::System& system;
|
||||||
|
};
|
65
src/yuzu/configuration/configure_applets.ui
Normal file
65
src/yuzu/configuration/configure_applets.ui
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<ui version="4.0">
|
||||||
|
<class>ConfigureApplets</class>
|
||||||
|
<widget class="QWidget" name="ConfigureApplets">
|
||||||
|
<property name="geometry">
|
||||||
|
<rect>
|
||||||
|
<x>0</x>
|
||||||
|
<y>0</y>
|
||||||
|
<width>605</width>
|
||||||
|
<height>300</height>
|
||||||
|
</rect>
|
||||||
|
</property>
|
||||||
|
<property name="windowTitle">
|
||||||
|
<string>Form</string>
|
||||||
|
</property>
|
||||||
|
<property name="accessibleName">
|
||||||
|
<string>Applets</string>
|
||||||
|
</property>
|
||||||
|
<layout class="QVBoxLayout" name="verticalLayout_1">
|
||||||
|
<item>
|
||||||
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
|
<item>
|
||||||
|
<widget class="QGroupBox" name="group_library_applet_modes">
|
||||||
|
<property name="title">
|
||||||
|
<string>Applet mode preference</string>
|
||||||
|
</property>
|
||||||
|
<layout class="QVBoxLayout">
|
||||||
|
<item>
|
||||||
|
<widget class="QWidget" name="applets_widget" native="true">
|
||||||
|
<layout class="QVBoxLayout" name="verticalLayout_3">
|
||||||
|
<property name="leftMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="topMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="rightMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<spacer name="verticalSpacer">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Vertical</enum>
|
||||||
|
</property>
|
||||||
|
<property name="sizeHint" stdset="0">
|
||||||
|
<size>
|
||||||
|
<width>20</width>
|
||||||
|
<height>40</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
</spacer>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
|
<resources/>
|
||||||
|
<connections/>
|
||||||
|
</ui>
|
|
@ -8,6 +8,7 @@
|
||||||
#include "core/core.h"
|
#include "core/core.h"
|
||||||
#include "ui_configure.h"
|
#include "ui_configure.h"
|
||||||
#include "vk_device_info.h"
|
#include "vk_device_info.h"
|
||||||
|
#include "yuzu/configuration/configure_applets.h"
|
||||||
#include "yuzu/configuration/configure_audio.h"
|
#include "yuzu/configuration/configure_audio.h"
|
||||||
#include "yuzu/configuration/configure_cpu.h"
|
#include "yuzu/configuration/configure_cpu.h"
|
||||||
#include "yuzu/configuration/configure_debug_tab.h"
|
#include "yuzu/configuration/configure_debug_tab.h"
|
||||||
|
@ -34,6 +35,7 @@ ConfigureDialog::ConfigureDialog(QWidget* parent, HotkeyRegistry& registry_,
|
||||||
: QDialog(parent), ui{std::make_unique<Ui::ConfigureDialog>()},
|
: QDialog(parent), ui{std::make_unique<Ui::ConfigureDialog>()},
|
||||||
registry(registry_), system{system_}, builder{std::make_unique<ConfigurationShared::Builder>(
|
registry(registry_), system{system_}, builder{std::make_unique<ConfigurationShared::Builder>(
|
||||||
this, !system_.IsPoweredOn())},
|
this, !system_.IsPoweredOn())},
|
||||||
|
applets_tab{std::make_unique<ConfigureApplets>(system_, nullptr, *builder, this)},
|
||||||
audio_tab{std::make_unique<ConfigureAudio>(system_, nullptr, *builder, this)},
|
audio_tab{std::make_unique<ConfigureAudio>(system_, nullptr, *builder, this)},
|
||||||
cpu_tab{std::make_unique<ConfigureCpu>(system_, nullptr, *builder, this)},
|
cpu_tab{std::make_unique<ConfigureCpu>(system_, nullptr, *builder, this)},
|
||||||
debug_tab_tab{std::make_unique<ConfigureDebugTab>(system_, this)},
|
debug_tab_tab{std::make_unique<ConfigureDebugTab>(system_, this)},
|
||||||
|
@ -58,6 +60,7 @@ ConfigureDialog::ConfigureDialog(QWidget* parent, HotkeyRegistry& registry_,
|
||||||
|
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
|
|
||||||
|
ui->tabWidget->addTab(applets_tab.get(), tr("Applets"));
|
||||||
ui->tabWidget->addTab(audio_tab.get(), tr("Audio"));
|
ui->tabWidget->addTab(audio_tab.get(), tr("Audio"));
|
||||||
ui->tabWidget->addTab(cpu_tab.get(), tr("CPU"));
|
ui->tabWidget->addTab(cpu_tab.get(), tr("CPU"));
|
||||||
ui->tabWidget->addTab(debug_tab_tab.get(), tr("Debug"));
|
ui->tabWidget->addTab(debug_tab_tab.get(), tr("Debug"));
|
||||||
|
@ -124,6 +127,7 @@ void ConfigureDialog::ApplyConfiguration() {
|
||||||
debug_tab_tab->ApplyConfiguration();
|
debug_tab_tab->ApplyConfiguration();
|
||||||
web_tab->ApplyConfiguration();
|
web_tab->ApplyConfiguration();
|
||||||
network_tab->ApplyConfiguration();
|
network_tab->ApplyConfiguration();
|
||||||
|
applets_tab->ApplyConfiguration();
|
||||||
system.ApplySettings();
|
system.ApplySettings();
|
||||||
Settings::LogSettings();
|
Settings::LogSettings();
|
||||||
}
|
}
|
||||||
|
@ -161,7 +165,8 @@ void ConfigureDialog::PopulateSelectionList() {
|
||||||
{{tr("General"),
|
{{tr("General"),
|
||||||
{general_tab.get(), hotkeys_tab.get(), ui_tab.get(), web_tab.get(), debug_tab_tab.get()}},
|
{general_tab.get(), hotkeys_tab.get(), ui_tab.get(), web_tab.get(), debug_tab_tab.get()}},
|
||||||
{tr("System"),
|
{tr("System"),
|
||||||
{system_tab.get(), profile_tab.get(), network_tab.get(), filesystem_tab.get()}},
|
{system_tab.get(), profile_tab.get(), network_tab.get(), filesystem_tab.get(),
|
||||||
|
applets_tab.get()}},
|
||||||
{tr("CPU"), {cpu_tab.get()}},
|
{tr("CPU"), {cpu_tab.get()}},
|
||||||
{tr("Graphics"), {graphics_tab.get(), graphics_advanced_tab.get()}},
|
{tr("Graphics"), {graphics_tab.get(), graphics_advanced_tab.get()}},
|
||||||
{tr("Audio"), {audio_tab.get()}},
|
{tr("Audio"), {audio_tab.get()}},
|
||||||
|
|
|
@ -15,6 +15,7 @@ namespace Core {
|
||||||
class System;
|
class System;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class ConfigureApplets;
|
||||||
class ConfigureAudio;
|
class ConfigureAudio;
|
||||||
class ConfigureCpu;
|
class ConfigureCpu;
|
||||||
class ConfigureDebugTab;
|
class ConfigureDebugTab;
|
||||||
|
@ -75,6 +76,7 @@ private:
|
||||||
std::unique_ptr<ConfigurationShared::Builder> builder;
|
std::unique_ptr<ConfigurationShared::Builder> builder;
|
||||||
std::vector<ConfigurationShared::Tab*> tab_group;
|
std::vector<ConfigurationShared::Tab*> tab_group;
|
||||||
|
|
||||||
|
std::unique_ptr<ConfigureApplets> applets_tab;
|
||||||
std::unique_ptr<ConfigureAudio> audio_tab;
|
std::unique_ptr<ConfigureAudio> audio_tab;
|
||||||
std::unique_ptr<ConfigureCpu> cpu_tab;
|
std::unique_ptr<ConfigureCpu> cpu_tab;
|
||||||
std::unique_ptr<ConfigureDebugTab> debug_tab_tab;
|
std::unique_ptr<ConfigureDebugTab> debug_tab_tab;
|
||||||
|
|
|
@ -26,6 +26,23 @@ std::unique_ptr<TranslationMap> InitializeTranslations(QWidget* parent) {
|
||||||
|
|
||||||
// A setting can be ignored by giving it a blank name
|
// A setting can be ignored by giving it a blank name
|
||||||
|
|
||||||
|
// Applets
|
||||||
|
INSERT(Settings, cabinet_applet_mode, tr("Amiibo editor"), QStringLiteral());
|
||||||
|
INSERT(Settings, controller_applet_mode, tr("Controller configuration"), QStringLiteral());
|
||||||
|
INSERT(Settings, data_erase_applet_mode, tr("Data erase"), QStringLiteral());
|
||||||
|
INSERT(Settings, error_applet_mode, tr("Error"), QStringLiteral());
|
||||||
|
INSERT(Settings, net_connect_applet_mode, tr("Net connect"), QStringLiteral());
|
||||||
|
INSERT(Settings, player_select_applet_mode, tr("Player select"), QStringLiteral());
|
||||||
|
INSERT(Settings, swkbd_applet_mode, tr("Software keyboard"), QStringLiteral());
|
||||||
|
INSERT(Settings, mii_edit_applet_mode, tr("Mii Edit"), QStringLiteral());
|
||||||
|
INSERT(Settings, web_applet_mode, tr("Online web"), QStringLiteral());
|
||||||
|
INSERT(Settings, shop_applet_mode, tr("Shop"), QStringLiteral());
|
||||||
|
INSERT(Settings, photo_viewer_applet_mode, tr("Photo viewer"), QStringLiteral());
|
||||||
|
INSERT(Settings, offline_web_applet_mode, tr("Offline web"), QStringLiteral());
|
||||||
|
INSERT(Settings, login_share_applet_mode, tr("Login share"), QStringLiteral());
|
||||||
|
INSERT(Settings, wifi_web_auth_applet_mode, tr("Wifi web auth"), QStringLiteral());
|
||||||
|
INSERT(Settings, my_page_applet_mode, tr("My page"), QStringLiteral());
|
||||||
|
|
||||||
// Audio
|
// Audio
|
||||||
INSERT(Settings, sink_id, tr("Output Engine:"), QStringLiteral());
|
INSERT(Settings, sink_id, tr("Output Engine:"), QStringLiteral());
|
||||||
INSERT(Settings, audio_output_device_id, tr("Output Device:"), QStringLiteral());
|
INSERT(Settings, audio_output_device_id, tr("Output Device:"), QStringLiteral());
|
||||||
|
@ -203,6 +220,11 @@ std::unique_ptr<ComboboxTranslationMap> ComboboxEnumeration(QWidget* parent) {
|
||||||
#define PAIR(ENUM, VALUE, TRANSLATION) {static_cast<u32>(Settings::ENUM::VALUE), (TRANSLATION)}
|
#define PAIR(ENUM, VALUE, TRANSLATION) {static_cast<u32>(Settings::ENUM::VALUE), (TRANSLATION)}
|
||||||
|
|
||||||
// Intentionally skipping VSyncMode to let the UI fill that one out
|
// Intentionally skipping VSyncMode to let the UI fill that one out
|
||||||
|
translations->insert({Settings::EnumMetadata<Settings::AppletMode>::Index(),
|
||||||
|
{
|
||||||
|
PAIR(AppletMode, HLE, tr("Custom frontend")),
|
||||||
|
PAIR(AppletMode, LLE, tr("Real applet")),
|
||||||
|
}});
|
||||||
|
|
||||||
translations->insert({Settings::EnumMetadata<Settings::AstcDecodeMode>::Index(),
|
translations->insert({Settings::EnumMetadata<Settings::AstcDecodeMode>::Index(),
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue