osu/osu.Game/Screens/Multi/Play/TimeshiftPlayer.cs

118 lines
3.4 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 12:12:32 +00:00
using System;
using System.Diagnostics;
2019-02-28 05:58:44 +00:00
using System.Linq;
using System.Threading;
2018-12-14 12:09:17 +00:00
using osu.Framework.Allocation;
2019-02-21 10:04:31 +00:00
using osu.Framework.Bindables;
using osu.Framework.Logging;
2019-01-23 11:52:00 +00:00
using osu.Framework.Screens;
2018-12-14 12:09:17 +00:00
using osu.Game.Online.API;
using osu.Game.Online.API.Requests;
2018-12-21 09:22:13 +00:00
using osu.Game.Online.Multiplayer;
using osu.Game.Rulesets;
2018-12-14 12:09:17 +00:00
using osu.Game.Scoring;
using osu.Game.Screens.Play;
namespace osu.Game.Screens.Multi.Play
{
public class TimeshiftPlayer : Player
{
2019-01-23 11:52:00 +00:00
public Action Exited;
2019-02-05 10:00:01 +00:00
[Resolved(typeof(Room), nameof(Room.RoomID))]
private Bindable<int?> roomId { get; set; }
2019-02-08 09:33:49 +00:00
private readonly PlaylistItem playlistItem;
2018-12-14 12:09:17 +00:00
[Resolved]
private IAPIProvider api { get; set; }
2018-12-14 12:09:17 +00:00
[Resolved]
private IBindable<RulesetInfo> ruleset { get; set; }
2019-02-08 09:33:49 +00:00
public TimeshiftPlayer(PlaylistItem playlistItem)
2018-12-14 12:09:17 +00:00
{
2019-02-08 09:33:49 +00:00
this.playlistItem = playlistItem;
2018-12-14 12:09:17 +00:00
}
private int? token;
2018-12-14 12:09:17 +00:00
[BackgroundDependencyLoader]
private void load()
{
token = null;
bool failed = false;
// Sanity checks to ensure that TimeshiftPlayer matches the settings for the current PlaylistItem
if (Beatmap.Value.BeatmapInfo.OnlineBeatmapID != playlistItem.Beatmap.Value.OnlineBeatmapID)
throw new InvalidOperationException("Current Beatmap does not match PlaylistItem's Beatmap");
if (ruleset.Value.ID != playlistItem.Ruleset.Value.ID)
throw new InvalidOperationException("Current Ruleset does not match PlaylistItem's Ruleset");
if (!playlistItem.RequiredMods.All(m => Mods.Value.Any(m.Equals)))
throw new InvalidOperationException("Current Mods do not match PlaylistItem's RequiredMods");
2019-02-08 09:33:49 +00:00
var req = new CreateRoomScoreRequest(roomId.Value ?? 0, playlistItem.ID);
2018-12-14 12:09:17 +00:00
req.Success += r => token = r.ID;
req.Failure += e =>
{
failed = true;
Logger.Error(e, "Failed to retrieve a score submission token.");
Schedule(() =>
{
ValidForResume = false;
2019-01-23 11:52:00 +00:00
this.Exit();
});
};
2018-12-14 12:09:17 +00:00
api.Queue(req);
while (!failed && !token.HasValue)
Thread.Sleep(1000);
2018-12-14 12:09:17 +00:00
}
2019-01-23 11:52:00 +00:00
public override bool OnExiting(IScreen next)
{
if (base.OnExiting(next))
return true;
Exited?.Invoke();
return false;
}
2018-12-14 12:09:17 +00:00
protected override ScoreInfo CreateScore()
2018-12-27 12:12:32 +00:00
{
submitScore();
return base.CreateScore();
}
private void submitScore()
2018-12-14 12:09:17 +00:00
{
var score = base.CreateScore();
2018-12-27 12:12:32 +00:00
score.TotalScore = (int)Math.Round(ScoreProcessor.GetStandardisedScore());
Debug.Assert(token != null);
2019-02-08 09:33:49 +00:00
var request = new SubmitRoomScoreRequest(token.Value, roomId.Value ?? 0, playlistItem.ID, score);
request.Failure += e => Logger.Error(e, "Failed to submit score");
2018-12-14 12:09:17 +00:00
api.Queue(request);
}
2018-12-21 09:22:13 +00:00
2019-01-23 11:52:00 +00:00
protected override void Dispose(bool isDisposing)
{
base.Dispose(isDisposing);
Exited = null;
}
2018-12-14 12:09:17 +00:00
}
}