From 53ec2729e01d19b05cfd468ece0006996af75a97 Mon Sep 17 00:00:00 2001 From: Zangetsu38 Date: Thu, 24 Oct 2024 00:55:32 +0200 Subject: [PATCH] gui/themes: Add support of BGM. config & gui/settings dialog: Add control of bgm volume. --- vita3k/config/include/config/config.h | 1 + vita3k/gui/CMakeLists.txt | 4 +- vita3k/gui/include/gui/functions.h | 4 + vita3k/gui/src/gui.cpp | 2 +- vita3k/gui/src/home_screen.cpp | 3 + vita3k/gui/src/settings_dialog.cpp | 5 +- vita3k/gui/src/themes.cpp | 247 +++++++++++++++++++++++++- vita3k/interface.cpp | 2 + vita3k/main.cpp | 1 + 9 files changed, 264 insertions(+), 5 deletions(-) diff --git a/vita3k/config/include/config/config.h b/vita3k/config/include/config/config.h index 4b74d07c78..f99a59a794 100644 --- a/vita3k/config/include/config/config.h +++ b/vita3k/config/include/config/config.h @@ -89,6 +89,7 @@ enum ScreenshotFormat { code(std::string, "audio-backend", "SDL", audio_backend) \ code(int, "audio-volume", 100, audio_volume) \ code(bool, "ngs-enable", true, ngs_enable) \ + code(int, "bgm-volume", 100, bgm_volume) \ code(int, "sys-button", static_cast(SCE_SYSTEM_PARAM_ENTER_BUTTON_CROSS), sys_button) \ code(int, "sys-lang", static_cast(SCE_SYSTEM_PARAM_LANG_ENGLISH_US), sys_lang) \ code(int, "sys-date-format", (int)SCE_SYSTEM_PARAM_DATE_FORMAT_MMDDYYYY, sys_date_format) \ diff --git a/vita3k/gui/CMakeLists.txt b/vita3k/gui/CMakeLists.txt index f9553f1b1c..5d30793a39 100644 --- a/vita3k/gui/CMakeLists.txt +++ b/vita3k/gui/CMakeLists.txt @@ -50,6 +50,6 @@ add_library( ) target_include_directories(gui PUBLIC include ${CMAKE_SOURCE_DIR}/vita3k) -target_link_libraries(gui PUBLIC app compat config dialog emuenv ime imgui lang regmgr np) -target_link_libraries(gui PRIVATE audio cppcommon ctrl kernel miniz psvpfsparser pugixml::pugixml stb renderer packages sdl2 touch vkutil host::dialog concurrentqueue) +target_link_libraries(gui PUBLIC app codec compat config dialog emuenv ime imgui lang regmgr np) +target_link_libraries(gui PRIVATE audio cubeb cppcommon ctrl kernel miniz psvpfsparser pugixml::pugixml stb renderer packages sdl2 touch vkutil host::dialog concurrentqueue) target_link_libraries(gui PUBLIC tracy) diff --git a/vita3k/gui/include/gui/functions.h b/vita3k/gui/include/gui/functions.h index 0cb5576e80..e7e7f47d4d 100644 --- a/vita3k/gui/include/gui/functions.h +++ b/vita3k/gui/include/gui/functions.h @@ -69,6 +69,7 @@ void init(GuiState &gui, EmuEnvState &emuenv); void init_app_background(GuiState &gui, EmuEnvState &emuenv, const std::string &app_path); void init_app_icon(GuiState &gui, EmuEnvState &emuenv, const std::string &app_path); void init_apps_icon(GuiState &gui, EmuEnvState &emuenv, const std::vector &app_list); +void init_bgm_player(const float vol); void init_config(GuiState &gui, EmuEnvState &emuenv, const std::string &app_path); void init_content_manager(GuiState &gui, EmuEnvState &emuenv); vfs::FileBuffer init_default_icon(GuiState &gui, EmuEnvState &emuenv); @@ -103,6 +104,9 @@ void save_apps_cache(GuiState &gui, EmuEnvState &emuenv); void save_user(GuiState &gui, EmuEnvState &emuenv, const std::string &user_id); void set_config(GuiState &gui, EmuEnvState &emuenv, const std::string &app_path); void set_shaders_compiled_display(GuiState &gui, EmuEnvState &emuenv); +void set_bgm_volume(const float volume); +void stop_bgm_theme(); +void switch_bgm_state(const bool pause); void update_app(GuiState &gui, EmuEnvState &emuenv, const std::string &app_path); void update_last_time_app_used(GuiState &gui, EmuEnvState &emuenv, const std::string &app); void update_live_area_current_open_apps_list(GuiState &gui, EmuEnvState &emuenv, const std::string &app_path); diff --git a/vita3k/gui/src/gui.cpp b/vita3k/gui/src/gui.cpp index 0045137355..681723125c 100644 --- a/vita3k/gui/src/gui.cpp +++ b/vita3k/gui/src/gui.cpp @@ -524,9 +524,9 @@ void init_home(GuiState &gui, EmuEnvState &emuenv) { } init_app_background(gui, emuenv, "NPXS10015"); + init_bgm_player(emuenv.cfg.bgm_volume / 100.f); regmgr::init_regmgr(emuenv.regmgr, emuenv.pref_path); - const auto is_cmd = emuenv.cfg.run_app_path || emuenv.cfg.content_path; if (!gui.users.empty() && gui.users.contains(emuenv.cfg.user_id) && (is_cmd || emuenv.cfg.auto_user_login)) { init_user(gui, emuenv, emuenv.cfg.user_id); diff --git a/vita3k/gui/src/home_screen.cpp b/vita3k/gui/src/home_screen.cpp index e169588ec7..0bbef43561 100644 --- a/vita3k/gui/src/home_screen.cpp +++ b/vita3k/gui/src/home_screen.cpp @@ -144,6 +144,7 @@ void pre_load_app(GuiState &gui, EmuEnvState &emuenv, bool live_area, const std: } void pre_run_app(GuiState &gui, EmuEnvState &emuenv, const std::string &app_path) { + switch_bgm_state(true); const auto is_sys = app_path.starts_with("NPXS") && (app_path != "NPXS10007"); if (!is_sys) { if (emuenv.io.app_path != app_path) { @@ -213,6 +214,7 @@ void close_system_app(GuiState &gui, EmuEnvState &emuenv) { gui.vita_area.information_bar = true; gui.vita_area.home_screen = true; } + switch_bgm_state(false); } void close_and_run_new_app(GuiState &gui, EmuEnvState &emuenv, const std::string &app_path) { @@ -544,6 +546,7 @@ void draw_home_screen(GuiState &gui, EmuEnvState &emuenv) { gui.vita_area.home_screen = false; gui.vita_area.information_bar = true; gui.vita_area.start_screen = true; + switch_bgm_state(true); } } } diff --git a/vita3k/gui/src/settings_dialog.cpp b/vita3k/gui/src/settings_dialog.cpp index 9c6550e3b5..7a25016a4d 100644 --- a/vita3k/gui/src/settings_dialog.cpp +++ b/vita3k/gui/src/settings_dialog.cpp @@ -380,6 +380,7 @@ static void save_config(GuiState &gui, EmuEnvState &emuenv) { app::update_viewport(emuenv); } + set_bgm_volume(emuenv.cfg.bgm_volume / 100.f); config::serialize_config(emuenv.cfg, emuenv.cfg.config_path); } @@ -813,6 +814,8 @@ void draw_settings_dialog(GuiState &gui, EmuEnvState &emuenv) { ImGui::Checkbox(lang.audio["enable_ngs_support"].c_str(), &config.ngs_enable); SetTooltipEx(lang.audio["ngs_description"].c_str()); ImGui::Spacing(); + ImGui::SliderInt("Bgm Volume", &emuenv.cfg.bgm_volume, 0, 100, "%d %%", ImGuiSliderFlags_AlwaysClamp); + SetTooltipEx("Adjusts the background music volume percentage of the theme"); ImGui::Separator(); ImGui::Spacing(); ImGui::EndTabItem(); @@ -1065,7 +1068,7 @@ void draw_settings_dialog(GuiState &gui, EmuEnvState &emuenv) { SetTooltipEx(lang.gui["select_delay_background"].c_str()); } ImGui::Spacing(); - ImGui::SliderInt(lang.gui["delay_start"].c_str(), &emuenv.cfg.delay_start, 10, 60); + ImGui::SliderInt(lang.gui["delay_start"].c_str(), &emuenv.cfg.delay_start, 10, 240); SetTooltipEx(lang.gui["select_delay_start"].c_str()); ImGui::EndTabItem(); } else diff --git a/vita3k/gui/src/themes.cpp b/vita3k/gui/src/themes.cpp index 34f0d05a11..0bdf28822e 100644 --- a/vita3k/gui/src/themes.cpp +++ b/vita3k/gui/src/themes.cpp @@ -17,7 +17,10 @@ #include "private.h" +#include