2020-12-20 23:04:06 +08:00
|
|
|
// 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.
|
|
|
|
|
2020-12-28 19:32:06 +08:00
|
|
|
using System.Collections.Generic;
|
2020-12-20 23:37:13 +08:00
|
|
|
using System.Linq;
|
|
|
|
using Humanizer;
|
|
|
|
using osu.Framework.Allocation;
|
|
|
|
using osu.Framework.Bindables;
|
2020-12-22 15:23:06 +08:00
|
|
|
using osu.Framework.Graphics;
|
2020-12-22 15:50:30 +08:00
|
|
|
using osu.Framework.Logging;
|
2020-12-20 23:37:13 +08:00
|
|
|
using osu.Framework.Screens;
|
2020-12-28 19:32:06 +08:00
|
|
|
using osu.Game.Beatmaps;
|
2020-12-22 16:08:02 +08:00
|
|
|
using osu.Game.Graphics.UserInterface;
|
2020-12-20 23:37:13 +08:00
|
|
|
using osu.Game.Online.Multiplayer;
|
2020-12-25 12:38:11 +08:00
|
|
|
using osu.Game.Online.Rooms;
|
2021-01-18 16:50:32 +08:00
|
|
|
using osu.Game.Overlays.Mods;
|
2020-12-28 19:32:06 +08:00
|
|
|
using osu.Game.Rulesets;
|
|
|
|
using osu.Game.Rulesets.Mods;
|
2020-12-20 23:04:06 +08:00
|
|
|
using osu.Game.Screens.Select;
|
|
|
|
|
2020-12-25 23:50:00 +08:00
|
|
|
namespace osu.Game.Screens.OnlinePlay.Multiplayer
|
2020-12-20 23:04:06 +08:00
|
|
|
{
|
2020-12-26 00:05:29 +08:00
|
|
|
public class MultiplayerMatchSongSelect : SongSelect, IOnlinePlaySubScreen
|
2020-12-20 23:04:06 +08:00
|
|
|
{
|
2020-12-20 23:37:13 +08:00
|
|
|
public string ShortTitle => "song selection";
|
|
|
|
|
|
|
|
public override string Title => ShortTitle.Humanize();
|
|
|
|
|
|
|
|
[Resolved(typeof(Room), nameof(Room.Playlist))]
|
|
|
|
private BindableList<PlaylistItem> playlist { get; set; }
|
|
|
|
|
|
|
|
[Resolved]
|
|
|
|
private StatefulMultiplayerClient client { get; set; }
|
2020-12-20 23:04:06 +08:00
|
|
|
|
2020-12-22 16:08:02 +08:00
|
|
|
private LoadingLayer loadingLayer;
|
|
|
|
|
2020-12-28 19:32:06 +08:00
|
|
|
private WorkingBeatmap initialBeatmap;
|
|
|
|
private RulesetInfo initialRuleset;
|
|
|
|
private IReadOnlyList<Mod> initialMods;
|
|
|
|
|
|
|
|
private bool itemSelected;
|
|
|
|
|
2020-12-25 12:38:11 +08:00
|
|
|
public MultiplayerMatchSongSelect()
|
2020-12-22 15:23:06 +08:00
|
|
|
{
|
|
|
|
Padding = new MarginPadding { Horizontal = HORIZONTAL_OVERFLOW_PADDING };
|
|
|
|
}
|
|
|
|
|
2020-12-22 16:08:02 +08:00
|
|
|
[BackgroundDependencyLoader]
|
|
|
|
private void load()
|
|
|
|
{
|
2021-01-04 21:42:39 +08:00
|
|
|
AddInternal(loadingLayer = new LoadingLayer(true));
|
2020-12-28 19:32:06 +08:00
|
|
|
initialBeatmap = Beatmap.Value;
|
|
|
|
initialRuleset = Ruleset.Value;
|
|
|
|
initialMods = Mods.Value.ToList();
|
2020-12-22 16:08:02 +08:00
|
|
|
}
|
|
|
|
|
2020-12-20 23:04:06 +08:00
|
|
|
protected override bool OnStart()
|
|
|
|
{
|
2020-12-28 19:32:06 +08:00
|
|
|
itemSelected = true;
|
2020-12-20 23:37:13 +08:00
|
|
|
var item = new PlaylistItem();
|
|
|
|
|
|
|
|
item.Beatmap.Value = Beatmap.Value.BeatmapInfo;
|
|
|
|
item.Ruleset.Value = Ruleset.Value;
|
|
|
|
|
|
|
|
item.RequiredMods.Clear();
|
|
|
|
item.RequiredMods.AddRange(Mods.Value.Select(m => m.CreateCopy()));
|
|
|
|
|
|
|
|
// If the client is already in a room, update via the client.
|
|
|
|
// Otherwise, update the playlist directly in preparation for it to be submitted to the API on match creation.
|
|
|
|
if (client.Room != null)
|
2020-12-22 15:50:30 +08:00
|
|
|
{
|
2020-12-22 16:08:02 +08:00
|
|
|
loadingLayer.Show();
|
|
|
|
|
|
|
|
client.ChangeSettings(item: item).ContinueWith(t =>
|
2020-12-22 15:50:30 +08:00
|
|
|
{
|
2020-12-23 16:10:34 +08:00
|
|
|
Schedule(() =>
|
2020-12-22 16:08:02 +08:00
|
|
|
{
|
|
|
|
loadingLayer.Hide();
|
|
|
|
|
|
|
|
if (t.IsCompletedSuccessfully)
|
|
|
|
this.Exit();
|
|
|
|
else
|
2020-12-23 21:18:24 +08:00
|
|
|
{
|
2020-12-22 16:08:02 +08:00
|
|
|
Logger.Log($"Could not use current beatmap ({t.Exception?.Message})", level: LogLevel.Important);
|
2020-12-23 21:18:24 +08:00
|
|
|
Carousel.AllowSelection = true;
|
|
|
|
}
|
2020-12-22 16:08:02 +08:00
|
|
|
});
|
|
|
|
});
|
2020-12-22 15:50:30 +08:00
|
|
|
}
|
2020-12-20 23:37:13 +08:00
|
|
|
else
|
|
|
|
{
|
|
|
|
playlist.Clear();
|
|
|
|
playlist.Add(item);
|
2020-12-22 15:50:30 +08:00
|
|
|
this.Exit();
|
2020-12-20 23:37:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
2020-12-20 23:04:06 +08:00
|
|
|
}
|
2020-12-20 23:37:13 +08:00
|
|
|
|
2020-12-28 19:32:06 +08:00
|
|
|
public override bool OnExiting(IScreen next)
|
|
|
|
{
|
|
|
|
if (!itemSelected)
|
|
|
|
{
|
|
|
|
Beatmap.Value = initialBeatmap;
|
|
|
|
Ruleset.Value = initialRuleset;
|
|
|
|
Mods.Value = initialMods;
|
|
|
|
}
|
|
|
|
|
|
|
|
return base.OnExiting(next);
|
|
|
|
}
|
|
|
|
|
2020-12-20 23:37:13 +08:00
|
|
|
protected override BeatmapDetailArea CreateBeatmapDetailArea() => new PlayBeatmapDetailArea();
|
2021-01-18 16:50:32 +08:00
|
|
|
|
2021-02-02 19:58:31 +08:00
|
|
|
protected override ModSelectOverlay CreateModSelectOverlay() => new SoloModSelectOverlay { IsValidMod = isValidMod };
|
2021-01-18 16:50:32 +08:00
|
|
|
|
|
|
|
private bool isValidMod(Mod mod) => !(mod is ModAutoplay) && (mod as MultiMod)?.Mods.Any(mm => mm is ModAutoplay) != true;
|
2020-12-20 23:04:06 +08:00
|
|
|
}
|
|
|
|
}
|