From 42914c3d7c68ce7ce0072e4aae1841408a3b7e8e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Henrik=20Rydg=C3=A5rd?= Date: Wed, 18 Sep 2024 15:17:20 +0200 Subject: [PATCH] Try to make Frame Advance a bit more reliable --- UI/EmuScreen.cpp | 26 ++++++++++++++++---------- UI/EmuScreen.h | 2 ++ UI/GameScreen.cpp | 4 +++- 3 files changed, 21 insertions(+), 11 deletions(-) diff --git a/UI/EmuScreen.cpp b/UI/EmuScreen.cpp index bb352c8b8111..bb4a669ebcf5 100644 --- a/UI/EmuScreen.cpp +++ b/UI/EmuScreen.cpp @@ -715,16 +715,9 @@ void EmuScreen::onVKey(int virtualKeyCode, bool down) { break; case VIRTKEY_FRAME_ADVANCE: - if (!Achievements::WarnUserIfHardcoreModeActive(false)) { - if (down) { - // If game is running, pause emulation immediately. Otherwise, advance a single frame. - if (Core_IsStepping()) { - frameStep_ = true; - Core_EnableStepping(false); - } else if (!frameStep_) { - Core_EnableStepping(true, "ui.frameAdvance", 0); - } - } + // Can't do this reliably in an async fashion, so we just set a variable. + if (down) { + doFrameAdvance_.store(true); } break; @@ -1422,6 +1415,19 @@ ScreenRenderFlags EmuScreen::render(ScreenRenderMode mode) { Core_UpdateDebugStats((DebugOverlay)g_Config.iDebugOverlay == DebugOverlay::DEBUG_STATS || g_Config.bLogFrameDrops); + if (doFrameAdvance_.exchange(false)) { + if (!Achievements::WarnUserIfHardcoreModeActive(false)) { + // If game is running, pause emulation immediately. Otherwise, advance a single frame. + if (Core_IsStepping()) { + frameStep_ = true; + Core_EnableStepping(false); + } else if (!frameStep_) { + lastNumFlips = gpuStats.numFlips; + Core_EnableStepping(true, "ui.frameAdvance", 0); + } + } + } + bool blockedExecution = Achievements::IsBlockingExecution(); uint32_t clearColor = 0; if (!blockedExecution) { diff --git a/UI/EmuScreen.h b/UI/EmuScreen.h index 77df9e381627..a80e684019ab 100644 --- a/UI/EmuScreen.h +++ b/UI/EmuScreen.h @@ -121,5 +121,7 @@ class EmuScreen : public UIScreen { std::string extraAssertInfoStr_; + std::atomic doFrameAdvance_{}; + ControlMapper controlMapper_; }; diff --git a/UI/GameScreen.cpp b/UI/GameScreen.cpp index baca52fc589e..14a71400f047 100644 --- a/UI/GameScreen.cpp +++ b/UI/GameScreen.cpp @@ -205,7 +205,9 @@ void GameScreen::CreateViews() { rightColumnItems->SetSpacing(0.0f); rightColumn->Add(rightColumnItems); - rightColumnItems->Add(new Choice(ga->T("Play")))->OnClick.Handle(this, &GameScreen::OnPlay); + if (!inGame_) { + rightColumnItems->Add(new Choice(ga->T("Play")))->OnClick.Handle(this, &GameScreen::OnPlay); + } btnGameSettings_ = rightColumnItems->Add(new Choice(ga->T("Game Settings"))); btnGameSettings_->OnClick.Handle(this, &GameScreen::OnGameSettings);