1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-13 02:32:55 +08:00

Use ScoreProcessor to fetch accuracy rather than calculating manually

This commit is contained in:
Dean Herbert 2023-01-17 17:03:04 +09:00
parent 70cb23bbc9
commit 23ea77cb74

View File

@ -5,23 +5,32 @@ using System;
using System.Globalization; using System.Globalization;
using System.Linq; using System.Linq;
using osu.Framework.Bindables; using osu.Framework.Bindables;
using osu.Framework.Localisation;
using osu.Game.Configuration; using osu.Game.Configuration;
using osu.Game.Graphics.UserInterface; using osu.Game.Graphics.UserInterface;
using osu.Game.Overlays.Settings; using osu.Game.Overlays.Settings;
using osu.Game.Rulesets.Scoring; using osu.Game.Rulesets.Scoring;
using osu.Game.Rulesets.Judgements; using osu.Game.Rulesets.Judgements;
using osu.Game.Scoring;
namespace osu.Game.Rulesets.Mods namespace osu.Game.Rulesets.Mods
{ {
public class ModAccuracyChallenge : ModFailCondition public class ModAccuracyChallenge : ModFailCondition, IApplicableToScoreProcessor
{ {
public override string Name => "Accuracy Challenge"; public override string Name => "Accuracy Challenge";
public override string Acronym => "AC"; public override string Acronym => "AC";
public override string Description => "Fail the map if you don't maintain a certain accuracy.";
public override LocalisableString Description => "Fail if your accuracy drops too low!";
public override ModType Type => ModType.DifficultyIncrease; public override ModType Type => ModType.DifficultyIncrease;
public override double ScoreMultiplier => 1.0; public override double ScoreMultiplier => 1.0;
public override Type[] IncompatibleMods => base.IncompatibleMods.Concat(new[] { typeof(ModEasyWithExtraLives), typeof(ModPerfect) }).ToArray(); public override Type[] IncompatibleMods => base.IncompatibleMods.Concat(new[] { typeof(ModEasyWithExtraLives), typeof(ModPerfect) }).ToArray();
public override bool RequiresConfiguration => false; public override bool RequiresConfiguration => false;
public override string SettingDescription => base.SettingDescription.Replace(MinimumAccuracy.ToString(), MinimumAccuracy.Value.ToString("##%", NumberFormatInfo.InvariantInfo)); public override string SettingDescription => base.SettingDescription.Replace(MinimumAccuracy.ToString(), MinimumAccuracy.Value.ToString("##%", NumberFormatInfo.InvariantInfo));
[SettingSource("Minimum accuracy", "Trigger a failure if your accuracy goes below this value.", SettingControlType = typeof(SettingsSlider<double, PercentSlider>))] [SettingSource("Minimum accuracy", "Trigger a failure if your accuracy goes below this value.", SettingControlType = typeof(SettingsSlider<double, PercentSlider>))]
@ -34,9 +43,14 @@ namespace osu.Game.Rulesets.Mods
Value = 0.9, Value = 0.9,
}; };
private double baseScore; private ScoreProcessor scoreProcessor = null!;
private double maxBaseScore;
private double accuracy => maxBaseScore > 0 ? baseScore / maxBaseScore : 1; public void ApplyToScoreProcessor(ScoreProcessor scoreProcessor)
{
this.scoreProcessor = scoreProcessor;
}
public ScoreRank AdjustRank(ScoreRank rank, double accuracy) => rank;
protected override bool FailCondition(HealthProcessor healthProcessor, JudgementResult result) protected override bool FailCondition(HealthProcessor healthProcessor, JudgementResult result)
{ {
@ -44,14 +58,11 @@ namespace osu.Game.Rulesets.Mods
if (!result.Type.IsScorable() || result.Type.IsBonus()) if (!result.Type.IsScorable() || result.Type.IsBonus())
return false; return false;
baseScore += result.Type.IsHit() ? result.Judgement.NumericResultFor(result) : 0; return scoreProcessor.Accuracy.Value < MinimumAccuracy.Value;
maxBaseScore += result.Judgement.MaxNumericResult;
return accuracy < MinimumAccuracy.Value;
} }
} }
public class PercentSlider : OsuSliderBar<double> public partial class PercentSlider : OsuSliderBar<double>
{ {
public PercentSlider() public PercentSlider()
{ {