mirror of
https://github.com/osukey/osukey.git
synced 2025-08-07 00:23:59 +09:00
Merge branch 'master' into taiko-fixes
This commit is contained in:
@ -35,6 +35,8 @@ namespace osu.Game.Screens.Play
|
|||||||
|
|
||||||
public BeatmapInfo BeatmapInfo;
|
public BeatmapInfo BeatmapInfo;
|
||||||
|
|
||||||
|
public Action RestartRequested;
|
||||||
|
|
||||||
public bool IsPaused => !interpolatedSourceClock.IsRunning;
|
public bool IsPaused => !interpolatedSourceClock.IsRunning;
|
||||||
|
|
||||||
public bool HasFailed { get; private set; }
|
public bool HasFailed { get; private set; }
|
||||||
@ -246,20 +248,9 @@ namespace osu.Game.Screens.Play
|
|||||||
|
|
||||||
public void Restart()
|
public void Restart()
|
||||||
{
|
{
|
||||||
sourceClock.Stop(); // If the clock is running and Restart is called the game will lag until relaunch
|
|
||||||
|
|
||||||
var newPlayer = new Player();
|
|
||||||
|
|
||||||
ValidForResume = false;
|
ValidForResume = false;
|
||||||
|
RestartRequested?.Invoke();
|
||||||
LoadComponentAsync(newPlayer, delegate
|
Exit();
|
||||||
{
|
|
||||||
newPlayer.RestartCount = RestartCount + 1;
|
|
||||||
if (!Push(newPlayer))
|
|
||||||
{
|
|
||||||
// Error(?)
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private ScheduledDelegate onCompletionEvent;
|
private ScheduledDelegate onCompletionEvent;
|
||||||
@ -324,24 +315,23 @@ namespace osu.Game.Screens.Play
|
|||||||
protected override void OnSuspending(Screen next)
|
protected override void OnSuspending(Screen next)
|
||||||
{
|
{
|
||||||
fadeOut();
|
fadeOut();
|
||||||
|
|
||||||
base.OnSuspending(next);
|
base.OnSuspending(next);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override bool OnExiting(Screen next)
|
protected override bool OnExiting(Screen next)
|
||||||
{
|
{
|
||||||
if (HasFailed || !ValidForResume)
|
if (!HasFailed && ValidForResume)
|
||||||
return false;
|
|
||||||
|
|
||||||
if (pauseOverlay != null && !HitRenderer.HasReplayLoaded)
|
|
||||||
{
|
{
|
||||||
//pause screen override logic.
|
if (pauseOverlay != null && !HitRenderer.HasReplayLoaded)
|
||||||
if (pauseOverlay?.State == Visibility.Hidden && !canPause) return true;
|
|
||||||
|
|
||||||
if (!IsPaused) // For if the user presses escape quickly when entering the map
|
|
||||||
{
|
{
|
||||||
Pause();
|
//pause screen override logic.
|
||||||
return true;
|
if (pauseOverlay?.State == Visibility.Hidden && !canPause) return true;
|
||||||
|
|
||||||
|
if (!IsPaused) // For if the user presses escape quickly when entering the map
|
||||||
|
{
|
||||||
|
Pause();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,17 +19,25 @@ namespace osu.Game.Screens.Play
|
|||||||
{
|
{
|
||||||
public class PlayerLoader : OsuScreen
|
public class PlayerLoader : OsuScreen
|
||||||
{
|
{
|
||||||
private readonly Player player;
|
private Player player;
|
||||||
|
|
||||||
private readonly OsuLogo logo;
|
private readonly OsuLogo logo;
|
||||||
private BeatmapMetadataDisplay info;
|
private BeatmapMetadataDisplay info;
|
||||||
|
|
||||||
|
private bool showOverlays = true;
|
||||||
|
internal override bool ShowOverlays => showOverlays;
|
||||||
|
|
||||||
protected override BackgroundScreen CreateBackground() => new BackgroundScreenBeatmap(Beatmap);
|
protected override BackgroundScreen CreateBackground() => new BackgroundScreenBeatmap(Beatmap);
|
||||||
|
|
||||||
public PlayerLoader(Player player)
|
public PlayerLoader(Player player)
|
||||||
{
|
{
|
||||||
ValidForResume = false;
|
|
||||||
this.player = player;
|
this.player = player;
|
||||||
|
|
||||||
|
player.RestartRequested = () => {
|
||||||
|
showOverlays = false;
|
||||||
|
ValidForResume = true;
|
||||||
|
};
|
||||||
|
|
||||||
Children = new Drawable[]
|
Children = new Drawable[]
|
||||||
{
|
{
|
||||||
logo = new OsuLogo
|
logo = new OsuLogo
|
||||||
@ -53,6 +61,37 @@ namespace osu.Game.Screens.Play
|
|||||||
LoadComponentAsync(player);
|
LoadComponentAsync(player);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected override void OnResuming(Screen last)
|
||||||
|
{
|
||||||
|
base.OnResuming(last);
|
||||||
|
|
||||||
|
contentIn();
|
||||||
|
|
||||||
|
//we will only be resumed if the player has requested a re-run (see ValidForResume setting above)
|
||||||
|
LoadComponentAsync(player = new Player
|
||||||
|
{
|
||||||
|
RestartCount = player.RestartCount + 1,
|
||||||
|
RestartRequested = player.RestartRequested,
|
||||||
|
Beatmap = player.Beatmap,
|
||||||
|
});
|
||||||
|
|
||||||
|
Delay(400);
|
||||||
|
|
||||||
|
Schedule(pushWhenLoaded);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void contentIn()
|
||||||
|
{
|
||||||
|
Content.ScaleTo(1, 650, EasingTypes.OutQuint);
|
||||||
|
Content.FadeInFromZero(400);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void contentOut()
|
||||||
|
{
|
||||||
|
Content.ScaleTo(0.7f, 300, EasingTypes.InQuint);
|
||||||
|
Content.FadeOut(250);
|
||||||
|
}
|
||||||
|
|
||||||
protected override void OnEntering(Screen last)
|
protected override void OnEntering(Screen last)
|
||||||
{
|
{
|
||||||
base.OnEntering(last);
|
base.OnEntering(last);
|
||||||
@ -60,20 +99,27 @@ namespace osu.Game.Screens.Play
|
|||||||
Background.FadeTo(0.4f, 250);
|
Background.FadeTo(0.4f, 250);
|
||||||
|
|
||||||
Content.ScaleTo(0.7f);
|
Content.ScaleTo(0.7f);
|
||||||
Content.ScaleTo(1, 750, EasingTypes.OutQuint);
|
|
||||||
Content.FadeInFromZero(500);
|
|
||||||
|
|
||||||
Delay(1000, true);
|
contentIn();
|
||||||
|
|
||||||
|
Delay(500, true);
|
||||||
|
|
||||||
logo.MoveToOffset(new Vector2(0, -180), 500, EasingTypes.InOutExpo);
|
logo.MoveToOffset(new Vector2(0, -180), 500, EasingTypes.InOutExpo);
|
||||||
Delay(250, true);
|
Delay(250, true);
|
||||||
|
|
||||||
info.FadeIn(500);
|
info.FadeIn(500);
|
||||||
|
|
||||||
Delay(2000, true);
|
Delay(1400, true);
|
||||||
|
|
||||||
Content.ScaleTo(0.7f, 300, EasingTypes.InQuint);
|
Schedule(pushWhenLoaded);
|
||||||
Content.FadeOut(250);
|
}
|
||||||
|
|
||||||
|
private void pushWhenLoaded()
|
||||||
|
{
|
||||||
|
if (!player.IsLoaded)
|
||||||
|
Schedule(pushWhenLoaded);
|
||||||
|
|
||||||
|
contentOut();
|
||||||
|
|
||||||
Delay(250);
|
Delay(250);
|
||||||
|
|
||||||
@ -83,6 +129,12 @@ namespace osu.Game.Screens.Play
|
|||||||
|
|
||||||
if (!Push(player))
|
if (!Push(player))
|
||||||
Exit();
|
Exit();
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//By default, we want to load the player and never be returned to.
|
||||||
|
//Note that this may change if the player we load requested a re-run.
|
||||||
|
ValidForResume = false;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user