mirror of
https://github.com/ppy/osu.git
synced 2024-11-15 20:37:26 +08:00
985604fab5
There were no usages of more than one column being provided per row, so it seemed like unnecessarily complexity. I'm currently trying to reduce complexity so we can improve the layout of the results screen, which currently has up to three levels of nested `GridContainer`s. Of note, I can't add backwards compatibility because the method signature has not changed in `Ruleset` (only the return type). If we do want to keep compatibility with other rulesets, we could designate a new name for the updated method.
49 lines
1.6 KiB
C#
49 lines
1.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.
|
|
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using osu.Framework.Bindables;
|
|
using osu.Framework.Graphics;
|
|
using osu.Game.Beatmaps;
|
|
using osu.Game.Online.Solo;
|
|
using osu.Game.Scoring;
|
|
using osu.Game.Screens.Ranking.Statistics.User;
|
|
|
|
namespace osu.Game.Screens.Ranking.Statistics
|
|
{
|
|
public partial class SoloStatisticsPanel : StatisticsPanel
|
|
{
|
|
private readonly ScoreInfo achievedScore;
|
|
|
|
public SoloStatisticsPanel(ScoreInfo achievedScore)
|
|
{
|
|
this.achievedScore = achievedScore;
|
|
}
|
|
|
|
public Bindable<SoloStatisticsUpdate?> StatisticsUpdate { get; } = new Bindable<SoloStatisticsUpdate?>();
|
|
|
|
protected override ICollection<StatisticItem> CreateStatisticItems(ScoreInfo newScore, IBeatmap playableBeatmap)
|
|
{
|
|
var items = base.CreateStatisticItems(newScore, playableBeatmap);
|
|
|
|
if (newScore.UserID > 1
|
|
&& newScore.UserID == achievedScore.UserID
|
|
&& newScore.OnlineID > 0
|
|
&& newScore.OnlineID == achievedScore.OnlineID)
|
|
{
|
|
items = items.Append(new StatisticItem("Overall Ranking", () => new OverallRanking
|
|
{
|
|
RelativeSizeAxes = Axes.X,
|
|
Anchor = Anchor.Centre,
|
|
Origin = Anchor.Centre,
|
|
Width = 0.5f,
|
|
StatisticsUpdate = { BindTarget = StatisticsUpdate }
|
|
})).ToArray();
|
|
}
|
|
|
|
return items;
|
|
}
|
|
}
|
|
}
|