1
0
mirror of https://github.com/ppy/osu.git synced 2025-03-12 00:37:19 +08:00
osu-lazer/osu.Game/Screens/Ranking/SoloResultsScreen.cs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

91 lines
3.1 KiB
C#
Raw Normal View History

2020-05-26 17:00:41 +09: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.
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Threading.Tasks;
2020-05-26 17:00:41 +09:00
using osu.Framework.Allocation;
using osu.Framework.Logging;
2020-06-03 11:36:47 +09:30
using osu.Game.Beatmaps;
using osu.Game.Extensions;
2020-05-26 17:00:41 +09:00
using osu.Game.Online.API;
using osu.Game.Online.API.Requests;
using osu.Game.Online.API.Requests.Responses;
2020-05-26 17:00:41 +09:00
using osu.Game.Rulesets;
using osu.Game.Scoring;
namespace osu.Game.Screens.Ranking
{
public partial class SoloResultsScreen : ResultsScreen
{
2022-12-28 07:49:09 +01:00
private GetScoresRequest? getScoreRequest;
2020-05-26 17:00:41 +09:00
[Resolved]
2022-12-28 07:49:09 +01:00
private RulesetStore rulesets { get; set; } = null!;
2020-05-26 17:00:41 +09:00
[Resolved]
private IAPIProvider api { get; set; } = null!;
public SoloResultsScreen(ScoreInfo score)
: base(score)
2020-05-26 17:00:41 +09:00
{
}
2025-02-25 22:55:55 +09:00
protected override async Task<ScoreInfo[]> FetchScores()
2020-05-26 17:00:41 +09:00
{
Debug.Assert(Score != null);
2023-07-04 14:50:34 +09:00
if (Score.BeatmapInfo!.OnlineID <= 0 || Score.BeatmapInfo.Status <= BeatmapOnlineStatus.Pending)
return [];
var requestTaskSource = new TaskCompletionSource<APIScoresCollection>();
2020-06-03 11:36:47 +09:30
getScoreRequest = new GetScoresRequest(Score.BeatmapInfo, Score.Ruleset);
getScoreRequest.Success += requestTaskSource.SetResult;
getScoreRequest.Failure += requestTaskSource.SetException;
api.Queue(getScoreRequest);
try
{
2025-02-25 22:56:38 +09:00
var scores = await requestTaskSource.Task.ConfigureAwait(false);
var toDisplay = new List<ScoreInfo>();
for (int i = 0; i < scores.Scores.Count; ++i)
{
var score = scores.Scores[i];
int position = i + 1;
if (score.MatchesOnlineID(Score))
{
// we don't want to add the same score twice, but also setting any properties of `Score` this late will have no visible effect,
// so we have to fish out the actual drawable panel and set the position to it directly.
var panel = ScorePanelList.GetPanelForScore(Score);
Score.Position = panel.ScorePosition.Value = position;
}
else
{
var converted = score.ToScoreInfo(rulesets, Beatmap.Value.BeatmapInfo);
converted.Position = position;
toDisplay.Add(converted);
}
}
2025-02-25 22:55:55 +09:00
return toDisplay.ToArray();
}
catch (Exception ex)
{
Logger.Log($"Failed to fetch scores (beatmap: {Score.BeatmapInfo}, ruleset: {Score.Ruleset}): {ex}");
return [];
}
}
protected override void Dispose(bool isDisposing)
{
base.Dispose(isDisposing);
getScoreRequest?.Cancel();
2020-05-26 17:00:41 +09:00
}
}
}