mirror of
https://github.com/ppy/osu.git
synced 2025-01-07 17:52:54 +08:00
Clear all tasks and transforms when resetting Breaks
This commit is contained in:
parent
b62f2437ac
commit
ac6c323f93
@ -5,9 +5,11 @@ using OpenTK;
|
|||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
using osu.Framework.Graphics.Shapes;
|
using osu.Framework.Graphics.Shapes;
|
||||||
|
using osu.Framework.Threading;
|
||||||
using osu.Game.Beatmaps.Timing;
|
using osu.Game.Beatmaps.Timing;
|
||||||
using osu.Game.Rulesets.Scoring;
|
using osu.Game.Rulesets.Scoring;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
namespace osu.Game.Screens.Play.BreaksOverlay
|
namespace osu.Game.Screens.Play.BreaksOverlay
|
||||||
{
|
{
|
||||||
@ -17,7 +19,21 @@ namespace osu.Game.Screens.Play.BreaksOverlay
|
|||||||
private const float remaining_time_container_max_size = 0.3f;
|
private const float remaining_time_container_max_size = 0.3f;
|
||||||
private const int vertical_margin = 25;
|
private const int vertical_margin = 25;
|
||||||
|
|
||||||
public List<BreakPeriod> Breaks;
|
private List<BreakPeriod> breaks;
|
||||||
|
public List<BreakPeriod> Breaks
|
||||||
|
{
|
||||||
|
set
|
||||||
|
{
|
||||||
|
breaks = value;
|
||||||
|
initializeBreaks();
|
||||||
|
}
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return breaks;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private readonly List<ScheduledDelegate> tasks = new List<ScheduledDelegate>();
|
||||||
|
|
||||||
private readonly bool letterboxing;
|
private readonly bool letterboxing;
|
||||||
private readonly LetterboxOverlay letterboxOverlay;
|
private readonly LetterboxOverlay letterboxOverlay;
|
||||||
@ -71,15 +87,21 @@ namespace osu.Game.Screens.Play.BreaksOverlay
|
|||||||
protected override void LoadComplete()
|
protected override void LoadComplete()
|
||||||
{
|
{
|
||||||
base.LoadComplete();
|
base.LoadComplete();
|
||||||
InitializeBreaks();
|
initializeBreaks();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void InitializeBreaks()
|
private void initializeBreaks()
|
||||||
{
|
{
|
||||||
if (Breaks == null)
|
FinishTransforms(true);
|
||||||
|
|
||||||
|
foreach (var t in tasks)
|
||||||
|
t.Cancel();
|
||||||
|
tasks.Clear();
|
||||||
|
|
||||||
|
if (breaks == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
foreach (var b in Breaks)
|
foreach (var b in breaks)
|
||||||
{
|
{
|
||||||
if (!b.HasEffect)
|
if (!b.HasEffect)
|
||||||
continue;
|
continue;
|
||||||
@ -104,7 +126,9 @@ namespace osu.Game.Screens.Play.BreaksOverlay
|
|||||||
.Then()
|
.Then()
|
||||||
.ResizeWidthTo(0, b.Duration - fade_duration);
|
.ResizeWidthTo(0, b.Duration - fade_duration);
|
||||||
|
|
||||||
Scheduler.AddDelayed(() => remainingTimeCounter.StartCounting(b.EndTime), b.StartTime - Clock.CurrentTime);
|
tasks.Add(new ScheduledDelegate(() => remainingTimeCounter.StartCounting(b.EndTime), b.StartTime));
|
||||||
|
Scheduler.Add(tasks.Last());
|
||||||
|
|
||||||
remainingTimeCounter.FadeIn(fade_duration);
|
remainingTimeCounter.FadeIn(fade_duration);
|
||||||
|
|
||||||
info.FadeIn(fade_duration);
|
info.FadeIn(fade_duration);
|
||||||
|
@ -37,8 +37,6 @@ namespace osu.Game.Tests.Visual
|
|||||||
EndTime = Clock.CurrentTime + duration,
|
EndTime = Clock.CurrentTime + duration,
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
breakOverlay.InitializeBreaks();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startMultipleBreaks()
|
private void startMultipleBreaks()
|
||||||
@ -58,8 +56,6 @@ namespace osu.Game.Tests.Visual
|
|||||||
EndTime = currentTime + 6000,
|
EndTime = currentTime + 6000,
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
breakOverlay.InitializeBreaks();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user