1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-15 14:53:01 +08:00

Working on design

This commit is contained in:
DrabWeb 2017-01-27 14:18:57 -04:00
parent e115120543
commit 490feac030
2 changed files with 301 additions and 92 deletions

View File

@ -1,45 +1,217 @@
using OpenTK; using OpenTK;
using OpenTK.Graphics; using OpenTK.Graphics;
using osu.Framework.Graphics.UserInterface; using osu.Framework.Allocation;
using osu.Game.Graphics;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Transformations; using osu.Framework.Graphics.Transformations;
using osu.Framework.Graphics.Colour;
using osu.Framework.Graphics.Sprites;
using osu.Framework.Graphics.Containers;
using osu.Framework.Audio;
using osu.Framework.Audio.Sample; using osu.Framework.Audio.Sample;
using osu.Game.Graphics.Backgrounds;
namespace osu.Game.Overlays.Pause namespace osu.Game.Overlays.Pause
{ {
public class PauseButton : Button public class PauseButton : ClickableContainer
{ {
private float height = 100; private float height = 70;
private float width = 300; private float colourWidth = 0.8f;
private float expandedWidth = 350; private float colourExpandedWidth = 0.9f;
private float colourExpandTime = 500;
private float shear = 0.2f;
private float glowGradientEndAlpha = 0f;
public AudioSample sampleClick; private Color4 buttonColour;
public AudioSample sampleHover; private Color4 backgroundColour = OsuColour.Gray(34);
protected override bool OnMouseDown(Framework.Input.InputState state, Framework.Graphics.MouseDownEventArgs args) private AudioSample sampleClick;
private AudioSample sampleHover;
public PauseButtonType Type;
public string Text
{
get
{
switch (Type)
{
case PauseButtonType.Resume:
return "Continue";
case PauseButtonType.Retry:
return "Retry";
case PauseButtonType.Quit:
return "Quit to Main Menu";
default:
return "Unknown";
}
}
}
private Container backgroundContainer;
private Container colourContainer;
private Container glowContainer;
private SpriteText spriteText;
public override bool Contains(Vector2 screenSpacePos) => backgroundContainer.Contains(screenSpacePos);
protected override bool OnMouseUp(Framework.Input.InputState state, MouseUpEventArgs args)
{ {
sampleClick?.Play(); sampleClick?.Play();
return true; return true;
} }
protected override bool OnHover(Framework.Input.InputState state) protected override bool OnHover(Framework.Input.InputState state)
{ {
colourContainer.ResizeTo(new Vector2(colourExpandedWidth, 1f), colourExpandTime, EasingTypes.OutElastic);
glowContainer.FadeTo(1f, colourExpandTime, EasingTypes.Out);
sampleHover?.Play(); sampleHover?.Play();
ResizeTo(new Vector2(expandedWidth, height), 500, EasingTypes.OutElastic);
return true; return true;
} }
protected override void OnHoverLost(Framework.Input.InputState state) protected override void OnHoverLost(Framework.Input.InputState state)
{ {
ResizeTo(new Vector2(width, height), 500, EasingTypes.OutElastic); colourContainer.ResizeTo(new Vector2(colourWidth, 1f), colourExpandTime, EasingTypes.OutElastic);
glowContainer.FadeTo(0f, colourExpandTime, EasingTypes.Out);
} }
public PauseButton() [BackgroundDependencyLoader]
private void load(AudioManager audio, OsuColour colours)
{ {
Size = new Vector2(width, height); switch (Type)
Colour = Color4.Black; {
Shear = new Vector2(0.1f, 0); case PauseButtonType.Resume:
} buttonColour = colours.Green;
} sampleClick = audio.Sample.Get(@"Menu/menuback");
} break;
case PauseButtonType.Retry:
buttonColour = colours.YellowDark;
sampleClick = audio.Sample.Get(@"Menu/menu-play-click");
break;
case PauseButtonType.Quit:
// For whatever reason the red from the mockup is not in the osu! palette
buttonColour = new Color4(170, 27, 39, 255);
sampleClick = audio.Sample.Get(@"Menu/menuback");
break;
}
sampleHover = audio.Sample.Get(@"Menu/menuclick");
Add(new Drawable[]
{
backgroundContainer = new Container
{
RelativeSizeAxes = Axes.Both,
Width = 1f,
Children = new Drawable[]
{
new Box
{
RelativeSizeAxes = Axes.Both,
Colour = backgroundColour,
},
}
},
glowContainer = new Container
{
RelativeSizeAxes = Axes.Both,
Width = 1f,
Alpha = 0f,
Children = new Drawable[]
{
new Box
{
RelativeSizeAxes = Axes.Both,
Origin = Anchor.TopLeft,
Anchor = Anchor.TopLeft,
Width = 0.125f,
ColourInfo = ColourInfo.GradientHorizontal(new Color4(buttonColour.R, buttonColour.G, buttonColour.B, glowGradientEndAlpha), buttonColour),
},
new Box
{
RelativeSizeAxes = Axes.Both,
Origin = Anchor.TopRight,
Anchor = Anchor.TopRight,
Width = 0.125f,
ColourInfo = ColourInfo.GradientHorizontal(buttonColour, new Color4(buttonColour.R, buttonColour.G, buttonColour.B, glowGradientEndAlpha)),
},
}
},
new Container
{
RelativeSizeAxes = Axes.X,
Height = height,
Origin = Anchor.Centre,
Anchor = Anchor.Centre,
Masking = true,
Children = new Drawable[]
{
colourContainer = new Container
{
RelativeSizeAxes = Axes.Both,
Origin = Anchor.Centre,
Anchor = Anchor.Centre,
Width = colourWidth,
Masking = true,
EdgeEffect = new EdgeEffect
{
Type = EdgeEffectType.Shadow,
Colour = Color4.Black.Opacity(0.2f),
Radius = 5,
Offset = new Vector2(0, 5),
},
Colour = buttonColour,
Shear = new Vector2(shear, 0),
Children = new Drawable[]
{
new Box
{
EdgeSmoothness = new Vector2(2, 0),
RelativeSizeAxes = Axes.Both,
},
new Triangles
{
Masking = true,
BlendingMode = BlendingMode.Additive,
RelativeSizeAxes = Axes.Both,
TriangleScale = 4,
Alpha = 0.05f,
Shear = new Vector2(-shear, 0),
},
}
},
}
},
spriteText = new SpriteText
{
Text = Text,
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
TextSize = 25,
Font = "Exo2.0-Bold",
Shadow = true,
ShadowColour = new Color4(0, 0, 0, 0.1f),
Colour = Color4.White,
},
});
}
public PauseButton()
{
Height = height;
RelativeSizeAxes = Axes.X;
}
}
public enum PauseButtonType
{
Resume,
Retry,
Quit
}
}

