From 93b2d9741e6097ccaa4de90293036ae6b99e31a8 Mon Sep 17 00:00:00 2001 From: Mark Wilson <23439518+wlsnmrk@users.noreply.github.com> Date: Thu, 28 Dec 2023 13:33:45 -0700 Subject: [PATCH] fix: prevent doubled music audio Prevent doubled game music after player death and restart, by stopping the game-music player before fading it in. Prevent doubled menu music after rapidly starting the game and returning to the menu, by stopping the menu-music player before fading it in. --- src/in_game_audio/InGameAudio.cs | 2 ++ test/src/in_game_audio/InGameAudioTest.cs | 2 ++ 2 files changed, 4 insertions(+) diff --git a/src/in_game_audio/InGameAudio.cs b/src/in_game_audio/InGameAudio.cs index 7612e94..f7e7966 100644 --- a/src/in_game_audio/InGameAudio.cs +++ b/src/in_game_audio/InGameAudio.cs @@ -72,11 +72,13 @@ public void OnExitTree() { public void StartMainMenuMusic() { GameMusic.FadeOut(); + MainMenuMusic.Stop(); MainMenuMusic.FadeIn(); } public void StartGameMusic() { MainMenuMusic.FadeOut(); + GameMusic.Stop(); GameMusic.FadeIn(); } } diff --git a/test/src/in_game_audio/InGameAudioTest.cs b/test/src/in_game_audio/InGameAudioTest.cs index 85a1415..af529e9 100644 --- a/test/src/in_game_audio/InGameAudioTest.cs +++ b/test/src/in_game_audio/InGameAudioTest.cs @@ -70,6 +70,7 @@ public void OnExitTree() { public void PlaysMainMenuMusic() { _logic.Setup(logic => logic.Start()); _gameMusic.Setup(music => music.FadeOut()); + _mainMenuMusic.Setup(music => music.Stop()); _mainMenuMusic.Setup(music => music.FadeIn()); _audio.OnResolved(); @@ -84,6 +85,7 @@ public void PlaysMainMenuMusic() { [Test] public void PlaysGameMusic() { _logic.Setup(logic => logic.Start()); + _gameMusic.Setup(music => music.Stop()); _gameMusic.Setup(music => music.FadeIn()); _mainMenuMusic.Setup(music => music.FadeOut());