1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-15 22:22:56 +08:00

clean up linQ result formatting. Replace numbers with hitresult displaynames.

Make adjustments to statistics to allow them to work with autosizing
This commit is contained in:
mk56-spn 2023-01-17 20:13:50 +01:00
parent d73ce1ddb2
commit c44891d427
2 changed files with 20 additions and 58 deletions

View File

@ -43,7 +43,7 @@ namespace osu.Game.Tests.Visual.SongSelect
Position = 22333, Position = 22333,
Rank = ScoreRank.S, Rank = ScoreRank.S,
Accuracy = 0.1f, Accuracy = 0.1f,
MaxCombo = 2404, MaxCombo = 32040,
Mods = new Mod[] { new OsuModHidden(), new OsuModHardRock(), new OsuModAlternate(), new OsuModFlashlight(), new OsuModFreezeFrame(), new OsuModClassic() }, Mods = new Mod[] { new OsuModHidden(), new OsuModHardRock(), new OsuModAlternate(), new OsuModFlashlight(), new OsuModFreezeFrame(), new OsuModClassic() },
TotalScore = 1707827, TotalScore = 1707827,
Ruleset = new OsuRuleset().RulesetInfo, Ruleset = new OsuRuleset().RulesetInfo,

View File

@ -21,7 +21,6 @@ using osu.Game.Graphics;
using osu.Game.Graphics.Containers; using osu.Game.Graphics.Containers;
using osu.Game.Graphics.Sprites; using osu.Game.Graphics.Sprites;
using osu.Game.Graphics.UserInterface; using osu.Game.Graphics.UserInterface;
using osu.Game.Localisation;
using osu.Game.Online.API.Requests.Responses; using osu.Game.Online.API.Requests.Responses;
using osu.Game.Overlays; using osu.Game.Overlays;
using osu.Game.Resources.Localisation.Web; using osu.Game.Resources.Localisation.Web;
@ -33,7 +32,6 @@ using osu.Game.Screens.Select;
using osu.Game.Users.Drawables; using osu.Game.Users.Drawables;
using osu.Game.Utils; using osu.Game.Utils;
using osuTK; using osuTK;
using CommonStrings = osu.Game.Resources.Localisation.Web.CommonStrings;
namespace osu.Game.Online.Leaderboards namespace osu.Game.Online.Leaderboards
{ {
@ -220,7 +218,8 @@ namespace osu.Game.Online.Leaderboards
}, },
new FillFlowContainer new FillFlowContainer
{ {
Spacing = new Vector2(5, 0), Margin = new MarginPadding { Right = 40 },
Spacing = new Vector2(25, 0),
Shear = -shear, Shear = -shear,
Anchor = Anchor.CentreRight, Anchor = Anchor.CentreRight,
Origin = Anchor.CentreRight, Origin = Anchor.CentreRight,
@ -290,7 +289,7 @@ namespace osu.Game.Online.Leaderboards
protected (CaseTransformableString, LocalisableString DisplayAccuracy)[] GetStatistics(ScoreInfo model) => new[] protected (CaseTransformableString, LocalisableString DisplayAccuracy)[] GetStatistics(ScoreInfo model) => new[]
{ {
(EditorSetupStrings.ComboColourPrefix.ToUpper(), model.MaxCombo.ToString().Insert(model.MaxCombo.ToString().Length, "x")), (BeatmapsetsStrings.ShowScoreboardHeadersCombo.ToUpper(), model.MaxCombo.ToString().Insert(model.MaxCombo.ToString().Length, "x")),
(BeatmapsetsStrings.ShowScoreboardHeadersAccuracy.ToUpper(), model.DisplayAccuracy), (BeatmapsetsStrings.ShowScoreboardHeadersAccuracy.ToUpper(), model.DisplayAccuracy),
(getResultNames(score).ToUpper(), getResults(score).ToUpper()) (getResultNames(score).ToUpper(), getResults(score).ToUpper())
}; };
@ -380,7 +379,7 @@ namespace osu.Game.Online.Leaderboards
[BackgroundDependencyLoader] [BackgroundDependencyLoader]
private void load(OsuColour colours, OverlayColourProvider colourProvider) private void load(OsuColour colours, OverlayColourProvider colourProvider)
{ {
AutoSizeAxes = Axes.Y; AutoSizeAxes = Axes.Both;
OsuSpriteText value; OsuSpriteText value;
Child = content = new FillFlowContainer Child = content = new FillFlowContainer
{ {
@ -396,24 +395,17 @@ namespace osu.Game.Online.Leaderboards
}, },
value = new OsuSpriteText value = new OsuSpriteText
{ {
// We don't want the value setting the horizontal size, since it leads to wonky accuracy container length,
// since the accuracy is sometimes longer than its name.
BypassAutoSizeAxes = Axes.X,
Text = statisticInfo.Value, Text = statisticInfo.Value,
Font = OsuFont.GetFont(size: 19, weight: FontWeight.Medium), Font = OsuFont.GetFont(size: 19, weight: FontWeight.Medium),
} }
} }
}; };
if (statisticInfo.Name == EditorSetupStrings.ComboColourPrefix.ToUpper()) if (score.Combo != score.MaxCombo && statisticInfo.Name == BeatmapsetsStrings.ShowScoreboardHeadersCombo)
{
Width = 45;
if (score.Combo != score.MaxCombo) return;
value.Colour = colours.Lime1; value.Colour = colours.Lime1;
return;
}
Width = statisticInfo.Name == BeatmapsetsStrings.ShowScoreboardHeadersAccuracy.ToUpper() ? 60 : 120;
} }
} }
@ -446,7 +438,7 @@ namespace osu.Game.Online.Leaderboards
} }
} }
private partial class ColouredModSwitchTiny : ModSwitchTiny, IHasTooltip private sealed partial class ColouredModSwitchTiny : ModSwitchTiny, IHasTooltip
{ {
private readonly IMod mod; private readonly IMod mod;
@ -474,7 +466,7 @@ namespace osu.Game.Online.Leaderboards
Background.Colour = colours.Yellow; Background.Colour = colours.Yellow;
} }
public virtual LocalisableString TooltipText => (mod as Mod)?.IconTooltip ?? mod.Name; public LocalisableString TooltipText => (mod as Mod)?.IconTooltip ?? mod.Name;
} }
#endregion #endregion
@ -499,52 +491,22 @@ namespace osu.Game.Online.Leaderboards
private LocalisableString getResults(ScoreInfo score) private LocalisableString getResults(ScoreInfo score)
{ {
string resultString = score.GetStatisticsForDisplay().Where(s => s.Result.IsBasic()).Aggregate(string.Empty, (current, result) => string resultString = score.GetStatisticsForDisplay()
current.Insert(current.Length, $"{result.Count}/")); .Where(s => s.Result.IsBasic())
.Aggregate(string.Empty, (current, result) =>
current.Insert(current.Length, $"{result.Count}/"));
return resultString.Remove(resultString.Length - 1); return resultString.Remove(resultString.Length - 1);
} }
private LocalisableString getResultNames(ScoreInfo score) private LocalisableString getResultNames(ScoreInfo score)
{ {
string resultName = string.Empty; string resultName = score.GetStatisticsForDisplay()
.Where(s => s.Result.IsBasic())
.Aggregate(string.Empty, (current, hitResult) =>
current.Insert(current.Length, $"{hitResult.DisplayName.ToString().ToUpperInvariant()}/"));
foreach (var hitResult in score.GetStatisticsForDisplay().Where(s => s.Result.IsBasic())) return resultName.Remove(resultName.Length - 1);
{
switch (hitResult.Result)
{
case HitResult.Perfect:
appendToString("320/");
break;
case HitResult.Great:
appendToString("300/");
break;
case HitResult.Good:
appendToString("200/");
break;
case HitResult.Ok:
appendToString("100/");
break;
case HitResult.Meh:
appendToString("50/");
break;
case HitResult.Miss:
appendToString("X");
break;
default:
throw new ArgumentOutOfRangeException();
}
}
void appendToString(string appendedString) => resultName = resultName.Insert(resultName.Length, appendedString);
return resultName.Remove(resultName.Length);
} }
} }
} }