1
0
mirror of https://github.com/ppy/osu.git synced 2024-11-07 18:07:28 +08:00
osu-lazer/osu.Game/Screens/OnlinePlay/Playlists/PlaylistsPlayer.cs

142 lines
4.3 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-12-27 20:12:32 +08:00
using System;
using System.Diagnostics;
2019-02-28 13:58:44 +08:00
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
2018-12-14 20:09:17 +08:00
using osu.Framework.Allocation;
2019-02-21 18:04:31 +08:00
using osu.Framework.Bindables;
using osu.Framework.Logging;
2019-01-23 19:52:00 +08:00
using osu.Framework.Screens;
2018-12-14 20:09:17 +08:00
using osu.Game.Online.API;
2020-12-25 12:38:11 +08:00
using osu.Game.Online.Rooms;
using osu.Game.Rulesets;
2018-12-14 20:09:17 +08:00
using osu.Game.Scoring;
using osu.Game.Screens.Play;
using osu.Game.Screens.Ranking;
namespace osu.Game.Screens.OnlinePlay.Playlists
{
2020-12-25 12:11:21 +08:00
public class PlaylistsPlayer : Player
{
2019-01-23 19:52:00 +08:00
public Action Exited;
2019-02-05 18:00:01 +08:00
[Resolved(typeof(Room), nameof(Room.RoomID))]
2020-12-20 23:13:05 +08:00
protected Bindable<int?> RoomId { get; private set; }
2019-02-05 18:00:01 +08:00
2020-12-20 23:13:05 +08:00
protected readonly PlaylistItem PlaylistItem;
protected int? Token { get; private set; }
2018-12-14 20:09:17 +08:00
[Resolved]
private IAPIProvider api { get; set; }
2018-12-14 20:09:17 +08:00
[Resolved]
private IBindable<RulesetInfo> ruleset { get; set; }
2020-12-25 12:11:21 +08:00
public PlaylistsPlayer(PlaylistItem playlistItem, PlayerConfiguration configuration = null)
: base(configuration)
2018-12-14 20:09:17 +08:00
{
2020-12-20 23:13:05 +08:00
PlaylistItem = playlistItem;
2018-12-14 20:09:17 +08:00
}
[BackgroundDependencyLoader]
private void load()
{
2020-12-20 23:13:05 +08:00
Token = null;
bool failed = false;
2020-12-25 12:11:21 +08:00
// Sanity checks to ensure that PlaylistsPlayer matches the settings for the current PlaylistItem
2020-12-20 23:13:05 +08:00
if (Beatmap.Value.BeatmapInfo.OnlineBeatmapID != PlaylistItem.Beatmap.Value.OnlineBeatmapID)
throw new InvalidOperationException("Current Beatmap does not match PlaylistItem's Beatmap");
2020-12-20 23:13:05 +08:00
if (ruleset.Value.ID != PlaylistItem.Ruleset.Value.ID)
throw new InvalidOperationException("Current Ruleset does not match PlaylistItem's Ruleset");
2020-12-20 23:13:05 +08:00
if (!PlaylistItem.RequiredMods.All(m => Mods.Value.Any(m.Equals)))
throw new InvalidOperationException("Current Mods do not match PlaylistItem's RequiredMods");
2020-12-20 23:13:05 +08:00
var req = new CreateRoomScoreRequest(RoomId.Value ?? 0, PlaylistItem.ID, Game.VersionHash);
req.Success += r => Token = r.ID;
req.Failure += e =>
{
failed = true;
2021-02-05 21:53:40 +08:00
if (string.IsNullOrEmpty(e.Message))
Logger.Error(e, "Failed to retrieve a score submission token.");
else
Logger.Log($"You are not able to submit a score: {e.Message}", level: LogLevel.Important);
Schedule(() =>
{
ValidForResume = false;
2019-01-23 19:52:00 +08:00
this.Exit();
});
};
2018-12-14 20:09:17 +08:00
api.Queue(req);
2020-12-20 23:13:05 +08:00
while (!failed && !Token.HasValue)
Thread.Sleep(1000);
2018-12-14 20:09:17 +08:00
}
2019-01-23 19:52:00 +08:00
public override bool OnExiting(IScreen next)
{
if (base.OnExiting(next))
return true;
Exited?.Invoke();
return false;
}
protected override ResultsScreen CreateResults(ScoreInfo score)
{
2020-12-20 23:13:05 +08:00
Debug.Assert(RoomId.Value != null);
2020-12-25 12:11:21 +08:00
return new PlaylistsResultsScreen(score, RoomId.Value.Value, PlaylistItem, true);
}
protected override Score CreateScore()
2018-12-14 20:09:17 +08:00
{
var score = base.CreateScore();
score.ScoreInfo.TotalScore = (int)Math.Round(ScoreProcessor.GetStandardisedScore());
return score;
}
protected override async Task SubmitScore(Score score)
{
await base.SubmitScore(score);
2020-12-20 23:13:05 +08:00
Debug.Assert(Token != null);
2020-12-19 02:17:04 +08:00
var tcs = new TaskCompletionSource<bool>();
2020-12-20 23:13:05 +08:00
var request = new SubmitRoomScoreRequest(Token.Value, RoomId.Value ?? 0, PlaylistItem.ID, score.ScoreInfo);
request.Success += s =>
{
score.ScoreInfo.OnlineScoreID = s.ID;
2020-12-19 02:17:04 +08:00
tcs.SetResult(true);
};
request.Failure += e =>
{
Logger.Error(e, "Failed to submit score");
2020-12-19 02:17:04 +08:00
tcs.SetResult(false);
};
2018-12-14 20:09:17 +08:00
api.Queue(request);
2020-12-19 02:17:04 +08:00
await tcs.Task;
2018-12-14 20:09:17 +08:00
}
2018-12-21 17:22:13 +08:00
2019-01-23 19:52:00 +08:00
protected override void Dispose(bool isDisposing)
{
base.Dispose(isDisposing);
Exited = null;
}
2018-12-14 20:09:17 +08:00
}
}