mirror of
https://github.com/ppy/osu.git
synced 2025-01-06 09:42:55 +08:00
Add dummy SongSelectV2
screen to house new footer buttons (and new components going forward)
This commit is contained in:
parent
2b5818a4d7
commit
8b285f5b1e
204
osu.Game.Tests/Visual/SongSelect/TestSceneSongSelectV2.cs
Normal file
204
osu.Game.Tests/Visual/SongSelect/TestSceneSongSelectV2.cs
Normal file
@ -0,0 +1,204 @@
|
|||||||
|
// 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.
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using NUnit.Framework;
|
||||||
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Graphics.Cursor;
|
||||||
|
using osu.Framework.Screens;
|
||||||
|
using osu.Framework.Testing;
|
||||||
|
using osu.Game.Overlays.Mods;
|
||||||
|
using osu.Game.Rulesets.Mods;
|
||||||
|
using osu.Game.Rulesets.Osu.Mods;
|
||||||
|
using osu.Game.Screens;
|
||||||
|
using osu.Game.Screens.Footer;
|
||||||
|
using osu.Game.Screens.Menu;
|
||||||
|
using osu.Game.Screens.SelectV2;
|
||||||
|
using osu.Game.Screens.SelectV2.Footer;
|
||||||
|
using osuTK.Input;
|
||||||
|
|
||||||
|
namespace osu.Game.Tests.Visual.SongSelect
|
||||||
|
{
|
||||||
|
public partial class TestSceneSongSelectV2 : ScreenTestScene
|
||||||
|
{
|
||||||
|
[Cached]
|
||||||
|
private readonly ScreenFooter screenScreenFooter;
|
||||||
|
|
||||||
|
[Cached]
|
||||||
|
private readonly OsuLogo logo;
|
||||||
|
|
||||||
|
public TestSceneSongSelectV2()
|
||||||
|
{
|
||||||
|
Children = new Drawable[]
|
||||||
|
{
|
||||||
|
new PopoverContainer
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
|
Child = screenScreenFooter = new ScreenFooter
|
||||||
|
{
|
||||||
|
OnBack = () => Stack.CurrentScreen.Exit(),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
logo = new OsuLogo
|
||||||
|
{
|
||||||
|
Alpha = 0f,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void LoadComplete()
|
||||||
|
{
|
||||||
|
base.LoadComplete();
|
||||||
|
|
||||||
|
Stack.ScreenPushed += updateFooter;
|
||||||
|
Stack.ScreenExited += updateFooter;
|
||||||
|
}
|
||||||
|
|
||||||
|
[SetUpSteps]
|
||||||
|
public override void SetUpSteps()
|
||||||
|
{
|
||||||
|
base.SetUpSteps();
|
||||||
|
|
||||||
|
AddStep("load screen", () => Stack.Push(new SongSelectV2()));
|
||||||
|
AddUntilStep("wait for load", () => Stack.CurrentScreen is SongSelectV2 songSelect && songSelect.IsLoaded);
|
||||||
|
}
|
||||||
|
|
||||||
|
#region Footer
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestMods()
|
||||||
|
{
|
||||||
|
AddStep("one mod", () => SelectedMods.Value = new List<Mod> { new OsuModHidden() });
|
||||||
|
AddStep("two mods", () => SelectedMods.Value = new List<Mod> { new OsuModHidden(), new OsuModHardRock() });
|
||||||
|
AddStep("three mods", () => SelectedMods.Value = new List<Mod> { new OsuModHidden(), new OsuModHardRock(), new OsuModDoubleTime() });
|
||||||
|
AddStep("four mods", () => SelectedMods.Value = new List<Mod> { new OsuModHidden(), new OsuModHardRock(), new OsuModDoubleTime(), new OsuModClassic() });
|
||||||
|
AddStep("five mods", () => SelectedMods.Value = new List<Mod> { new OsuModHidden(), new OsuModHardRock(), new OsuModDoubleTime(), new OsuModClassic(), new OsuModDifficultyAdjust() });
|
||||||
|
|
||||||
|
AddStep("modified", () => SelectedMods.Value = new List<Mod> { new OsuModDoubleTime { SpeedChange = { Value = 1.2 } } });
|
||||||
|
AddStep("modified + one", () => SelectedMods.Value = new List<Mod> { new OsuModHidden(), new OsuModDoubleTime { SpeedChange = { Value = 1.2 } } });
|
||||||
|
AddStep("modified + two", () => SelectedMods.Value = new List<Mod> { new OsuModHidden(), new OsuModHardRock(), new OsuModDoubleTime { SpeedChange = { Value = 1.2 } } });
|
||||||
|
AddStep("modified + three", () => SelectedMods.Value = new List<Mod> { new OsuModHidden(), new OsuModHardRock(), new OsuModClassic(), new OsuModDoubleTime { SpeedChange = { Value = 1.2 } } });
|
||||||
|
AddStep("modified + four", () => SelectedMods.Value = new List<Mod> { new OsuModHidden(), new OsuModHardRock(), new OsuModClassic(), new OsuModDifficultyAdjust(), new OsuModDoubleTime { SpeedChange = { Value = 1.2 } } });
|
||||||
|
|
||||||
|
AddStep("clear mods", () => SelectedMods.Value = Array.Empty<Mod>());
|
||||||
|
AddWaitStep("wait", 3);
|
||||||
|
AddStep("one mod", () => SelectedMods.Value = new List<Mod> { new OsuModHidden() });
|
||||||
|
|
||||||
|
AddStep("clear mods", () => SelectedMods.Value = Array.Empty<Mod>());
|
||||||
|
AddWaitStep("wait", 3);
|
||||||
|
AddStep("five mods", () => SelectedMods.Value = new List<Mod> { new OsuModHidden(), new OsuModHardRock(), new OsuModDoubleTime(), new OsuModClassic(), new OsuModDifficultyAdjust() });
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestShowOptions()
|
||||||
|
{
|
||||||
|
AddStep("enable options", () =>
|
||||||
|
{
|
||||||
|
var optionsButton = this.ChildrenOfType<ScreenFooterButton>().Last();
|
||||||
|
|
||||||
|
optionsButton.Enabled.Value = true;
|
||||||
|
optionsButton.TriggerClick();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestState()
|
||||||
|
{
|
||||||
|
AddToggleStep("set options enabled state", state => this.ChildrenOfType<ScreenFooterButton>().Last().Enabled.Value = state);
|
||||||
|
}
|
||||||
|
|
||||||
|
// add these test cases when functionality is implemented.
|
||||||
|
// [Test]
|
||||||
|
// public void TestFooterRandom()
|
||||||
|
// {
|
||||||
|
// AddStep("press F2", () => InputManager.Key(Key.F2));
|
||||||
|
// AddAssert("next random invoked", () => nextRandomCalled && !previousRandomCalled);
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// [Test]
|
||||||
|
// public void TestFooterRandomViaMouse()
|
||||||
|
// {
|
||||||
|
// AddStep("click button", () =>
|
||||||
|
// {
|
||||||
|
// InputManager.MoveMouseTo(randomButton);
|
||||||
|
// InputManager.Click(MouseButton.Left);
|
||||||
|
// });
|
||||||
|
// AddAssert("next random invoked", () => nextRandomCalled && !previousRandomCalled);
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// [Test]
|
||||||
|
// public void TestFooterRewind()
|
||||||
|
// {
|
||||||
|
// AddStep("press Shift+F2", () =>
|
||||||
|
// {
|
||||||
|
// InputManager.PressKey(Key.LShift);
|
||||||
|
// InputManager.PressKey(Key.F2);
|
||||||
|
// InputManager.ReleaseKey(Key.F2);
|
||||||
|
// InputManager.ReleaseKey(Key.LShift);
|
||||||
|
// });
|
||||||
|
// AddAssert("previous random invoked", () => previousRandomCalled && !nextRandomCalled);
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// [Test]
|
||||||
|
// public void TestFooterRewindViaShiftMouseLeft()
|
||||||
|
// {
|
||||||
|
// AddStep("shift + click button", () =>
|
||||||
|
// {
|
||||||
|
// InputManager.PressKey(Key.LShift);
|
||||||
|
// InputManager.MoveMouseTo(randomButton);
|
||||||
|
// InputManager.Click(MouseButton.Left);
|
||||||
|
// InputManager.ReleaseKey(Key.LShift);
|
||||||
|
// });
|
||||||
|
// AddAssert("previous random invoked", () => previousRandomCalled && !nextRandomCalled);
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// [Test]
|
||||||
|
// public void TestFooterRewindViaMouseRight()
|
||||||
|
// {
|
||||||
|
// AddStep("right click button", () =>
|
||||||
|
// {
|
||||||
|
// InputManager.MoveMouseTo(randomButton);
|
||||||
|
// InputManager.Click(MouseButton.Right);
|
||||||
|
// });
|
||||||
|
// AddAssert("previous random invoked", () => previousRandomCalled && !nextRandomCalled);
|
||||||
|
// }
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestOverlayPresent()
|
||||||
|
{
|
||||||
|
AddStep("Press F1", () =>
|
||||||
|
{
|
||||||
|
InputManager.MoveMouseTo(this.ChildrenOfType<ScreenFooterButtonMods>().Single());
|
||||||
|
InputManager.Click(MouseButton.Left);
|
||||||
|
});
|
||||||
|
AddAssert("Overlay visible", () => this.ChildrenOfType<ModSelectOverlay>().Single().State.Value == Visibility.Visible);
|
||||||
|
AddStep("Hide", () => this.ChildrenOfType<ModSelectOverlay>().Single().Hide());
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
protected override void Update()
|
||||||
|
{
|
||||||
|
base.Update();
|
||||||
|
Stack.Padding = new MarginPadding { Bottom = screenScreenFooter.DrawHeight - screenScreenFooter.Y };
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateFooter(IScreen? _, IScreen? newScreen)
|
||||||
|
{
|
||||||
|
if (newScreen is IOsuScreen osuScreen && osuScreen.ShowFooter)
|
||||||
|
{
|
||||||
|
screenScreenFooter.Show();
|
||||||
|
screenScreenFooter.SetButtons(osuScreen.CreateFooterButtons());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
screenScreenFooter.Hide();
|
||||||
|
screenScreenFooter.SetButtons(Array.Empty<ScreenFooterButton>());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,33 @@
|
|||||||
|
// 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.
|
||||||
|
|
||||||
|
using System.Linq;
|
||||||
|
using NUnit.Framework;
|
||||||
|
using osu.Framework.Testing;
|
||||||
|
using osu.Game.Screens.Menu;
|
||||||
|
using osu.Game.Screens.SelectV2;
|
||||||
|
using osuTK.Input;
|
||||||
|
|
||||||
|
namespace osu.Game.Tests.Visual.SongSelect
|
||||||
|
{
|
||||||
|
public partial class TestSceneSongSelectV2Navigation : OsuGameTestScene
|
||||||
|
{
|
||||||
|
public override void SetUpSteps()
|
||||||
|
{
|
||||||
|
base.SetUpSteps();
|
||||||
|
AddStep("press enter", () => InputManager.Key(Key.Enter));
|
||||||
|
AddWaitStep("wait", 5);
|
||||||
|
PushAndConfirm(() => new SongSelectV2());
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestClickLogo()
|
||||||
|
{
|
||||||
|
AddStep("click", () =>
|
||||||
|
{
|
||||||
|
InputManager.MoveMouseTo(Game.ChildrenOfType<OsuLogo>().Single());
|
||||||
|
InputManager.Click(MouseButton.Left);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
145
osu.Game/Screens/SelectV2/SongSelectV2.cs
Normal file
145
osu.Game/Screens/SelectV2/SongSelectV2.cs
Normal file
@ -0,0 +1,145 @@
|
|||||||
|
// 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.
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Graphics.Cursor;
|
||||||
|
using osu.Framework.Screens;
|
||||||
|
using osu.Game.Overlays;
|
||||||
|
using osu.Game.Overlays.Mods;
|
||||||
|
using osu.Game.Screens.Footer;
|
||||||
|
using osu.Game.Screens.Menu;
|
||||||
|
using osu.Game.Screens.Play;
|
||||||
|
using osu.Game.Screens.SelectV2.Footer;
|
||||||
|
|
||||||
|
namespace osu.Game.Screens.SelectV2
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// This screen is intended to house all components introduced in the new song select design to add transitions and examine the overall look.
|
||||||
|
/// This will be gradually built upon and ultimately replace <see cref="Select.SongSelect"/> once everything is in place.
|
||||||
|
/// </summary>
|
||||||
|
public partial class SongSelectV2 : OsuScreen
|
||||||
|
{
|
||||||
|
private readonly ModSelectOverlay modSelectOverlay = new SoloModSelectOverlay();
|
||||||
|
|
||||||
|
[Cached]
|
||||||
|
private readonly OverlayColourProvider colourProvider = new OverlayColourProvider(OverlayColourScheme.Aquamarine);
|
||||||
|
|
||||||
|
public override bool ShowFooter => true;
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load()
|
||||||
|
{
|
||||||
|
AddRangeInternal(new Drawable[]
|
||||||
|
{
|
||||||
|
new PopoverContainer
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
|
},
|
||||||
|
modSelectOverlay,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public override IReadOnlyList<ScreenFooterButton> CreateFooterButtons() => new ScreenFooterButton[]
|
||||||
|
{
|
||||||
|
new ScreenFooterButtonMods(modSelectOverlay) { Current = Mods },
|
||||||
|
new ScreenFooterButtonRandom(),
|
||||||
|
new ScreenFooterButtonOptions(),
|
||||||
|
};
|
||||||
|
|
||||||
|
public override void OnEntering(ScreenTransitionEvent e)
|
||||||
|
{
|
||||||
|
this.FadeIn();
|
||||||
|
base.OnEntering(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void OnResuming(ScreenTransitionEvent e)
|
||||||
|
{
|
||||||
|
this.FadeIn();
|
||||||
|
base.OnResuming(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void OnSuspending(ScreenTransitionEvent e)
|
||||||
|
{
|
||||||
|
this.Delay(400).FadeOut();
|
||||||
|
base.OnSuspending(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
public override bool OnExiting(ScreenExitEvent e)
|
||||||
|
{
|
||||||
|
this.Delay(400).FadeOut();
|
||||||
|
return base.OnExiting(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
public override bool OnBackButton()
|
||||||
|
{
|
||||||
|
if (modSelectOverlay.State.Value == Visibility.Visible)
|
||||||
|
{
|
||||||
|
modSelectOverlay.Hide();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void LogoArriving(OsuLogo logo, bool resuming)
|
||||||
|
{
|
||||||
|
base.LogoArriving(logo, resuming);
|
||||||
|
|
||||||
|
if (logo.Alpha > 0.8f)
|
||||||
|
Footer?.StartTrackingLogo(logo, 400, Easing.OutQuint);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
logo.Hide();
|
||||||
|
logo.ScaleTo(0.2f);
|
||||||
|
Footer?.StartTrackingLogo(logo);
|
||||||
|
}
|
||||||
|
|
||||||
|
logo.FadeIn(240, Easing.OutQuint);
|
||||||
|
logo.ScaleTo(0.4f, 240, Easing.OutQuint);
|
||||||
|
|
||||||
|
logo.Action = () =>
|
||||||
|
{
|
||||||
|
this.Push(new PlayerLoaderV2(() => new SoloPlayer()));
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void LogoSuspending(OsuLogo logo)
|
||||||
|
{
|
||||||
|
base.LogoSuspending(logo);
|
||||||
|
Footer?.StopTrackingLogo();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void LogoExiting(OsuLogo logo)
|
||||||
|
{
|
||||||
|
base.LogoExiting(logo);
|
||||||
|
Scheduler.AddDelayed(() => Footer?.StopTrackingLogo(), 120);
|
||||||
|
logo.ScaleTo(0.2f, 120, Easing.Out);
|
||||||
|
logo.FadeOut(120, Easing.Out);
|
||||||
|
}
|
||||||
|
|
||||||
|
private partial class SoloModSelectOverlay : ModSelectOverlay
|
||||||
|
{
|
||||||
|
protected override bool ShowPresets => true;
|
||||||
|
|
||||||
|
public SoloModSelectOverlay()
|
||||||
|
: base(OverlayColourScheme.Aquamarine)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private partial class PlayerLoaderV2 : PlayerLoader
|
||||||
|
{
|
||||||
|
public override bool ShowFooter => true;
|
||||||
|
|
||||||
|
public PlayerLoaderV2(Func<Player> createPlayer)
|
||||||
|
: base(createPlayer)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user