mirror of
https://github.com/ppy/osu.git
synced 2025-01-25 15:42:55 +08:00
3bb30d7ff9
You wouldn't think this would be an actual thing that can happen to us, but it is. The most important one by far is `MaximumStatistics`; that is the root cause behind why stuff like spinner ticks or slider tails wasn't showing. On a better day we should probably do cleanup to unify these models better, but today is not that day.
115 lines
3.6 KiB
C#
115 lines
3.6 KiB
C#
// 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.
|
|
|
|
#nullable disable
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using JetBrains.Annotations;
|
|
using Newtonsoft.Json;
|
|
using Newtonsoft.Json.Converters;
|
|
using osu.Game.Beatmaps;
|
|
using osu.Game.Online.API;
|
|
using osu.Game.Online.API.Requests.Responses;
|
|
using osu.Game.Rulesets;
|
|
using osu.Game.Rulesets.Mods;
|
|
using osu.Game.Rulesets.Scoring;
|
|
using osu.Game.Scoring;
|
|
|
|
namespace osu.Game.Online.Rooms
|
|
{
|
|
public class MultiplayerScore
|
|
{
|
|
[JsonProperty("id")]
|
|
public long ID { get; set; }
|
|
|
|
[JsonProperty("user")]
|
|
public APIUser User { get; set; }
|
|
|
|
[JsonProperty("rank")]
|
|
[JsonConverter(typeof(StringEnumConverter))]
|
|
public ScoreRank Rank { get; set; }
|
|
|
|
[JsonProperty("total_score")]
|
|
public long TotalScore { get; set; }
|
|
|
|
[JsonProperty("accuracy")]
|
|
public double Accuracy { get; set; }
|
|
|
|
[JsonProperty("max_combo")]
|
|
public int MaxCombo { get; set; }
|
|
|
|
[JsonProperty("mods")]
|
|
public APIMod[] Mods { get; set; }
|
|
|
|
[JsonProperty("statistics")]
|
|
public Dictionary<HitResult, int> Statistics = new Dictionary<HitResult, int>();
|
|
|
|
[JsonProperty("maximum_statistics")]
|
|
public Dictionary<HitResult, int> MaximumStatistics = new Dictionary<HitResult, int>();
|
|
|
|
[JsonProperty("passed")]
|
|
public bool Passed { get; set; }
|
|
|
|
[JsonProperty("ended_at")]
|
|
public DateTimeOffset EndedAt { get; set; }
|
|
|
|
/// <summary>
|
|
/// The position of this score, starting at 1.
|
|
/// </summary>
|
|
[JsonProperty("position")]
|
|
public int? Position { get; set; }
|
|
|
|
[JsonProperty("pp")]
|
|
public double? PP { get; set; }
|
|
|
|
[JsonProperty("has_replay")]
|
|
public bool HasReplay { get; set; }
|
|
|
|
[JsonProperty("ranked")]
|
|
public bool Ranked { get; set; }
|
|
|
|
/// <summary>
|
|
/// Any scores in the room around this score.
|
|
/// </summary>
|
|
[JsonProperty("scores_around")]
|
|
[CanBeNull]
|
|
public MultiplayerScoresAround ScoresAround { get; set; }
|
|
|
|
public ScoreInfo CreateScoreInfo(ScoreManager scoreManager, RulesetStore rulesets, PlaylistItem playlistItem, [NotNull] BeatmapInfo beatmap)
|
|
{
|
|
var ruleset = rulesets.GetRuleset(playlistItem.RulesetID);
|
|
if (ruleset == null)
|
|
throw new InvalidOperationException($"Couldn't create score with unknown ruleset: {playlistItem.RulesetID}");
|
|
|
|
var rulesetInstance = ruleset.CreateInstance();
|
|
|
|
var scoreInfo = new ScoreInfo
|
|
{
|
|
OnlineID = ID,
|
|
TotalScore = TotalScore,
|
|
MaxCombo = MaxCombo,
|
|
BeatmapInfo = beatmap,
|
|
Ruleset = rulesets.GetRuleset(playlistItem.RulesetID) ?? throw new InvalidOperationException($"Ruleset with ID of {playlistItem.RulesetID} not found locally"),
|
|
Passed = Passed,
|
|
Statistics = Statistics,
|
|
MaximumStatistics = MaximumStatistics,
|
|
User = User,
|
|
Accuracy = Accuracy,
|
|
Date = EndedAt,
|
|
HasOnlineReplay = HasReplay,
|
|
Rank = Rank,
|
|
Mods = Mods?.Select(m => m.ToMod(rulesetInstance)).ToArray() ?? Array.Empty<Mod>(),
|
|
PP = PP,
|
|
Ranked = Ranked,
|
|
Position = Position,
|
|
};
|
|
|
|
scoreManager.PopulateMaximumStatistics(scoreInfo);
|
|
|
|
return scoreInfo;
|
|
}
|
|
}
|
|
}
|