mirror of
https://github.com/osukey/osukey.git
synced 2025-08-04 23:24:04 +09:00
Merge pull request #10555 from peppy/fix-score-display-zero-padding
Fix incorrect zero padding for classic scoring mode
This commit is contained in:
@ -15,5 +15,11 @@ namespace osu.Game.Screens.Play.HUD
|
||||
/// The current score to be displayed.
|
||||
/// </summary>
|
||||
Bindable<double> Current { get; }
|
||||
|
||||
/// <summary>
|
||||
/// The number of digits required to display most sane scores.
|
||||
/// This may be exceeded in very rare cases, but is useful to pad or space the display to avoid it jumping around.
|
||||
/// </summary>
|
||||
Bindable<int> RequiredDisplayDigits { get; }
|
||||
}
|
||||
}
|
||||
|
@ -1,7 +1,11 @@
|
||||
// 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 osu.Framework.Allocation;
|
||||
using osu.Framework.Bindables;
|
||||
using osu.Game.Configuration;
|
||||
using osu.Game.Rulesets.Scoring;
|
||||
using osu.Game.Skinning;
|
||||
|
||||
namespace osu.Game.Screens.Play.HUD
|
||||
@ -10,12 +14,38 @@ namespace osu.Game.Screens.Play.HUD
|
||||
{
|
||||
public Bindable<double> Current { get; } = new Bindable<double>();
|
||||
|
||||
private Bindable<ScoringMode> scoreDisplayMode;
|
||||
|
||||
public Bindable<int> RequiredDisplayDigits { get; } = new Bindable<int>();
|
||||
|
||||
public SkinnableScoreCounter()
|
||||
: base(new HUDSkinComponent(HUDSkinComponents.ScoreCounter), _ => new DefaultScoreCounter())
|
||||
{
|
||||
CentreComponent = false;
|
||||
}
|
||||
|
||||
[BackgroundDependencyLoader]
|
||||
private void load(OsuConfigManager config)
|
||||
{
|
||||
scoreDisplayMode = config.GetBindable<ScoringMode>(OsuSetting.ScoreDisplayMode);
|
||||
scoreDisplayMode.BindValueChanged(scoreMode =>
|
||||
{
|
||||
switch (scoreMode.NewValue)
|
||||
{
|
||||
case ScoringMode.Standardised:
|
||||
RequiredDisplayDigits.Value = 6;
|
||||
break;
|
||||
|
||||
case ScoringMode.Classic:
|
||||
RequiredDisplayDigits.Value = 8;
|
||||
break;
|
||||
|
||||
default:
|
||||
throw new ArgumentOutOfRangeException(nameof(scoreMode));
|
||||
}
|
||||
}, true);
|
||||
}
|
||||
|
||||
private IScoreCounter skinnedCounter;
|
||||
|
||||
protected override void SkinChanged(ISkinSource skin, bool allowFallback)
|
||||
@ -23,7 +53,9 @@ namespace osu.Game.Screens.Play.HUD
|
||||
base.SkinChanged(skin, allowFallback);
|
||||
|
||||
skinnedCounter = Drawable as IScoreCounter;
|
||||
|
||||
skinnedCounter?.Current.BindTo(Current);
|
||||
skinnedCounter?.RequiredDisplayDigits.BindTo(RequiredDisplayDigits);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user