osu/osu.Game/Utils/FormatUtils.cs

36 lines
1.5 KiB
C#
Raw Normal View History

2020-02-04 04:18:19 +00: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;
2020-12-19 14:02:56 +00:00
using Humanizer;
using osu.Framework.Extensions.LocalisationExtensions;
2021-07-23 20:37:08 +00:00
using osu.Framework.Localisation;
2020-12-19 14:02:56 +00:00
namespace osu.Game.Utils
{
2020-02-04 04:36:22 +00:00
public static class FormatUtils
{
/// <summary>
/// Turns the provided accuracy into a percentage with 2 decimal places.
/// </summary>
/// <param name="accuracy">The accuracy to be formatted.</param>
/// <returns>formatted accuracy in percentage</returns>
2021-07-23 20:37:08 +00:00
public static LocalisableString FormatAccuracy(this double accuracy)
{
// for the sake of display purposes, we don't want to show a user a "rounded up" percentage to the next whole number.
// ie. a score which gets 89.99999% shouldn't ever show as 90%.
// the reasoning for this is that cutoffs for grade increases are at whole numbers and displaying the required
// percentile with a non-matching grade is confusing.
accuracy = Math.Floor(accuracy * 10000) / 10000;
2021-07-23 20:37:08 +00:00
return accuracy.ToLocalisableString("0.00%");
}
2020-12-19 14:02:56 +00:00
/// <summary>
/// Formats the supplied rank/leaderboard position in a consistent, simplified way.
/// </summary>
/// <param name="rank">The rank/position to be formatted.</param>
public static string FormatRank(this int rank) => rank.ToMetric(decimals: rank < 100_000 ? 1 : 0);
2020-02-04 04:36:22 +00:00
}
}