mirror of
https://github.com/ppy/osu.git
synced 2025-01-14 18:32:56 +08:00
Added PauseOverlay.TogglePaused, renamed OnPlay and similar to OnResume, made Pause and Play public, added proper testing for the visual test(pause button instead of auto-pause, logging actions), made PauseOverlay's fade duration a constant instead of statically typed
This commit is contained in:
parent
81de5a2097
commit
3ed88ea043
@ -1,11 +1,14 @@
|
||||
using System;
|
||||
using OpenTK.Graphics;
|
||||
using osu.Framework.Logging;
|
||||
using osu.Framework.Graphics;
|
||||
using osu.Game.Overlays.Pause;
|
||||
using osu.Framework.Graphics.Containers;
|
||||
using osu.Framework.Graphics.Sprites;
|
||||
using osu.Framework.Graphics.Colour;
|
||||
using osu.Framework.GameModes.Testing;
|
||||
using osu.Framework.Graphics.UserInterface;
|
||||
|
||||
namespace osu.Desktop.VisualTests.Tests
|
||||
{
|
||||
class TestCasePauseOverlay : TestCase
|
||||
@ -27,7 +30,20 @@ namespace osu.Desktop.VisualTests.Tests
|
||||
});
|
||||
Add(pauseOverlay = new PauseOverlay());
|
||||
|
||||
pauseOverlay.ToggleVisibility();
|
||||
}
|
||||
Add(new Button
|
||||
{
Text = @"Pause",
|
||||
Anchor = Anchor.TopLeft,
|
||||
Origin = Anchor.TopLeft,
|
||||
Width = 100,
|
||||
Height = 50,
|
||||
Colour = Color4.Black,
|
||||
Action = (() => pauseOverlay.Pause())
|
||||
});
|
||||
|
||||
pauseOverlay.OnPause += (() => Logger.Log(@"Pause"));
|
||||
pauseOverlay.OnResume += (() => Logger.Log(@"Resume"));
|
||||
pauseOverlay.OnRetry += (() => Logger.Log(@"Retry"));
|
||||
pauseOverlay.OnQuit += (() => Logger.Log(@"Quit"));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -16,9 +16,10 @@ namespace osu.Game.Overlays.Pause
|
||||
public class PauseOverlay : OverlayContainer
|
||||
{
|
||||
private bool paused = false;
|
||||
private int fadeDuration = 100;
|
||||
|
||||
public event Action OnPause;
|
||||
public event Action OnPlay;
|
||||
public event Action OnResume;
|
||||
public event Action OnRetry;
|
||||
public event Action OnQuit;
|
||||
|
||||
@ -39,7 +40,7 @@ namespace osu.Game.Overlays.Pause
|
||||
Origin = Anchor.Centre,
|
||||
Anchor = Anchor.Centre,
|
||||
Position = new Vector2(0, -200),
|
||||
Action = Play
|
||||
Action = Resume
|
||||
},
|
||||
new PauseButton
|
||||
{
|
||||
@ -61,13 +62,13 @@ namespace osu.Game.Overlays.Pause
|
||||
|
||||
protected override void PopIn()
|
||||
{
|
||||
this.FadeTo(1, 100, EasingTypes.In);
|
||||
this.FadeTo(1, fadeDuration, EasingTypes.In);
|
||||
paused = true;
|
||||
}
|
||||
|
||||
protected override void PopOut()
|
||||
{
|
||||
this.FadeTo(0, 100, EasingTypes.In);
|
||||
this.FadeTo(0, fadeDuration, EasingTypes.In);
|
||||
paused = false;
|
||||
}
|
||||
|
||||
@ -76,23 +77,28 @@ namespace osu.Game.Overlays.Pause
|
||||
switch (args.Key)
|
||||
{
|
||||
case Key.Escape:
|
||||
paused = !paused;
|
||||
(paused ? (Action)Pause : Play)?.Invoke();
|
||||
TogglePaused();
|
||||
return true;
|
||||
}
|
||||
return base.OnKeyDown(state, args);
|
||||
}
|
||||
|
||||
private void Pause()
|
||||
public void Pause()
|
||||
{
|
||||
Show();
|
||||
OnPause?.Invoke();
|
||||
}
|
||||
|
||||
private void Play()
|
||||
public void Resume()
|
||||
{
|
||||
Hide();
|
||||
OnPlay?.Invoke();
|
||||
Hide();
|
||||
OnResume?.Invoke();
|
||||
}
|
||||
|
||||
public void TogglePaused()
|
||||
{
|
||||
ToggleVisibility();
|
||||
(paused ? (Action)Pause : Resume)?.Invoke();
|
||||
}
|
||||
|
||||
private void Retry()
|
||||
|
@ -101,7 +101,7 @@ namespace osu.Game.Screens.Play
|
||||
|
||||
pauseOverlay = new PauseOverlay();
|
||||
pauseOverlay.OnPause += onPause;
|
||||
pauseOverlay.OnPlay += onPlay;
|
||||
pauseOverlay.OnResume += onResume;
|
||||
pauseOverlay.OnRetry += onRetry;
|
||||
pauseOverlay.OnQuit += onQuit;
|
||||
|
||||
@ -180,7 +180,7 @@ namespace osu.Game.Screens.Play
|
||||
sourceClock.Stop();
|
||||
}
|
||||
|
||||
private void onPlay()
|
||||
private void onResume()
|
||||
{
|
||||
scoreOverlay.KeyCounter.IsCounting = true;
|
||||
sourceClock.Start();
|
||||
|
Loading…
Reference in New Issue
Block a user