1
0
mirror of https://github.com/ppy/osu.git synced 2024-12-15 06:35:05 +08:00
osu-lazer/osu.Game/Screens/Select/PlaySongSelect.cs

117 lines
3.7 KiB
C#
Raw Normal View History

// 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.
2018-04-13 17:19:50 +08:00
using System.Linq;
using osu.Framework.Allocation;
using osu.Framework.Graphics.Sprites;
2020-03-02 18:40:32 +08:00
using osu.Framework.Input.Events;
2018-04-13 17:19:50 +08:00
using osu.Framework.Screens;
using osu.Game.Graphics;
2020-06-02 19:32:52 +08:00
using osu.Game.Overlays;
using osu.Game.Overlays.Notifications;
using osu.Game.Scoring;
2018-04-13 17:19:50 +08:00
using osu.Game.Screens.Play;
2020-03-17 16:43:16 +08:00
using osu.Game.Screens.Ranking;
using osu.Game.Users;
using osuTK.Input;
2018-04-13 17:19:50 +08:00
namespace osu.Game.Screens.Select
{
public class PlaySongSelect : SongSelect
{
private bool removeAutoModOnResume;
private OsuScreen player;
2018-04-13 17:19:50 +08:00
2020-06-02 22:01:01 +08:00
[Resolved(CanBeNull = true)]
2020-06-02 19:32:52 +08:00
private NotificationOverlay notifications { get; set; }
public override bool AllowExternalScreenChange => true;
protected override UserActivity InitialActivity => new UserActivity.ChoosingBeatmap();
[BackgroundDependencyLoader]
private void load(OsuColour colours)
2018-04-13 17:19:50 +08:00
{
2019-04-02 18:55:24 +08:00
BeatmapOptions.AddButton(@"Edit", @"beatmap", FontAwesome.Solid.PencilAlt, colours.Yellow, () =>
2018-04-13 17:19:50 +08:00
{
ValidForResume = false;
Edit();
}, Key.Number4);
2020-02-12 18:52:47 +08:00
((PlayBeatmapDetailArea)BeatmapDetails).Leaderboard.ScoreSelected += PresentScore;
2018-04-13 17:19:50 +08:00
}
protected void PresentScore(ScoreInfo score) =>
2020-05-26 16:00:41 +08:00
FinaliseSelection(score.Beatmap, score.Ruleset, () => this.Push(new SoloResultsScreen(score)));
2020-02-12 18:52:47 +08:00
protected override BeatmapDetailArea CreateBeatmapDetailArea() => new PlayBeatmapDetailArea();
2019-01-23 19:52:00 +08:00
public override void OnResuming(IScreen last)
2018-04-13 17:19:50 +08:00
{
base.OnResuming(last);
2018-04-13 17:19:50 +08:00
player = null;
if (removeAutoModOnResume)
{
var autoType = Ruleset.Value.CreateInstance().GetAutoplayMod()?.GetType();
if (autoType != null)
ModSelect.DeselectTypes(new[] { autoType }, true);
2018-04-13 17:19:50 +08:00
removeAutoModOnResume = false;
}
}
2020-03-02 18:40:32 +08:00
protected override bool OnKeyDown(KeyDownEvent e)
{
switch (e.Key)
{
case Key.Enter:
case Key.KeypadEnter:
2020-03-02 18:40:32 +08:00
// this is a special hard-coded case; we can't rely on OnPressed (of SongSelect) as GlobalActionContainer is
// matching with exact modifier consideration (so Ctrl+Enter would be ignored).
FinaliseSelection();
return true;
}
return base.OnKeyDown(e);
}
protected override bool OnStart()
2018-04-13 17:19:50 +08:00
{
if (player != null) return false;
// Ctrl+Enter should start map with autoplay enabled.
if (GetContainingInputManager().CurrentState?.Keyboard.ControlPressed == true)
{
var auto = Ruleset.Value.CreateInstance().GetAutoplayMod();
var autoType = auto?.GetType();
2018-04-13 17:19:50 +08:00
2020-06-02 19:32:52 +08:00
var mods = Mods.Value;
2020-06-02 19:32:52 +08:00
if (autoType == null)
{
2020-06-02 22:01:01 +08:00
notifications?.Post(new SimpleNotification
{
2020-06-02 19:32:52 +08:00
Text = "The current ruleset doesn't have an autoplay mod avalaible!"
});
return false;
}
if (mods.All(m => m.GetType() != autoType))
{
Mods.Value = mods.Append(auto).ToArray();
removeAutoModOnResume = true;
2018-04-13 17:19:50 +08:00
}
}
SampleConfirm?.Play();
2018-04-13 17:19:50 +08:00
this.Push(player = new PlayerLoader(() => new Player()));
2018-04-13 17:19:50 +08:00
return true;
}
}
}