From 5480e42cd116384d90407a44cd46bc4d5fecdb4d Mon Sep 17 00:00:00 2001 From: Stenzek Date: Sat, 2 Sep 2023 19:40:23 +1000 Subject: [PATCH] ImGuiManager: Fix changing global scale through FSUI --- src/core/host.cpp | 2 +- src/core/system.cpp | 9 ++++++-- src/util/imgui_manager.cpp | 42 ++++++++++++++++++++++++++++++-------- src/util/imgui_manager.h | 5 ++++- 4 files changed, 45 insertions(+), 13 deletions(-) diff --git a/src/core/host.cpp b/src/core/host.cpp index 3bf172f1b..2cb42922a 100644 --- a/src/core/host.cpp +++ b/src/core/host.cpp @@ -249,7 +249,7 @@ bool Host::CreateGPUDevice(RenderAPI api) return false; } - if (!ImGuiManager::Initialize(g_settings.display_osd_scale / 100.0f)) + if (!ImGuiManager::Initialize(g_settings.display_osd_scale / 100.0f, g_settings.display_show_osd_messages)) { Log_ErrorPrintf("Failed to initialize ImGuiManager."); g_gpu_device->Destroy(); diff --git a/src/core/system.cpp b/src/core/system.cpp index 99ba47393..ad05f0f2c 100644 --- a/src/core/system.cpp +++ b/src/core/system.cpp @@ -3690,8 +3690,13 @@ void System::CheckForSettingsChanges(const Settings& old_settings) PostProcessing::UpdateSettings(); } - if (g_gpu_device && g_settings.display_osd_scale != old_settings.display_osd_scale) - ImGuiManager::SetGlobalScale(g_settings.display_osd_scale / 100.0f); + if (g_gpu_device) + { + if (g_settings.display_osd_scale != old_settings.display_osd_scale) + ImGuiManager::SetGlobalScale(g_settings.display_osd_scale / 100.0f); + if (g_settings.display_show_osd_messages != old_settings.display_show_osd_messages) + ImGuiManager::SetShowOSDMessages(g_settings.display_show_osd_messages); + } bool controllers_updated = false; for (u32 i = 0; i < NUM_CONTROLLER_AND_CARD_PORTS; i++) diff --git a/src/util/imgui_manager.cpp b/src/util/imgui_manager.cpp index d0202eff2..e48c21d66 100644 --- a/src/util/imgui_manager.cpp +++ b/src/util/imgui_manager.cpp @@ -90,6 +90,8 @@ struct OSDMessage static std::deque s_osd_active_messages; static std::deque s_osd_posted_messages; static std::mutex s_osd_messages_lock; +static bool s_show_osd_messages = true; +static bool s_global_prescale_changed = false; static std::array s_software_cursors = {}; @@ -107,11 +109,24 @@ void ImGuiManager::SetFontRange(const u16* range) void ImGuiManager::SetGlobalScale(float global_scale) { + if (s_global_prescale == global_scale) + return; + s_global_prescale = global_scale; - UpdateScale(); + s_global_prescale_changed = true; } -bool ImGuiManager::Initialize(float global_scale) +void ImGuiManager::SetShowOSDMessages(bool enable) +{ + if (s_show_osd_messages == enable) + return; + + s_show_osd_messages = enable; + if (!enable) + Host::ClearOSDMessages(); +} + +bool ImGuiManager::Initialize(float global_scale, bool show_osd_messages) { if (!LoadFontData()) { @@ -121,6 +136,7 @@ bool ImGuiManager::Initialize(float global_scale) s_global_prescale = global_scale; s_global_scale = std::max(g_gpu_device->GetWindowScale() * global_scale, 1.0f); + s_show_osd_messages = show_osd_messages; ImGui::CreateContext(); @@ -181,10 +197,11 @@ void ImGuiManager::WindowResized() ImGui::GetIO().DisplaySize = ImVec2(static_cast(new_width), static_cast(new_height)); - UpdateScale(); - // restart imgui frame on the new window size to pick it up, otherwise we draw to the old size ImGui::EndFrame(); + + UpdateScale(); + NewFrame(); } @@ -196,9 +213,6 @@ void ImGuiManager::UpdateScale() if (scale == s_global_scale && (!HasFullscreenFonts() || !ImGuiFullscreen::UpdateLayoutScale())) return; - // This is assumed to be called mid-frame. - ImGui::EndFrame(); - s_global_scale = scale; ImGui::GetStyle() = ImGuiStyle(); @@ -211,8 +225,6 @@ void ImGuiManager::UpdateScale() if (!g_gpu_device->UpdateImGuiFontTexture()) Panic("Failed to recreate font texture after scale+resize"); - - NewFrame(); } void ImGuiManager::NewFrame() @@ -220,6 +232,12 @@ void ImGuiManager::NewFrame() ImGuiIO& io = ImGui::GetIO(); io.DeltaTime = static_cast(s_last_render_time.GetTimeSecondsAndReset()); + if (s_global_prescale_changed) + { + s_global_prescale_changed = false; + UpdateScale(); + } + ImGui::NewFrame(); // Disable nav input on the implicit (Debug##Default) window. Otherwise we end up requesting keyboard @@ -587,6 +605,9 @@ void Host::AddKeyedOSDMessage(std::string key, std::string message, float durati else Log_InfoPrintf("OSD: %s", message.c_str()); + if (!s_show_osd_messages) + return; + OSDMessage msg; msg.key = std::move(key); msg.text = std::move(message); @@ -622,6 +643,9 @@ void Host::AddKeyedFormattedOSDMessage(std::string key, float duration, const ch void Host::RemoveKeyedOSDMessage(std::string key) { + if (!s_show_osd_messages) + return; + OSDMessage msg; msg.key = std::move(key); msg.duration = 0.0f; diff --git a/src/util/imgui_manager.h b/src/util/imgui_manager.h index 5cd822508..b3c137ef2 100644 --- a/src/util/imgui_manager.h +++ b/src/util/imgui_manager.h @@ -21,8 +21,11 @@ void SetFontRange(const u16* range); /// Changes the global scale. void SetGlobalScale(float global_scale); +/// Changes whether OSD messages are silently dropped. +void SetShowOSDMessages(bool enable); + /// Initializes ImGui, creates fonts, etc. -bool Initialize(float global_scale); +bool Initialize(float global_scale, bool show_osd_messages); /// Frees all ImGui resources. void Shutdown();