forked from eden-emu/eden
		
	general: add default configurations for applet mode
This commit is contained in:
		
							parent
							
								
									ba17a8c2b8
								
							
						
					
					
						commit
						b4b3ddf4b4
					
				
					 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,8 +92,9 @@ 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, | ||||||
|  |                                                           AppletId applet_id, | ||||||
|                                                           LibraryAppletMode mode) { |                                                           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) { | ||||||
|  | @ -117,8 +147,9 @@ 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, | ||||||
|  |                                                              AppletId applet_id, | ||||||
|                                                              LibraryAppletMode mode) { |                                                              LibraryAppletMode mode) { | ||||||
|     const auto program_id = static_cast<u64>(AppletIdToProgramId(applet_id)); |     const auto program_id = static_cast<u64>(AppletIdToProgramId(applet_id)); | ||||||
| 
 | 
 | ||||||
|  | @ -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…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Liam
						Liam