View File

@ -10,7 +10,8 @@ using osu.Framework.Graphics;
using osu.Framework.Graphics.Sprites; using osu.Framework.Graphics.Sprites;
using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Transformations; using osu.Framework.Graphics.Transformations;
using osu.Game.Graphics.Backgrounds;
using osu.Game.Screens.Menu;
namespace osu.Game.Overlays.Pause namespace osu.Game.Overlays.Pause
{ {
@ -25,71 +26,107 @@ namespace osu.Game.Overlays.Pause
private int fadeDuration = 100; private int fadeDuration = 100;
private double pauseCooldown = 1000; private double pauseCooldown = 1000;
private double lastActionTime = -1000; private double lastActionTime = 0;
private PauseButton resumeButton;
private PauseButton retryButton;
private PauseButton quitButton;
[BackgroundDependencyLoader] [BackgroundDependencyLoader]
private void load(AudioManager audio, OsuColour colours) private void load(OsuColour colours)
{ {
var sampleHover = audio.Sample.Get(@"Menu/menuclick");
var sampleBack = audio.Sample.Get(@"Menu/menuback");
var samplePlayClick = audio.Sample.Get(@"Menu/menu-play-click");
Children = new Drawable[] Children = new Drawable[]
{ {
new Box new Box
{ {
RelativeSizeAxes = Axes.Both, RelativeSizeAxes = Axes.Both,
Colour = Color4.Black, Colour = Color4.Black,
Alpha = 0.6f, Alpha = 0.75f,
}, },
resumeButton = new PauseButton new SpriteText
{ {
Text = @"Resume", Text = @"paused",
Origin = Anchor.BottomCentre,
Anchor = Anchor.Centre,
Position = new Vector2(0, -175),
Font = @"Exo2.0-Medium",
Spacing = new Vector2(5, 0),
TextSize = 30,
Colour = colours.Yellow,
Shadow = true,
ShadowColour = new Color4(0, 0, 0, 0.25f),
},
new SpriteText
{
Text = @"you're not going to do what i think you're going to do, ain't ya?",
Origin = Anchor.BottomCentre,
Anchor = Anchor.Centre,
Width = 100,
Position = new Vector2(0, -125),
Shadow = true,
ShadowColour = new Color4(0, 0, 0, 0.25f),
},
new SpriteText
{
Text = @"You've retried 0 times in this session",
Origin = Anchor.TopCentre,
Anchor = Anchor.Centre,
Width = 100,
Position = new Vector2(0, 175),
Shadow = true,
ShadowColour = new Color4(0, 0, 0, 0.25f),
TextSize = 18,
},
new FlowContainer
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Origin = Anchor.Centre, Origin = Anchor.Centre,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Position = new Vector2(0, -200), Position = new Vector2(0, 25),
Action = Resume, Masking = true,
}, EdgeEffect = new EdgeEffect
retryButton = new PauseButton {
{ Type = EdgeEffectType.Shadow,
Text = @"Retry", Colour = new Color4(0, 0, 0, 150),
Origin = Anchor.Centre, Radius = 50,
Anchor = Anchor.Centre, Offset = new Vector2(0, 0),
Action = Retry, },
},
quitButton = new PauseButton Children = new Drawable[]
{ {
Text = @"Quit", new PauseButton
Origin = Anchor.Centre, {
Anchor = Anchor.Centre, Type = PauseButtonType.Resume,
Position = new Vector2(0, 200), Origin = Anchor.TopCentre,
Action = Quit, Anchor = Anchor.TopCentre,
Action = Resume,
},
new PauseButton
{
Type = PauseButtonType.Retry,
Origin = Anchor.TopCentre,
Anchor = Anchor.TopCentre,
Action = Retry,
},
new PauseButton
{
Type = PauseButtonType.Quit,
Origin = Anchor.TopCentre,
Anchor = Anchor.TopCentre,
Action = Quit,
},
new Button(@"solo", @"freeplay", FontAwesome.fa_user, new Color4(102, 68, 204, 255), () => OnPause?.Invoke(), 300, Key.P),
}
}, },
}; };
resumeButton.sampleHover = sampleHover;
resumeButton.sampleClick = sampleBack;
retryButton.sampleHover = sampleHover;
retryButton.sampleClick = samplePlayClick;
quitButton.sampleHover = sampleHover;
quitButton.sampleClick = sampleBack;
} }
protected override void PopIn() protected override void PopIn()
{ {
FadeTo(1, fadeDuration, EasingTypes.In); FadeTo(1, fadeDuration, EasingTypes.In);
isPaused = true; isPaused = true;
} }
protected override void PopOut() protected override void PopOut()
{ {
FadeTo(0, fadeDuration, EasingTypes.In); FadeTo(0, fadeDuration, EasingTypes.In);
isPaused = false; isPaused = false;
} }
@ -105,48 +142,48 @@ namespace osu.Game.Overlays.Pause
} }
public void Pause() public void Pause()
{ {
if (Time.Current >= (lastActionTime + pauseCooldown)) if (Time.Current >= (lastActionTime + pauseCooldown))
{
lastActionTime = Time.Current;
Show();
OnPause?.Invoke();
}
else
{ {
isPaused = false; lastActionTime = Time.Current;
Show();
OnPause?.Invoke();
}
else
{
isPaused = false;
} }
} }
public void Resume() public void Resume()
{ {
lastActionTime = Time.Current; lastActionTime = Time.Current;
Hide(); Hide();
OnResume?.Invoke(); OnResume?.Invoke();
} }
public void TogglePaused() public void TogglePaused()
{ {
isPaused = !isPaused; isPaused = !isPaused;
(isPaused ? (Action)Pause : Resume)?.Invoke(); (isPaused ? (Action)Pause : Resume)?.Invoke();
} }
private void Retry() private void Retry()
{ {
Hide(); Hide();
OnRetry?.Invoke(); OnRetry?.Invoke();
} }
private void Quit() private void Quit()
{ {
Hide(); Hide();
OnQuit?.Invoke(); OnQuit?.Invoke();
} }
public PauseOverlay() public PauseOverlay()
{ {
RelativeSizeAxes = Axes.Both; RelativeSizeAxes = Axes.Both;
AutoSizeAxes = Axes.Both; AutoSizeAxes = Axes.Both;
Depth = -1; Depth = -1;
} }
} }