1
0
mirror of https://github.com/ppy/osu.git synced 2024-12-13 05:22:54 +08:00

Unload beatmap storyboard background when no longer present

This commit is contained in:
Salman Ahmed 2023-11-08 06:37:29 +03:00
parent d4722a3988
commit bd8409219f
4 changed files with 72 additions and 6 deletions

View File

@ -1,15 +1,21 @@
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence. // Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text. // See the LICENCE file in the repository root for full licence text.
using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Diagnostics;
using System.Threading;
using osu.Framework.Allocation; using osu.Framework.Allocation;
using osu.Framework.Bindables; using osu.Framework.Bindables;
using osu.Framework.Extensions.ObjectExtensions;
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Containers;
using osu.Framework.Threading;
using osu.Framework.Timing; using osu.Framework.Timing;
using osu.Game.Beatmaps; using osu.Game.Beatmaps;
using osu.Game.Overlays; using osu.Game.Overlays;
using osu.Game.Rulesets.Mods; using osu.Game.Rulesets.Mods;
using osu.Game.Screens;
using osu.Game.Storyboards.Drawables; using osu.Game.Storyboards.Drawables;
namespace osu.Game.Graphics.Backgrounds namespace osu.Game.Graphics.Backgrounds
@ -18,6 +24,10 @@ namespace osu.Game.Graphics.Backgrounds
{ {
private readonly InterpolatingFramedClock storyboardClock; private readonly InterpolatingFramedClock storyboardClock;
private AudioContainer storyboardContainer = null!;
private DrawableStoryboard? drawableStoryboard;
private CancellationTokenSource? loadCancellationSource = new CancellationTokenSource();
[Resolved(CanBeNull = true)] [Resolved(CanBeNull = true)]
private MusicController? musicController { get; set; } private MusicController? musicController { get; set; }
@ -33,18 +43,48 @@ namespace osu.Game.Graphics.Backgrounds
[BackgroundDependencyLoader] [BackgroundDependencyLoader]
private void load() private void load()
{ {
AddInternal(storyboardContainer = new AudioContainer
{
RelativeSizeAxes = Axes.Both,
Volume = { Value = 0 },
});
LoadStoryboard();
}
public void LoadStoryboard()
{
Debug.Assert(drawableStoryboard == null);
if (!Beatmap.Storyboard.HasDrawable) if (!Beatmap.Storyboard.HasDrawable)
return; return;
if (Beatmap.Storyboard.ReplacesBackground) if (Beatmap.Storyboard.ReplacesBackground)
Sprite.Alpha = 0; Sprite.Alpha = 0;
LoadComponentAsync(new AudioContainer LoadComponentAsync(drawableStoryboard = new DrawableStoryboard(Beatmap.Storyboard, mods.Value)
{ {
RelativeSizeAxes = Axes.Both, Clock = storyboardClock
Volume = { Value = 0 }, }, s =>
Child = new DrawableStoryboard(Beatmap.Storyboard, mods.Value) { Clock = storyboardClock } {
}, AddInternal); storyboardContainer.FadeInFromZero(BackgroundScreen.TRANSITION_LENGTH, Easing.OutQuint);
storyboardContainer.Add(s);
}, (loadCancellationSource = new CancellationTokenSource()).Token);
}
public void UnloadStoryboard(Action<DrawableStoryboard> scheduleStoryboardRemoval)
{
Debug.Assert(drawableStoryboard != null);
loadCancellationSource.AsNonNull().Cancel();
loadCancellationSource = null;
DrawableStoryboard s = drawableStoryboard;
storyboardContainer.FadeOut(BackgroundScreen.TRANSITION_LENGTH, Easing.OutQuint);
scheduleStoryboardRemoval(s);
drawableStoryboard = null;
} }
protected override void LoadComplete() protected override void LoadComplete()

View File

@ -13,7 +13,8 @@ namespace osu.Game.Screens
{ {
public abstract partial class BackgroundScreen : Screen, IEquatable<BackgroundScreen> public abstract partial class BackgroundScreen : Screen, IEquatable<BackgroundScreen>
{ {
protected const float TRANSITION_LENGTH = 500; public const float TRANSITION_LENGTH = 500;
private const float x_movement_amount = 50; private const float x_movement_amount = 50;
private readonly bool animateOnEnter; private readonly bool animateOnEnter;

View File

@ -4,6 +4,7 @@
using System.Collections.Generic; using System.Collections.Generic;
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Framework.Screens; using osu.Framework.Screens;
using osu.Game.Storyboards.Drawables;
namespace osu.Game.Screens namespace osu.Game.Screens
{ {
@ -33,5 +34,7 @@ namespace osu.Game.Screens
base.Push(screen); base.Push(screen);
return true; return true;
} }
public void ScheduleStoryboardDisposal(DrawableStoryboard storyboard) => Scheduler.AddDelayed(storyboard.RemoveAndDisposeImmediately, BackgroundScreen.TRANSITION_LENGTH);
} }
} }

View File

@ -3,11 +3,14 @@
#nullable disable #nullable disable
using System.Diagnostics;
using System.Threading; using System.Threading;
using JetBrains.Annotations;
using osu.Framework.Allocation; using osu.Framework.Allocation;
using osu.Framework.Bindables; using osu.Framework.Bindables;
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Framework.Logging; using osu.Framework.Logging;
using osu.Framework.Screens;
using osu.Framework.Threading; using osu.Framework.Threading;
using osu.Framework.Utils; using osu.Framework.Utils;
using osu.Game.Beatmaps; using osu.Game.Beatmaps;
@ -71,6 +74,25 @@ namespace osu.Game.Screens.Backgrounds
void next() => Next(); void next() => Next();
} }
public override void OnSuspending(ScreenTransitionEvent e)
{
var backgroundScreenStack = Parent as BackgroundScreenStack;
Debug.Assert(backgroundScreenStack != null);
if (background is BeatmapBackgroundWithStoryboard storyboardBackground)
storyboardBackground.UnloadStoryboard(backgroundScreenStack.ScheduleStoryboardDisposal);
base.OnSuspending(e);
}
public override void OnResuming(ScreenTransitionEvent e)
{
if (background is BeatmapBackgroundWithStoryboard storyboardBackground)
storyboardBackground.LoadStoryboard();
base.OnResuming(e);
}
private ScheduledDelegate nextTask; private ScheduledDelegate nextTask;
private CancellationTokenSource cancellationTokenSource; private CancellationTokenSource cancellationTokenSource;