From 768bc2bb5f847ce48fcd779622d3e8de122bc92e Mon Sep 17 00:00:00 2001 From: smoogipooo Date: Thu, 23 Mar 2017 19:14:21 +0900 Subject: [PATCH 01/17] Make TaikoHitObject store whether the hit object is a finisher. --- osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs | 6 ++++++ osu.Game.Modes.Taiko/Objects/TaikoHitObject.cs | 5 +++++ 2 files changed, 11 insertions(+) diff --git a/osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs b/osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs index 0606ee4d5a..d00d6ae473 100644 --- a/osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs +++ b/osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs @@ -3,6 +3,7 @@ using osu.Game.Beatmaps; using osu.Game.Beatmaps.Legacy; +using osu.Game.Beatmaps.Samples; using osu.Game.Modes.Objects; using osu.Game.Modes.Objects.Types; using osu.Game.Modes.Taiko.Objects; @@ -43,12 +44,15 @@ namespace osu.Game.Modes.Taiko.Beatmaps IHasRepeats repeatsData = original as IHasRepeats; IHasEndTime endTimeData = original as IHasEndTime; + bool isFinisher = (original.Sample.Type & SampleType.Finish) > 0; + if (distanceData != null) { return new DrumRoll { StartTime = original.StartTime, Sample = original.Sample, + IsFinisher = isFinisher, Distance = distanceData.Distance * (repeatsData?.RepeatCount ?? 1) }; @@ -61,6 +65,7 @@ namespace osu.Game.Modes.Taiko.Beatmaps { StartTime = original.StartTime, Sample = original.Sample, + IsFinisher = isFinisher, EndTime = original.StartTime + endTimeData.Duration * bash_convert_factor }; @@ -70,6 +75,7 @@ namespace osu.Game.Modes.Taiko.Beatmaps { StartTime = original.StartTime, Sample = original.Sample, + IsFinisher = isFinisher }; } } diff --git a/osu.Game.Modes.Taiko/Objects/TaikoHitObject.cs b/osu.Game.Modes.Taiko/Objects/TaikoHitObject.cs index 4505065489..a27d842053 100644 --- a/osu.Game.Modes.Taiko/Objects/TaikoHitObject.cs +++ b/osu.Game.Modes.Taiko/Objects/TaikoHitObject.cs @@ -19,6 +19,11 @@ namespace osu.Game.Modes.Taiko.Objects /// public double PreEmpt; + /// + /// Whether this HitObject is a finisher. + /// + public bool IsFinisher; + /// /// Whether this HitObject is in Kiai time. /// From 322a78830eadd6045d5a989057d8d209a1621d12 Mon Sep 17 00:00:00 2001 From: smoogipooo Date: Thu, 23 Mar 2017 19:24:23 +0900 Subject: [PATCH 02/17] Implement Taiko score processing. --- osu.Game.Modes.Taiko/TaikoScoreProcessor.cs | 244 ++++++++++++++++++++ osu.Game/Modes/ScoreProcessor.cs | 4 +- 2 files changed, 246 insertions(+), 2 deletions(-) diff --git a/osu.Game.Modes.Taiko/TaikoScoreProcessor.cs b/osu.Game.Modes.Taiko/TaikoScoreProcessor.cs index 849c0fa894..0beb9f7418 100644 --- a/osu.Game.Modes.Taiko/TaikoScoreProcessor.cs +++ b/osu.Game.Modes.Taiko/TaikoScoreProcessor.cs @@ -1,14 +1,120 @@ // Copyright (c) 2007-2017 ppy Pty Ltd . // Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE +using OpenTK; +using osu.Game.Beatmaps; +using osu.Game.Database; +using osu.Game.Modes.Objects.Drawables; using osu.Game.Modes.Taiko.Judgements; using osu.Game.Modes.Taiko.Objects; using osu.Game.Modes.UI; +using System; namespace osu.Game.Modes.Taiko { internal class TaikoScoreProcessor : ScoreProcessor { + /// + /// The maximum score achievable. + /// Does _not_ include bonus score - for bonus score see . + /// + private const int max_score = 1000000; + + /// + /// The amount of the score attributed to combo. + /// + private const double combo_portion_max = max_score * 0.2; + + /// + /// The amount of the score attributed to accuracy. + /// + private const double accuracy_portion_max = max_score * 0.8; + + /// + /// The factor used to determine relevance of combos. + /// + private const double combo_base = 4; + + /// + /// The HP awarded by a hit. + /// + private const double hp_hit_great = 0.03; + + /// + /// The HP awarded for a hit at HP >= 5. + /// + private const double hp_hit_good = 0.011; + + /// + /// The HP awarded for a hit at HP = 0. + /// + /// Yes, this is incorrect, and goods at HP = 0 will award more HP than greats. + /// This is legacy and should be fixed, but is kept as is for now for compatibility. + /// + /// + private const double hp_hit_good_max = hp_hit_good * 8; + + /// + /// The HP deducted for a at HP = 0. + /// + private const double hp_miss_min = -0.0018; + + /// + /// The HP deducted for a at HP = 5. + /// + private const double hp_miss_mid = -0.0075; + + /// + /// The HP deducted for a at HP = 10. + /// + private const double hp_miss_max = -0.12; + + /// + /// The HP awarded for a hit. + /// + /// hits award less HP as they're more spammable, although in hindsight + /// this probably awards too little HP and is kept at this value for now for compatibility. + /// + /// + private const double hp_hit_tick = 0.00000003; + + /// + /// Taiko fails at the end of the map if the player has not half-filled their HP bar. + /// + public override bool HasFailed => totalHits == maxTotalHits && Health.Value <= 0.5; + + /// + /// The final combo portion of the score. + /// + private double comboScore => combo_portion_max * comboPortion / maxComboPortion; + + /// + /// The final accuracy portion of the score. + /// + private double accuracyScore => accuracy_portion_max * Math.Pow(Accuracy, 3.6) * totalHits / maxTotalHits; + + /// + /// The final bonus score. + /// This is added on top of , thus the total score can exceed . + /// + private double bonusScore; + + /// + /// The multiple of the original score added to the combo portion of the score + /// for correctly hitting a finisher with both keys. + /// + private double finisherScoreScale; + + private double hpIncreaseTick; + private double hpIncreaseGreat; + private double hpIncreaseGood; + private double hpIncreaseMiss; + + private double maxComboPortion; + private double comboPortion; + private int maxTotalHits; + private int totalHits; + public TaikoScoreProcessor() { } @@ -18,8 +124,146 @@ namespace osu.Game.Modes.Taiko { } + protected override void ComputeTargets(Beatmap beatmap) + { + double hpMultiplierNormal = 1 / (hp_hit_great * beatmap.HitObjects.FindAll(o => o is Hit).Count * BeatmapDifficulty.DifficultyRange(beatmap.BeatmapInfo.Difficulty.DrainRate, 0.5, 0.75, 0.98)); + + hpIncreaseTick = hp_hit_tick; + hpIncreaseGreat = hpMultiplierNormal * hp_hit_great; + hpIncreaseGood = hpMultiplierNormal * BeatmapDifficulty.DifficultyRange(beatmap.BeatmapInfo.Difficulty.DrainRate, hp_hit_good_max, hp_hit_good, hp_hit_good); + hpIncreaseMiss = BeatmapDifficulty.DifficultyRange(beatmap.BeatmapInfo.Difficulty.DrainRate, hp_miss_min, hp_miss_mid, hp_miss_max); + + var finishers = beatmap.HitObjects.FindAll(o => o is Hit && o.IsFinisher); + + // This is a linear function that awards: + // 10 times bonus points for hitting a finisher with both keys with 30 finishers in the map + // 3 times bonus points for hitting a finisher with both keys with 120 finishers in the map + finisherScoreScale = -7d / 90d * MathHelper.Clamp(finishers.Count, 30, 120) + 111d / 9d; + + foreach (TaikoHitObject obj in beatmap.HitObjects) + { + if (obj is Hit) + { + AddJudgement(new TaikoJudgementInfo + { + Result = HitResult.Hit, + TaikoResult = TaikoHitResult.Great, + SecondHit = obj.IsFinisher + }); + } + else if (obj is DrumRoll) + { + for (int i = 0; i < ((DrumRoll)obj).TotalTicks; i++) + { + AddJudgement(new TaikoDrumRollTickJudgementInfo + { + Result = HitResult.Hit, + TaikoResult = TaikoHitResult.Great, + SecondHit = obj.IsFinisher + }); + } + + AddJudgement(new TaikoJudgementInfo + { + Result = HitResult.Hit, + TaikoResult = TaikoHitResult.Great, + SecondHit = obj.IsFinisher + }); + } + else if (obj is Bash) + { + AddJudgement(new TaikoJudgementInfo + { + Result = HitResult.Hit, + TaikoResult = TaikoHitResult.Great + }); + } + } + + maxTotalHits = totalHits; + maxComboPortion = comboPortion; + } + protected override void UpdateCalculations(TaikoJudgementInfo newJudgement) { + TaikoDrumRollTickJudgementInfo tickJudgement = newJudgement as TaikoDrumRollTickJudgementInfo; + + // Don't consider ticks as a type of hit that counts towards map completion + if (tickJudgement == null) + totalHits++; + + // Apply score changes + if (newJudgement.Result == HitResult.Hit) + { + double baseValue = newJudgement.ScoreValue; + + // Add bonus points for hitting a finisher with the second key + if (newJudgement.SecondHit) + baseValue += baseValue * finisherScoreScale; + + // Add score to portions + if (tickJudgement != null) + bonusScore += baseValue; + else + { + Combo.Value++; + + // A relevance factor that needs to be applied to make higher combos more relevant + // Value is capped at 400 combo + double comboRelevance = Math.Min(Math.Log(400, combo_base), Math.Max(0.5, Math.Log(Combo.Value, combo_base))); + + comboPortion += baseValue * comboRelevance; + } + } + + // Apply HP changes + switch (newJudgement.Result) + { + case HitResult.Miss: + // Missing ticks shouldn't drop HP + if (tickJudgement == null) + Health.Value += hpIncreaseMiss; + break; + case HitResult.Hit: + switch (newJudgement.TaikoResult) + { + case TaikoHitResult.Good: + Health.Value += hpIncreaseGood; + break; + case TaikoHitResult.Great: + // Ticks only give out a different portion of HP because they're more spammable + if (tickJudgement != null) + Health.Value += hpIncreaseTick; + else + Health.Value += hpIncreaseGreat; + break; + } + break; + } + + // Compute the new score + accuracy + int score = 0; + int maxScore = 0; + + foreach (var j in Judgements) + { + score += j.AccuracyScoreValue; + maxScore = j.MaxAccuracyScoreValue; + } + + Accuracy.Value = (double)score / maxScore; + TotalScore.Value = comboScore + accuracyScore + bonusScore; + } + + protected override void Reset() + { + base.Reset(); + + Health.Value = 0; + + bonusScore = 0; + comboPortion = 0; + totalHits = 0; } } } diff --git a/osu.Game/Modes/ScoreProcessor.cs b/osu.Game/Modes/ScoreProcessor.cs index a6e29d53e1..05e7647126 100644 --- a/osu.Game/Modes/ScoreProcessor.cs +++ b/osu.Game/Modes/ScoreProcessor.cs @@ -122,7 +122,7 @@ namespace osu.Game.Modes { Judgements.Capacity = hitRenderer.Beatmap.HitObjects.Count; - hitRenderer.OnJudgement += addJudgement; + hitRenderer.OnJudgement += AddJudgement; ComputeTargets(hitRenderer.Beatmap); @@ -139,7 +139,7 @@ namespace osu.Game.Modes /// Adds a judgement to this ScoreProcessor. /// /// The judgement to add. - private void addJudgement(TJudgement judgement) + protected void AddJudgement(TJudgement judgement) { Judgements.Add(judgement); From 8c4fd44a85785bfa2ac73f86f3487e1a850d932e Mon Sep 17 00:00:00 2001 From: Dean Herbert Date: Thu, 23 Mar 2017 19:32:58 +0900 Subject: [PATCH 03/17] Tidy up song select footer and fix depth of mod select vs osu! cookie. --- osu.Game/Screens/Select/Footer.cs | 6 +++--- osu.Game/Screens/Select/PlaySongSelect.cs | 3 +-- osu.Game/Screens/Select/SongSelect.cs | 16 ++++++++++++++-- 3 files changed, 18 insertions(+), 7 deletions(-) diff --git a/osu.Game/Screens/Select/Footer.cs b/osu.Game/Screens/Select/Footer.cs index 36030f5de4..c86ea2f30e 100644 --- a/osu.Game/Screens/Select/Footer.cs +++ b/osu.Game/Screens/Select/Footer.cs @@ -22,6 +22,8 @@ namespace osu.Game.Screens.Select private const float play_song_select_button_width = 100; private const float play_song_select_button_height = 50; + public const float HEIGHT = 50; + public const int TRANSITION_LENGTH = 300; private const float padding = 80; @@ -69,10 +71,8 @@ namespace osu.Game.Screens.Select { AlwaysReceiveInput = true; - const float bottom_tool_height = 50; - RelativeSizeAxes = Axes.X; - Height = bottom_tool_height; + Height = HEIGHT; Anchor = Anchor.BottomCentre; Origin = Anchor.BottomCentre; Children = new Drawable[] diff --git a/osu.Game/Screens/Select/PlaySongSelect.cs b/osu.Game/Screens/Select/PlaySongSelect.cs index e3a6371c27..f483aa00f7 100644 --- a/osu.Game/Screens/Select/PlaySongSelect.cs +++ b/osu.Game/Screens/Select/PlaySongSelect.cs @@ -22,12 +22,11 @@ namespace osu.Game.Screens.Select public PlaySongSelect() { - Add(modSelect = new ModSelectOverlay + FooterPanels.Add(modSelect = new ModSelectOverlay { RelativeSizeAxes = Axes.X, Origin = Anchor.BottomCentre, Anchor = Anchor.BottomCentre, - Margin = new MarginPadding { Bottom = 50 } }); LeftContent.Add(beatmapDetails = new BeatmapDetailArea diff --git a/osu.Game/Screens/Select/SongSelect.cs b/osu.Game/Screens/Select/SongSelect.cs index 1e7532b8a6..49762331c4 100644 --- a/osu.Game/Screens/Select/SongSelect.cs +++ b/osu.Game/Screens/Select/SongSelect.cs @@ -65,6 +65,12 @@ namespace osu.Game.Screens.Select /// protected readonly Footer Footer; + /// + /// Contains any panel which is triggered by a footer button. + /// Helps keep them located beneath the footer itself. + /// + protected readonly Container FooterPanels; + public readonly FilterControl FilterControl; protected SongSelect() @@ -131,11 +137,15 @@ namespace osu.Game.Screens.Select if (ShowFooter) { - Add(BeatmapOptions = new BeatmapOptionsOverlay + Add(FooterPanels = new Container { + Anchor = Anchor.BottomLeft, + Origin = Anchor.BottomLeft, + RelativeSizeAxes = Axes.X, + AutoSizeAxes = Axes.Y, Margin = new MarginPadding { - Bottom = 50, + Bottom = Footer.HEIGHT, }, }); Add(Footer = new Footer @@ -143,6 +153,8 @@ namespace osu.Game.Screens.Select OnBack = Exit, OnStart = raiseSelect, }); + + FooterPanels.Add(BeatmapOptions = new BeatmapOptionsOverlay()); } } From 63d7c5a5a3a4c8945cee57d663be920edd615964 Mon Sep 17 00:00:00 2001 From: Dean Herbert Date: Thu, 23 Mar 2017 19:35:46 +0900 Subject: [PATCH 04/17] Pressing back while mod select is visible should close mod select before exiting. --- osu.Game/Screens/Select/PlaySongSelect.cs | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/osu.Game/Screens/Select/PlaySongSelect.cs b/osu.Game/Screens/Select/PlaySongSelect.cs index f483aa00f7..fb7ed3809f 100644 --- a/osu.Game/Screens/Select/PlaySongSelect.cs +++ b/osu.Game/Screens/Select/PlaySongSelect.cs @@ -4,6 +4,7 @@ using OpenTK.Input; using osu.Framework.Allocation; using osu.Framework.Graphics; +using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Primitives; using osu.Framework.Screens; using osu.Game.Beatmaps; @@ -65,6 +66,17 @@ namespace osu.Game.Screens.Select base.OnResuming(last); } + protected override bool OnExiting(Screen next) + { + if (modSelect.State == Visibility.Visible) + { + modSelect.Hide(); + return true; + } + + return base.OnExiting(next); + } + protected override void OnSelected() { if (player != null) return; From a0c0a0fcfe8913f365bb9a869f3fddf0e8f81f55 Mon Sep 17 00:00:00 2001 From: smoogipooo Date: Thu, 23 Mar 2017 19:39:30 +0900 Subject: [PATCH 05/17] Fix post-merge errors. --- osu.Game.Modes.Taiko/TaikoScoreProcessor.cs | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/osu.Game.Modes.Taiko/TaikoScoreProcessor.cs b/osu.Game.Modes.Taiko/TaikoScoreProcessor.cs index 16934fd145..5370eab54b 100644 --- a/osu.Game.Modes.Taiko/TaikoScoreProcessor.cs +++ b/osu.Game.Modes.Taiko/TaikoScoreProcessor.cs @@ -140,11 +140,11 @@ namespace osu.Game.Modes.Taiko // 3 times bonus points for hitting a finisher with both keys with 120 finishers in the map finisherScoreScale = -7d / 90d * MathHelper.Clamp(finishers.Count, 30, 120) + 111d / 9d; - foreach (TaikoHitObject obj in beatmap.HitObjects) + foreach (var obj in beatmap.HitObjects) { if (obj is Hit) { - AddJudgement(new TaikoJudgementInfo + AddJudgement(new TaikoJudgement { Result = HitResult.Hit, TaikoResult = TaikoHitResult.Great, @@ -155,7 +155,7 @@ namespace osu.Game.Modes.Taiko { for (int i = 0; i < ((DrumRoll)obj).TotalTicks; i++) { - AddJudgement(new TaikoDrumRollTickJudgementInfo + AddJudgement(new TaikoDrumRollTickJudgement { Result = HitResult.Hit, TaikoResult = TaikoHitResult.Great, @@ -163,7 +163,7 @@ namespace osu.Game.Modes.Taiko }); } - AddJudgement(new TaikoJudgementInfo + AddJudgement(new TaikoJudgement { Result = HitResult.Hit, TaikoResult = TaikoHitResult.Great, @@ -172,7 +172,7 @@ namespace osu.Game.Modes.Taiko } else if (obj is Bash) { - AddJudgement(new TaikoJudgementInfo + AddJudgement(new TaikoJudgement { Result = HitResult.Hit, TaikoResult = TaikoHitResult.Great @@ -184,9 +184,9 @@ namespace osu.Game.Modes.Taiko maxComboPortion = comboPortion; } - protected override void UpdateCalculations(TaikoJudgementInfo newJudgement) + protected override void UpdateCalculations(TaikoJudgement newJudgement) { - TaikoDrumRollTickJudgementInfo tickJudgement = newJudgement as TaikoDrumRollTickJudgementInfo; + var tickJudgement = newJudgement as TaikoDrumRollTickJudgement; // Don't consider ticks as a type of hit that counts towards map completion if (tickJudgement == null) From c3adbb9b41412d8fc34e94d4af77f443b3baee8a Mon Sep 17 00:00:00 2001 From: smoogipooo Date: Thu, 23 Mar 2017 20:34:11 +0900 Subject: [PATCH 06/17] Fix nullref. --- osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs b/osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs index d00d6ae473..f873b7b929 100644 --- a/osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs +++ b/osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs @@ -44,7 +44,7 @@ namespace osu.Game.Modes.Taiko.Beatmaps IHasRepeats repeatsData = original as IHasRepeats; IHasEndTime endTimeData = original as IHasEndTime; - bool isFinisher = (original.Sample.Type & SampleType.Finish) > 0; + bool isFinisher = ((original.Sample?.Type ?? SampleType.None) & SampleType.Finish) > 0; if (distanceData != null) { From c52ad6c6eecd99044eee255b9ac835164cb16921 Mon Sep 17 00:00:00 2001 From: Dean Herbert Date: Thu, 23 Mar 2017 20:34:24 +0900 Subject: [PATCH 07/17] Attempt to speed up CI by excluding some file types from analysis. --- osu.sln.DotSettings | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/osu.sln.DotSettings b/osu.sln.DotSettings index f266b81ec9..a92832ec8c 100644 --- a/osu.sln.DotSettings +++ b/osu.sln.DotSettings @@ -1,4 +1,9 @@  + True + True + True + True + ExplicitlyExcluded SOLUTION WARNING WARNING From 0bcb463acf8745ebf7e7ae413dba258f701a28f1 Mon Sep 17 00:00:00 2001 From: Dean Herbert Date: Thu, 23 Mar 2017 19:22:40 +0900 Subject: [PATCH 08/17] ParallaxContainer should always know the mouse position. --- osu.Game/Graphics/Containers/ParallaxContainer.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/osu.Game/Graphics/Containers/ParallaxContainer.cs b/osu.Game/Graphics/Containers/ParallaxContainer.cs index 9dfc26dd3c..dc2f01a2bc 100644 --- a/osu.Game/Graphics/Containers/ParallaxContainer.cs +++ b/osu.Game/Graphics/Containers/ParallaxContainer.cs @@ -12,7 +12,7 @@ using osu.Framework.Configuration; namespace osu.Game.Graphics.Containers { - internal class ParallaxContainer : Container + internal class ParallaxContainer : Container, IRequireHighFrequencyMousePosition { public float ParallaxAmount = 0.02f; From 1c404cba5cd14e54e88a3835006b92642ddf7abd Mon Sep 17 00:00:00 2001 From: Dean Herbert Date: Thu, 23 Mar 2017 22:42:50 +0900 Subject: [PATCH 09/17] Update framework. --- osu-framework | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/osu-framework b/osu-framework index 34c9f17a6a..51737ec132 160000 --- a/osu-framework +++ b/osu-framework @@ -1 +1 @@ -Subproject commit 34c9f17a6ac6fa5e9fd5569f9e119331316c1313 +Subproject commit 51737ec1320b4ea9dce4978f24e1d77a28f0a98e From 2074812f4615f852b81108c21e312c7a6ef9ae97 Mon Sep 17 00:00:00 2001 From: smoogipooo Date: Fri, 24 Mar 2017 09:51:52 +0900 Subject: [PATCH 10/17] Move ScoreProcessor and Score to Scoring/. --- osu.Desktop.VisualTests/Tests/TestCaseLeaderboard.cs | 2 +- osu.Game.Modes.Catch/CatchRuleset.cs | 2 ++ .../{ => Scoring}/CatchScoreProcessor.cs | 3 ++- osu.Game.Modes.Catch/UI/CatchHitRenderer.cs | 2 ++ osu.Game.Modes.Catch/osu.Game.Modes.Catch.csproj | 2 +- osu.Game.Modes.Mania/ManiaRuleset.cs | 2 ++ .../{ => Scoring}/ManiaScoreProcessor.cs | 3 ++- osu.Game.Modes.Mania/UI/ManiaHitRenderer.cs | 2 ++ osu.Game.Modes.Mania/osu.Game.Modes.Mania.csproj | 2 +- osu.Game.Modes.Osu/Mods/OsuMod.cs | 1 + osu.Game.Modes.Osu/OsuRuleset.cs | 2 ++ osu.Game.Modes.Osu/{ => Scoring}/OsuScore.cs | 4 +++- osu.Game.Modes.Osu/{ => Scoring}/OsuScoreProcessor.cs | 3 ++- osu.Game.Modes.Osu/UI/OsuHitRenderer.cs | 2 ++ osu.Game.Modes.Osu/osu.Game.Modes.Osu.csproj | 4 ++-- .../{ => Scoring}/TaikoScoreProcessor.cs | 7 ++++--- osu.Game.Modes.Taiko/TaikoRuleset.cs | 2 ++ osu.Game.Modes.Taiko/UI/TaikoHitRenderer.cs | 2 ++ osu.Game.Modes.Taiko/osu.Game.Modes.Taiko.csproj | 2 +- osu.Game/Database/ScoreDatabase.cs | 1 + osu.Game/Modes/Mods/Mod.cs | 1 + osu.Game/Modes/Ruleset.cs | 1 + osu.Game/Modes/{ => Scoring}/Score.cs | 4 ++-- osu.Game/Modes/{ => Scoring}/ScoreProcessor.cs | 10 +++++----- osu.Game/Modes/{ => Scoring}/ScoreRank.cs | 2 +- osu.Game/Modes/UI/HitRenderer.cs | 1 + osu.Game/Modes/UI/HudOverlay.cs | 1 + osu.Game/Online/API/Requests/GetScoresRequest.cs | 2 +- osu.Game/OsuGame.cs | 1 + osu.Game/Screens/Play/Player.cs | 1 + osu.Game/Screens/Ranking/Results.cs | 2 +- osu.Game/Screens/Select/Leaderboards/DrawableRank.cs | 2 +- osu.Game/Screens/Select/Leaderboards/Leaderboard.cs | 2 +- .../Screens/Select/Leaderboards/LeaderboardScore.cs | 2 +- osu.Game/osu.Game.csproj | 6 +++--- 35 files changed, 59 insertions(+), 29 deletions(-) rename osu.Game.Modes.Catch/{ => Scoring}/CatchScoreProcessor.cs (87%) rename osu.Game.Modes.Mania/{ => Scoring}/ManiaScoreProcessor.cs (87%) rename osu.Game.Modes.Osu/{ => Scoring}/OsuScore.cs (72%) rename osu.Game.Modes.Osu/{ => Scoring}/OsuScoreProcessor.cs (92%) rename osu.Game.Modes.Taiko/{ => Scoring}/TaikoScoreProcessor.cs (96%) rename osu.Game/Modes/{ => Scoring}/Score.cs (94%) rename osu.Game/Modes/{ => Scoring}/ScoreProcessor.cs (96%) rename osu.Game/Modes/{ => Scoring}/ScoreRank.cs (90%) diff --git a/osu.Desktop.VisualTests/Tests/TestCaseLeaderboard.cs b/osu.Desktop.VisualTests/Tests/TestCaseLeaderboard.cs index cc30e3de95..329d5c5687 100644 --- a/osu.Desktop.VisualTests/Tests/TestCaseLeaderboard.cs +++ b/osu.Desktop.VisualTests/Tests/TestCaseLeaderboard.cs @@ -4,9 +4,9 @@ using OpenTK; using osu.Framework.Graphics; using osu.Framework.Screens.Testing; -using osu.Game.Modes; using osu.Game.Modes.Mods; using osu.Game.Modes.Osu.Mods; +using osu.Game.Modes.Scoring; using osu.Game.Screens.Select.Leaderboards; using osu.Game.Users; diff --git a/osu.Game.Modes.Catch/CatchRuleset.cs b/osu.Game.Modes.Catch/CatchRuleset.cs index 50224e3fdb..09d8bdb9e5 100644 --- a/osu.Game.Modes.Catch/CatchRuleset.cs +++ b/osu.Game.Modes.Catch/CatchRuleset.cs @@ -10,6 +10,8 @@ using osu.Game.Modes.Mods; using osu.Game.Modes.UI; using osu.Game.Screens.Play; using System.Collections.Generic; +using osu.Game.Modes.Catch.Scoring; +using osu.Game.Modes.Scoring; namespace osu.Game.Modes.Catch { diff --git a/osu.Game.Modes.Catch/CatchScoreProcessor.cs b/osu.Game.Modes.Catch/Scoring/CatchScoreProcessor.cs similarity index 87% rename from osu.Game.Modes.Catch/CatchScoreProcessor.cs rename to osu.Game.Modes.Catch/Scoring/CatchScoreProcessor.cs index 6563949fbc..101f442b31 100644 --- a/osu.Game.Modes.Catch/CatchScoreProcessor.cs +++ b/osu.Game.Modes.Catch/Scoring/CatchScoreProcessor.cs @@ -3,9 +3,10 @@ using osu.Game.Modes.Catch.Judgements; using osu.Game.Modes.Catch.Objects; +using osu.Game.Modes.Scoring; using osu.Game.Modes.UI; -namespace osu.Game.Modes.Catch +namespace osu.Game.Modes.Catch.Scoring { internal class CatchScoreProcessor : ScoreProcessor { diff --git a/osu.Game.Modes.Catch/UI/CatchHitRenderer.cs b/osu.Game.Modes.Catch/UI/CatchHitRenderer.cs index 751a8291d4..90bd61a39f 100644 --- a/osu.Game.Modes.Catch/UI/CatchHitRenderer.cs +++ b/osu.Game.Modes.Catch/UI/CatchHitRenderer.cs @@ -5,7 +5,9 @@ using osu.Game.Beatmaps; using osu.Game.Modes.Catch.Beatmaps; using osu.Game.Modes.Catch.Judgements; using osu.Game.Modes.Catch.Objects; +using osu.Game.Modes.Catch.Scoring; using osu.Game.Modes.Objects.Drawables; +using osu.Game.Modes.Scoring; using osu.Game.Modes.UI; namespace osu.Game.Modes.Catch.UI diff --git a/osu.Game.Modes.Catch/osu.Game.Modes.Catch.csproj b/osu.Game.Modes.Catch/osu.Game.Modes.Catch.csproj index 717e9175e4..593d8db4f6 100644 --- a/osu.Game.Modes.Catch/osu.Game.Modes.Catch.csproj +++ b/osu.Game.Modes.Catch/osu.Game.Modes.Catch.csproj @@ -50,7 +50,7 @@ - + diff --git a/osu.Game.Modes.Mania/ManiaRuleset.cs b/osu.Game.Modes.Mania/ManiaRuleset.cs index 27b3fcdf60..bd995d87d6 100644 --- a/osu.Game.Modes.Mania/ManiaRuleset.cs +++ b/osu.Game.Modes.Mania/ManiaRuleset.cs @@ -9,6 +9,8 @@ using osu.Game.Modes.Mods; using osu.Game.Modes.UI; using osu.Game.Screens.Play; using System.Collections.Generic; +using osu.Game.Modes.Mania.Scoring; +using osu.Game.Modes.Scoring; namespace osu.Game.Modes.Mania { diff --git a/osu.Game.Modes.Mania/ManiaScoreProcessor.cs b/osu.Game.Modes.Mania/Scoring/ManiaScoreProcessor.cs similarity index 87% rename from osu.Game.Modes.Mania/ManiaScoreProcessor.cs rename to osu.Game.Modes.Mania/Scoring/ManiaScoreProcessor.cs index c694717edb..72592a5278 100644 --- a/osu.Game.Modes.Mania/ManiaScoreProcessor.cs +++ b/osu.Game.Modes.Mania/Scoring/ManiaScoreProcessor.cs @@ -3,9 +3,10 @@ using osu.Game.Modes.Mania.Judgements; using osu.Game.Modes.Mania.Objects; +using osu.Game.Modes.Scoring; using osu.Game.Modes.UI; -namespace osu.Game.Modes.Mania +namespace osu.Game.Modes.Mania.Scoring { internal class ManiaScoreProcessor : ScoreProcessor { diff --git a/osu.Game.Modes.Mania/UI/ManiaHitRenderer.cs b/osu.Game.Modes.Mania/UI/ManiaHitRenderer.cs index 2a6629e25b..0415bc961a 100644 --- a/osu.Game.Modes.Mania/UI/ManiaHitRenderer.cs +++ b/osu.Game.Modes.Mania/UI/ManiaHitRenderer.cs @@ -5,7 +5,9 @@ using osu.Game.Beatmaps; using osu.Game.Modes.Mania.Beatmaps; using osu.Game.Modes.Mania.Judgements; using osu.Game.Modes.Mania.Objects; +using osu.Game.Modes.Mania.Scoring; using osu.Game.Modes.Objects.Drawables; +using osu.Game.Modes.Scoring; using osu.Game.Modes.UI; namespace osu.Game.Modes.Mania.UI diff --git a/osu.Game.Modes.Mania/osu.Game.Modes.Mania.csproj b/osu.Game.Modes.Mania/osu.Game.Modes.Mania.csproj index d9af517eee..cc925d417a 100644 --- a/osu.Game.Modes.Mania/osu.Game.Modes.Mania.csproj +++ b/osu.Game.Modes.Mania/osu.Game.Modes.Mania.csproj @@ -51,7 +51,7 @@ - + diff --git a/osu.Game.Modes.Osu/Mods/OsuMod.cs b/osu.Game.Modes.Osu/Mods/OsuMod.cs index e80975aed1..db2ee26b7a 100644 --- a/osu.Game.Modes.Osu/Mods/OsuMod.cs +++ b/osu.Game.Modes.Osu/Mods/OsuMod.cs @@ -7,6 +7,7 @@ using osu.Game.Modes.Mods; using osu.Game.Modes.Osu.Objects; using System; using System.Linq; +using osu.Game.Modes.Scoring; namespace osu.Game.Modes.Osu.Mods { diff --git a/osu.Game.Modes.Osu/OsuRuleset.cs b/osu.Game.Modes.Osu/OsuRuleset.cs index bbaf7eed5f..12df7d3f3c 100644 --- a/osu.Game.Modes.Osu/OsuRuleset.cs +++ b/osu.Game.Modes.Osu/OsuRuleset.cs @@ -12,6 +12,8 @@ using osu.Game.Modes.UI; using osu.Game.Screens.Play; using System.Collections.Generic; using System.Linq; +using osu.Game.Modes.Osu.Scoring; +using osu.Game.Modes.Scoring; namespace osu.Game.Modes.Osu { diff --git a/osu.Game.Modes.Osu/OsuScore.cs b/osu.Game.Modes.Osu/Scoring/OsuScore.cs similarity index 72% rename from osu.Game.Modes.Osu/OsuScore.cs rename to osu.Game.Modes.Osu/Scoring/OsuScore.cs index dddf826887..a0a639a59e 100644 --- a/osu.Game.Modes.Osu/OsuScore.cs +++ b/osu.Game.Modes.Osu/Scoring/OsuScore.cs @@ -1,7 +1,9 @@ // Copyright (c) 2007-2017 ppy Pty Ltd . // Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE -namespace osu.Game.Modes.Osu +using osu.Game.Modes.Scoring; + +namespace osu.Game.Modes.Osu.Scoring { internal class OsuScore : Score { diff --git a/osu.Game.Modes.Osu/OsuScoreProcessor.cs b/osu.Game.Modes.Osu/Scoring/OsuScoreProcessor.cs similarity index 92% rename from osu.Game.Modes.Osu/OsuScoreProcessor.cs rename to osu.Game.Modes.Osu/Scoring/OsuScoreProcessor.cs index f473a578bd..cdaa7b465c 100644 --- a/osu.Game.Modes.Osu/OsuScoreProcessor.cs +++ b/osu.Game.Modes.Osu/Scoring/OsuScoreProcessor.cs @@ -4,9 +4,10 @@ using osu.Game.Modes.Objects.Drawables; using osu.Game.Modes.Osu.Judgements; using osu.Game.Modes.Osu.Objects; +using osu.Game.Modes.Scoring; using osu.Game.Modes.UI; -namespace osu.Game.Modes.Osu +namespace osu.Game.Modes.Osu.Scoring { internal class OsuScoreProcessor : ScoreProcessor { diff --git a/osu.Game.Modes.Osu/UI/OsuHitRenderer.cs b/osu.Game.Modes.Osu/UI/OsuHitRenderer.cs index 18f8fbb8b9..ca9ff6fc61 100644 --- a/osu.Game.Modes.Osu/UI/OsuHitRenderer.cs +++ b/osu.Game.Modes.Osu/UI/OsuHitRenderer.cs @@ -7,6 +7,8 @@ using osu.Game.Modes.Osu.Beatmaps; using osu.Game.Modes.Osu.Judgements; using osu.Game.Modes.Osu.Objects; using osu.Game.Modes.Osu.Objects.Drawables; +using osu.Game.Modes.Osu.Scoring; +using osu.Game.Modes.Scoring; using osu.Game.Modes.UI; using osu.Game.Screens.Play; diff --git a/osu.Game.Modes.Osu/osu.Game.Modes.Osu.csproj b/osu.Game.Modes.Osu/osu.Game.Modes.Osu.csproj index a56bb799c4..55322e855e 100644 --- a/osu.Game.Modes.Osu/osu.Game.Modes.Osu.csproj +++ b/osu.Game.Modes.Osu/osu.Game.Modes.Osu.csproj @@ -72,8 +72,8 @@ - - + + diff --git a/osu.Game.Modes.Taiko/TaikoScoreProcessor.cs b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs similarity index 96% rename from osu.Game.Modes.Taiko/TaikoScoreProcessor.cs rename to osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs index 5370eab54b..2002dcb9a7 100644 --- a/osu.Game.Modes.Taiko/TaikoScoreProcessor.cs +++ b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs @@ -1,16 +1,17 @@ // Copyright (c) 2007-2017 ppy Pty Ltd . // Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE -using OpenTK; +using System; using osu.Game.Beatmaps; using osu.Game.Database; using osu.Game.Modes.Objects.Drawables; +using osu.Game.Modes.Scoring; using osu.Game.Modes.Taiko.Judgements; using osu.Game.Modes.Taiko.Objects; using osu.Game.Modes.UI; -using System; +using OpenTK; -namespace osu.Game.Modes.Taiko +namespace osu.Game.Modes.Taiko.Scoring { internal class TaikoScoreProcessor : ScoreProcessor { diff --git a/osu.Game.Modes.Taiko/TaikoRuleset.cs b/osu.Game.Modes.Taiko/TaikoRuleset.cs index ff481e9162..ce7e756e30 100644 --- a/osu.Game.Modes.Taiko/TaikoRuleset.cs +++ b/osu.Game.Modes.Taiko/TaikoRuleset.cs @@ -10,6 +10,8 @@ using osu.Game.Modes.Taiko.UI; using osu.Game.Modes.UI; using osu.Game.Screens.Play; using System.Collections.Generic; +using osu.Game.Modes.Scoring; +using osu.Game.Modes.Taiko.Scoring; namespace osu.Game.Modes.Taiko { diff --git a/osu.Game.Modes.Taiko/UI/TaikoHitRenderer.cs b/osu.Game.Modes.Taiko/UI/TaikoHitRenderer.cs index 21ee3434d3..3266b5c030 100644 --- a/osu.Game.Modes.Taiko/UI/TaikoHitRenderer.cs +++ b/osu.Game.Modes.Taiko/UI/TaikoHitRenderer.cs @@ -3,9 +3,11 @@ using osu.Game.Beatmaps; using osu.Game.Modes.Objects.Drawables; +using osu.Game.Modes.Scoring; using osu.Game.Modes.Taiko.Beatmaps; using osu.Game.Modes.Taiko.Judgements; using osu.Game.Modes.Taiko.Objects; +using osu.Game.Modes.Taiko.Scoring; using osu.Game.Modes.UI; namespace osu.Game.Modes.Taiko.UI diff --git a/osu.Game.Modes.Taiko/osu.Game.Modes.Taiko.csproj b/osu.Game.Modes.Taiko/osu.Game.Modes.Taiko.csproj index e1c10fe8f4..937c5a5e51 100644 --- a/osu.Game.Modes.Taiko/osu.Game.Modes.Taiko.csproj +++ b/osu.Game.Modes.Taiko/osu.Game.Modes.Taiko.csproj @@ -60,7 +60,7 @@ - + diff --git a/osu.Game/Database/ScoreDatabase.cs b/osu.Game/Database/ScoreDatabase.cs index cfa8e6ac7e..665ae8649e 100644 --- a/osu.Game/Database/ScoreDatabase.cs +++ b/osu.Game/Database/ScoreDatabase.cs @@ -8,6 +8,7 @@ using osu.Framework.Platform; using osu.Game.IO.Legacy; using osu.Game.IPC; using osu.Game.Modes; +using osu.Game.Modes.Scoring; using SharpCompress.Compressors.LZMA; namespace osu.Game.Database diff --git a/osu.Game/Modes/Mods/Mod.cs b/osu.Game/Modes/Mods/Mod.cs index 6a720a3574..8416ae6211 100644 --- a/osu.Game/Modes/Mods/Mod.cs +++ b/osu.Game/Modes/Mods/Mod.cs @@ -6,6 +6,7 @@ using osu.Game.Graphics; using osu.Game.Modes.Objects; using osu.Game.Modes.UI; using System; +using osu.Game.Modes.Scoring; namespace osu.Game.Modes.Mods { diff --git a/osu.Game/Modes/Ruleset.cs b/osu.Game/Modes/Ruleset.cs index 886b49f26b..c97420fbe3 100644 --- a/osu.Game/Modes/Ruleset.cs +++ b/osu.Game/Modes/Ruleset.cs @@ -9,6 +9,7 @@ using osu.Game.Screens.Play; using System; using System.Collections.Concurrent; using System.Collections.Generic; +using osu.Game.Modes.Scoring; namespace osu.Game.Modes { diff --git a/osu.Game/Modes/Score.cs b/osu.Game/Modes/Scoring/Score.cs similarity index 94% rename from osu.Game/Modes/Score.cs rename to osu.Game/Modes/Scoring/Score.cs index 55bbed8e77..fa74fba279 100644 --- a/osu.Game/Modes/Score.cs +++ b/osu.Game/Modes/Scoring/Score.cs @@ -3,11 +3,11 @@ using System; using Newtonsoft.Json; -using osu.Game.Users; using osu.Game.Database; using osu.Game.Modes.Mods; +using osu.Game.Users; -namespace osu.Game.Modes +namespace osu.Game.Modes.Scoring { public class Score { diff --git a/osu.Game/Modes/ScoreProcessor.cs b/osu.Game/Modes/Scoring/ScoreProcessor.cs similarity index 96% rename from osu.Game/Modes/ScoreProcessor.cs rename to osu.Game/Modes/Scoring/ScoreProcessor.cs index 488f484163..d881d830fa 100644 --- a/osu.Game/Modes/ScoreProcessor.cs +++ b/osu.Game/Modes/Scoring/ScoreProcessor.cs @@ -1,15 +1,15 @@ // Copyright (c) 2007-2017 ppy Pty Ltd . // Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE -using osu.Framework.Configuration; using System; using System.Collections.Generic; -using osu.Game.Modes.Judgements; -using osu.Game.Modes.UI; -using osu.Game.Modes.Objects; +using osu.Framework.Configuration; using osu.Game.Beatmaps; +using osu.Game.Modes.Judgements; +using osu.Game.Modes.Objects; +using osu.Game.Modes.UI; -namespace osu.Game.Modes +namespace osu.Game.Modes.Scoring { public abstract class ScoreProcessor { diff --git a/osu.Game/Modes/ScoreRank.cs b/osu.Game/Modes/Scoring/ScoreRank.cs similarity index 90% rename from osu.Game/Modes/ScoreRank.cs rename to osu.Game/Modes/Scoring/ScoreRank.cs index 433158f249..743f24ecd6 100644 --- a/osu.Game/Modes/ScoreRank.cs +++ b/osu.Game/Modes/Scoring/ScoreRank.cs @@ -3,7 +3,7 @@ using System.ComponentModel; -namespace osu.Game.Modes +namespace osu.Game.Modes.Scoring { public enum ScoreRank { diff --git a/osu.Game/Modes/UI/HitRenderer.cs b/osu.Game/Modes/UI/HitRenderer.cs index d53c65ec16..3d108b895d 100644 --- a/osu.Game/Modes/UI/HitRenderer.cs +++ b/osu.Game/Modes/UI/HitRenderer.cs @@ -14,6 +14,7 @@ using System; using System.Collections.Generic; using System.Diagnostics; using System.Linq; +using osu.Game.Modes.Scoring; namespace osu.Game.Modes.UI { diff --git a/osu.Game/Modes/UI/HudOverlay.cs b/osu.Game/Modes/UI/HudOverlay.cs index 4b454797ce..a6c54e7f3a 100644 --- a/osu.Game/Modes/UI/HudOverlay.cs +++ b/osu.Game/Modes/UI/HudOverlay.cs @@ -9,6 +9,7 @@ using osu.Game.Configuration; using osu.Game.Graphics.UserInterface; using osu.Game.Screens.Play; using System; +using osu.Game.Modes.Scoring; namespace osu.Game.Modes.UI { diff --git a/osu.Game/Online/API/Requests/GetScoresRequest.cs b/osu.Game/Online/API/Requests/GetScoresRequest.cs index 8c0fc4383a..66c5e6c72d 100644 --- a/osu.Game/Online/API/Requests/GetScoresRequest.cs +++ b/osu.Game/Online/API/Requests/GetScoresRequest.cs @@ -5,7 +5,7 @@ using System.Collections.Generic; using Newtonsoft.Json; using osu.Framework.IO.Network; using osu.Game.Database; -using osu.Game.Modes; +using osu.Game.Modes.Scoring; namespace osu.Game.Online.API.Requests { diff --git a/osu.Game/OsuGame.cs b/osu.Game/OsuGame.cs index 1fca318149..8ac809e591 100644 --- a/osu.Game/OsuGame.cs +++ b/osu.Game/OsuGame.cs @@ -26,6 +26,7 @@ using osu.Framework.Graphics.Primitives; using System.Threading.Tasks; using osu.Framework.Threading; using osu.Game.Graphics; +using osu.Game.Modes.Scoring; using osu.Game.Overlays.Notifications; using osu.Game.Screens.Play; diff --git a/osu.Game/Screens/Play/Player.cs b/osu.Game/Screens/Play/Player.cs index ddd963da00..702f907428 100644 --- a/osu.Game/Screens/Play/Player.cs +++ b/osu.Game/Screens/Play/Player.cs @@ -23,6 +23,7 @@ using osu.Game.Screens.Backgrounds; using osu.Game.Screens.Ranking; using System; using System.Linq; +using osu.Game.Modes.Scoring; namespace osu.Game.Screens.Play { diff --git a/osu.Game/Screens/Ranking/Results.cs b/osu.Game/Screens/Ranking/Results.cs index 2df654b889..daf0866d10 100644 --- a/osu.Game/Screens/Ranking/Results.cs +++ b/osu.Game/Screens/Ranking/Results.cs @@ -6,7 +6,7 @@ using osu.Framework.Graphics; using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Transforms; using osu.Game.Graphics.Sprites; -using osu.Game.Modes; +using osu.Game.Modes.Scoring; using osu.Game.Screens.Backgrounds; using OpenTK; using OpenTK.Graphics; diff --git a/osu.Game/Screens/Select/Leaderboards/DrawableRank.cs b/osu.Game/Screens/Select/Leaderboards/DrawableRank.cs index 9e73148ada..6b59af0bb4 100644 --- a/osu.Game/Screens/Select/Leaderboards/DrawableRank.cs +++ b/osu.Game/Screens/Select/Leaderboards/DrawableRank.cs @@ -6,8 +6,8 @@ using osu.Framework.Graphics; using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Sprites; using osu.Framework.Graphics.Textures; -using osu.Game.Modes; using osu.Framework.Extensions; +using osu.Game.Modes.Scoring; namespace osu.Game.Screens.Select.Leaderboards { diff --git a/osu.Game/Screens/Select/Leaderboards/Leaderboard.cs b/osu.Game/Screens/Select/Leaderboards/Leaderboard.cs index 4ce40cb943..12ff096d16 100644 --- a/osu.Game/Screens/Select/Leaderboards/Leaderboard.cs +++ b/osu.Game/Screens/Select/Leaderboards/Leaderboard.cs @@ -9,8 +9,8 @@ using osu.Framework.Graphics; using osu.Framework.Graphics.Colour; using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Primitives; -using osu.Game.Modes; using System; +using osu.Game.Modes.Scoring; namespace osu.Game.Screens.Select.Leaderboards { diff --git a/osu.Game/Screens/Select/Leaderboards/LeaderboardScore.cs b/osu.Game/Screens/Select/Leaderboards/LeaderboardScore.cs index d32f3a497a..1df6d2b55c 100644 --- a/osu.Game/Screens/Select/Leaderboards/LeaderboardScore.cs +++ b/osu.Game/Screens/Select/Leaderboards/LeaderboardScore.cs @@ -10,11 +10,11 @@ using osu.Framework.Graphics.Sprites; using osu.Framework.Graphics.Transforms; using osu.Game.Graphics; using osu.Game.Graphics.Sprites; -using osu.Game.Modes; using osu.Framework.Extensions.Color4Extensions; using osu.Game.Modes.Mods; using osu.Game.Users; using osu.Framework; +using osu.Game.Modes.Scoring; namespace osu.Game.Screens.Select.Leaderboards { diff --git a/osu.Game/osu.Game.csproj b/osu.Game/osu.Game.csproj index bcae668e9f..989e605c16 100644 --- a/osu.Game/osu.Game.csproj +++ b/osu.Game/osu.Game.csproj @@ -124,8 +124,8 @@ - - + + @@ -359,7 +359,7 @@ - + From 4e31e3b4439fe4658bb30abe849593bf44ceabf2 Mon Sep 17 00:00:00 2001 From: smoogipooo Date: Fri, 24 Mar 2017 09:50:18 +0900 Subject: [PATCH 11/17] Rename things around to make a bit more sense. --- .../Judgements/CatchJudgement.cs | 4 +-- .../Judgements/ManiaJudgement.cs | 4 +-- osu.Game.Modes.Osu/Judgements/OsuJudgement.cs | 4 +-- .../Judgements/TaikoDrumRollTickJudgement.cs | 4 +-- .../Judgements/TaikoJudgement.cs | 36 +++++++++---------- .../Scoring/TaikoScoreProcessor.cs | 12 +++---- .../Modes/Judgements/DrawableJudgement.cs | 4 +-- osu.Game/Modes/Judgements/Judgement.cs | 8 ++--- 8 files changed, 38 insertions(+), 38 deletions(-) diff --git a/osu.Game.Modes.Catch/Judgements/CatchJudgement.cs b/osu.Game.Modes.Catch/Judgements/CatchJudgement.cs index 8e18c68153..eaacedd7e0 100644 --- a/osu.Game.Modes.Catch/Judgements/CatchJudgement.cs +++ b/osu.Game.Modes.Catch/Judgements/CatchJudgement.cs @@ -7,8 +7,8 @@ namespace osu.Game.Modes.Catch.Judgements { public class CatchJudgement : Judgement { - public override string ScoreString => string.Empty; + public override string ResultString => string.Empty; - public override string MaxScoreString => string.Empty; + public override string MaxResultString => string.Empty; } } diff --git a/osu.Game.Modes.Mania/Judgements/ManiaJudgement.cs b/osu.Game.Modes.Mania/Judgements/ManiaJudgement.cs index 07c5fcbfef..3ef5b0f29b 100644 --- a/osu.Game.Modes.Mania/Judgements/ManiaJudgement.cs +++ b/osu.Game.Modes.Mania/Judgements/ManiaJudgement.cs @@ -7,8 +7,8 @@ namespace osu.Game.Modes.Mania.Judgements { public class ManiaJudgement : Judgement { - public override string ScoreString => string.Empty; + public override string ResultString => string.Empty; - public override string MaxScoreString => string.Empty; + public override string MaxResultString => string.Empty; } } diff --git a/osu.Game.Modes.Osu/Judgements/OsuJudgement.cs b/osu.Game.Modes.Osu/Judgements/OsuJudgement.cs index bbb1754ce6..e65d3dde3a 100644 --- a/osu.Game.Modes.Osu/Judgements/OsuJudgement.cs +++ b/osu.Game.Modes.Osu/Judgements/OsuJudgement.cs @@ -25,9 +25,9 @@ namespace osu.Game.Modes.Osu.Judgements /// public OsuScoreResult MaxScore = OsuScoreResult.Hit300; - public override string ScoreString => Score.GetDescription(); + public override string ResultString => Score.GetDescription(); - public override string MaxScoreString => MaxScore.GetDescription(); + public override string MaxResultString => MaxScore.GetDescription(); public int ScoreValue => scoreToInt(Score); diff --git a/osu.Game.Modes.Taiko/Judgements/TaikoDrumRollTickJudgement.cs b/osu.Game.Modes.Taiko/Judgements/TaikoDrumRollTickJudgement.cs index 7faf9db02f..b6a727aeb4 100644 --- a/osu.Game.Modes.Taiko/Judgements/TaikoDrumRollTickJudgement.cs +++ b/osu.Game.Modes.Taiko/Judgements/TaikoDrumRollTickJudgement.cs @@ -8,12 +8,12 @@ namespace osu.Game.Modes.Taiko.Judgements /// /// Drum roll ticks don't display judgement text. /// - public override string ScoreString => string.Empty; + public override string ResultString => string.Empty; /// /// Drum roll ticks don't display judgement text. /// - public override string MaxScoreString => string.Empty; + public override string MaxResultString => string.Empty; protected override int NumericResultForScore(TaikoHitResult result) { diff --git a/osu.Game.Modes.Taiko/Judgements/TaikoJudgement.cs b/osu.Game.Modes.Taiko/Judgements/TaikoJudgement.cs index d715fd0183..e50a685e24 100644 --- a/osu.Game.Modes.Taiko/Judgements/TaikoJudgement.cs +++ b/osu.Game.Modes.Taiko/Judgements/TaikoJudgement.cs @@ -9,38 +9,38 @@ namespace osu.Game.Modes.Taiko.Judgements public class TaikoJudgement : Judgement { /// - /// The maximum score value. + /// The maximum result. /// public const TaikoHitResult MAX_HIT_RESULT = TaikoHitResult.Great; /// - /// The score value. + /// The result. /// public TaikoHitResult TaikoResult; /// - /// The score value for the combo portion of the score. + /// The result value for the combo portion of the score. /// - public int ScoreValue => NumericResultForScore(TaikoResult); + public int ResultValueForScore => NumericResultForScore(TaikoResult); /// - /// The score value for the accuracy portion of the score. + /// The result value for the accuracy portion of the score. /// - public int AccuracyScoreValue => NumericResultForAccuracy(TaikoResult); + public int ResultValueForAccuracy => NumericResultForAccuracy(TaikoResult); /// - /// The maximum score value for the combo portion of the score. + /// The maximum result value for the combo portion of the score. /// - public int MaxScoreValue => NumericResultForScore(MAX_HIT_RESULT); + public int MaxResultValueForScore => NumericResultForScore(MAX_HIT_RESULT); /// - /// The maximum score value for the accuracy portion of the score. + /// The maximum result value for the accuracy portion of the score. /// - public int MaxAccuracyScoreValue => NumericResultForAccuracy(MAX_HIT_RESULT); + public int MaxResultValueForAccuracy => NumericResultForAccuracy(MAX_HIT_RESULT); - public override string ScoreString => TaikoResult.GetDescription(); + public override string ResultString => TaikoResult.GetDescription(); - public override string MaxScoreString => MAX_HIT_RESULT.GetDescription(); + public override string MaxResultString => MAX_HIT_RESULT.GetDescription(); /// /// Whether this Judgement has a secondary hit in the case of finishers. @@ -48,11 +48,11 @@ namespace osu.Game.Modes.Taiko.Judgements public bool SecondHit; /// - /// Computes the numeric score value for the combo portion of the score. + /// Computes the numeric result value for the combo portion of the score. /// For the accuracy portion of the score (including accuracy percentage), see . /// - /// The result to compute the score value for. - /// The numeric score value. + /// The result to compute the value for. + /// The numeric result value. protected virtual int NumericResultForScore(TaikoHitResult result) { switch (result) @@ -67,11 +67,11 @@ namespace osu.Game.Modes.Taiko.Judgements } /// - /// Computes the numeric score value for the accuracy portion of the score. + /// Computes the numeric result value for the accuracy portion of the score. /// For the combo portion of the score, see . /// - /// The result to compute the score value for. - /// The numeric score value. + /// The result to compute the value for. + /// The numeric result value. protected virtual int NumericResultForAccuracy(TaikoHitResult result) { switch (result) diff --git a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs index 2002dcb9a7..acf739d137 100644 --- a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs +++ b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs @@ -196,7 +196,7 @@ namespace osu.Game.Modes.Taiko.Scoring // Apply score changes if (newJudgement.Result == HitResult.Hit) { - double baseValue = newJudgement.ScoreValue; + double baseValue = newJudgement.ResultValueForScore; // Add bonus points for hitting a finisher with the second key if (newJudgement.SecondHit) @@ -243,16 +243,16 @@ namespace osu.Game.Modes.Taiko.Scoring } // Compute the new score + accuracy - int score = 0; - int maxScore = 0; + int scoreForAccuracy = 0; + int maxScoreForAccuracy = 0; foreach (var j in Judgements) { - score += j.AccuracyScoreValue; - maxScore = j.MaxAccuracyScoreValue; + scoreForAccuracy += j.ResultValueForAccuracy; + maxScoreForAccuracy = j.MaxResultValueForAccuracy; } - Accuracy.Value = (double)score / maxScore; + Accuracy.Value = (double)scoreForAccuracy / maxScoreForAccuracy; TotalScore.Value = comboScore + accuracyScore + bonusScore; } diff --git a/osu.Game/Modes/Judgements/DrawableJudgement.cs b/osu.Game/Modes/Judgements/DrawableJudgement.cs index ef67d07310..76c73335dd 100644 --- a/osu.Game/Modes/Judgements/DrawableJudgement.cs +++ b/osu.Game/Modes/Judgements/DrawableJudgement.cs @@ -35,7 +35,7 @@ namespace osu.Game.Modes.Judgements AutoSizeAxes = Axes.Both; - string scoreString = judgement.Result == HitResult.Hit ? judgement.ScoreString : judgement.Result.GetDescription(); + string resultString = judgement.Result == HitResult.Hit ? judgement.ResultString : judgement.Result.GetDescription(); Children = new[] { @@ -43,7 +43,7 @@ namespace osu.Game.Modes.Judgements { Origin = Anchor.Centre, Anchor = Anchor.Centre, - Text = scoreString.ToUpper(), + Text = resultString.ToUpper(), Font = @"Venera", TextSize = 16 } diff --git a/osu.Game/Modes/Judgements/Judgement.cs b/osu.Game/Modes/Judgements/Judgement.cs index 45f40647ca..d916fc15de 100644 --- a/osu.Game/Modes/Judgements/Judgement.cs +++ b/osu.Game/Modes/Judgements/Judgement.cs @@ -23,13 +23,13 @@ namespace osu.Game.Modes.Judgements public ulong? ComboAtHit; /// - /// The string representation for the score achieved. + /// The string representation for the result achieved. /// - public abstract string ScoreString { get; } + public abstract string ResultString { get; } /// - /// The string representation for the max score achievable. + /// The string representation for the max result achievable. /// - public abstract string MaxScoreString { get; } + public abstract string MaxResultString { get; } } } \ No newline at end of file From afdb719c60b75b12326de03ea50c453e1bdd8b19 Mon Sep 17 00:00:00 2001 From: smoogipooo Date: Fri, 24 Mar 2017 11:09:01 +0900 Subject: [PATCH 12/17] Rename finisher -> accented. --- osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs | 8 ++++---- osu.Game.Modes.Taiko/Objects/TaikoHitObject.cs | 5 +++-- osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs | 8 ++++---- 3 files changed, 11 insertions(+), 10 deletions(-) diff --git a/osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs b/osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs index f873b7b929..b2676bf28a 100644 --- a/osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs +++ b/osu.Game.Modes.Taiko/Beatmaps/TaikoBeatmapConverter.cs @@ -44,7 +44,7 @@ namespace osu.Game.Modes.Taiko.Beatmaps IHasRepeats repeatsData = original as IHasRepeats; IHasEndTime endTimeData = original as IHasEndTime; - bool isFinisher = ((original.Sample?.Type ?? SampleType.None) & SampleType.Finish) > 0; + bool accented = ((original.Sample?.Type ?? SampleType.None) & SampleType.Finish) > 0; if (distanceData != null) { @@ -52,7 +52,7 @@ namespace osu.Game.Modes.Taiko.Beatmaps { StartTime = original.StartTime, Sample = original.Sample, - IsFinisher = isFinisher, + Accented = accented, Distance = distanceData.Distance * (repeatsData?.RepeatCount ?? 1) }; @@ -65,7 +65,7 @@ namespace osu.Game.Modes.Taiko.Beatmaps { StartTime = original.StartTime, Sample = original.Sample, - IsFinisher = isFinisher, + Accented = accented, EndTime = original.StartTime + endTimeData.Duration * bash_convert_factor }; @@ -75,7 +75,7 @@ namespace osu.Game.Modes.Taiko.Beatmaps { StartTime = original.StartTime, Sample = original.Sample, - IsFinisher = isFinisher + Accented = accented }; } } diff --git a/osu.Game.Modes.Taiko/Objects/TaikoHitObject.cs b/osu.Game.Modes.Taiko/Objects/TaikoHitObject.cs index a27d842053..0ec1c2b93c 100644 --- a/osu.Game.Modes.Taiko/Objects/TaikoHitObject.cs +++ b/osu.Game.Modes.Taiko/Objects/TaikoHitObject.cs @@ -20,9 +20,10 @@ namespace osu.Game.Modes.Taiko.Objects public double PreEmpt; /// - /// Whether this HitObject is a finisher. + /// Whether this HitObject is accented. + /// Accented hit objects give more points for hitting the hit object with both keys. /// - public bool IsFinisher; + public bool Accented; /// /// Whether this HitObject is in Kiai time. diff --git a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs index acf739d137..944da3244d 100644 --- a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs +++ b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs @@ -134,7 +134,7 @@ namespace osu.Game.Modes.Taiko.Scoring hpIncreaseGood = hpMultiplierNormal * BeatmapDifficulty.DifficultyRange(beatmap.BeatmapInfo.Difficulty.DrainRate, hp_hit_good_max, hp_hit_good, hp_hit_good); hpIncreaseMiss = BeatmapDifficulty.DifficultyRange(beatmap.BeatmapInfo.Difficulty.DrainRate, hp_miss_min, hp_miss_mid, hp_miss_max); - var finishers = beatmap.HitObjects.FindAll(o => o is Hit && o.IsFinisher); + var finishers = beatmap.HitObjects.FindAll(o => o is Hit && o.Accented); // This is a linear function that awards: // 10 times bonus points for hitting a finisher with both keys with 30 finishers in the map @@ -149,7 +149,7 @@ namespace osu.Game.Modes.Taiko.Scoring { Result = HitResult.Hit, TaikoResult = TaikoHitResult.Great, - SecondHit = obj.IsFinisher + SecondHit = obj.Accented }); } else if (obj is DrumRoll) @@ -160,7 +160,7 @@ namespace osu.Game.Modes.Taiko.Scoring { Result = HitResult.Hit, TaikoResult = TaikoHitResult.Great, - SecondHit = obj.IsFinisher + SecondHit = obj.Accented }); } @@ -168,7 +168,7 @@ namespace osu.Game.Modes.Taiko.Scoring { Result = HitResult.Hit, TaikoResult = TaikoHitResult.Great, - SecondHit = obj.IsFinisher + SecondHit = obj.Accented }); } else if (obj is Bash) From 4ae45ea8668c8fe971f1bbc3907b947d5d767e84 Mon Sep 17 00:00:00 2001 From: smoogipooo Date: Fri, 24 Mar 2017 11:15:22 +0900 Subject: [PATCH 13/17] Final -> cumulative, to represent a growing score. --- osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs index 944da3244d..8399858cac 100644 --- a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs +++ b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs @@ -85,17 +85,17 @@ namespace osu.Game.Modes.Taiko.Scoring public override bool HasFailed => totalHits == maxTotalHits && Health.Value <= 0.5; /// - /// The final combo portion of the score. + /// The cumulative combo portion of the score. /// private double comboScore => combo_portion_max * comboPortion / maxComboPortion; /// - /// The final accuracy portion of the score. + /// The cumulative accuracy portion of the score. /// private double accuracyScore => accuracy_portion_max * Math.Pow(Accuracy, 3.6) * totalHits / maxTotalHits; /// - /// The final bonus score. + /// The cumulative bonus score. /// This is added on top of , thus the total score can exceed . /// private double bonusScore; From a1f5bc04aac3d2146f396998e610ec89b6374b23 Mon Sep 17 00:00:00 2001 From: smoogipooo Date: Fri, 24 Mar 2017 11:24:07 +0900 Subject: [PATCH 14/17] Use isTick. --- osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs index 8399858cac..33db88bdde 100644 --- a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs +++ b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs @@ -187,10 +187,10 @@ namespace osu.Game.Modes.Taiko.Scoring protected override void UpdateCalculations(TaikoJudgement newJudgement) { - var tickJudgement = newJudgement as TaikoDrumRollTickJudgement; + bool isTick = newJudgement is TaikoDrumRollTickJudgement; // Don't consider ticks as a type of hit that counts towards map completion - if (tickJudgement == null) + if (!isTick) totalHits++; // Apply score changes @@ -203,7 +203,7 @@ namespace osu.Game.Modes.Taiko.Scoring baseValue += baseValue * finisherScoreScale; // Add score to portions - if (tickJudgement != null) + if (isTick) bonusScore += baseValue; else { @@ -222,7 +222,7 @@ namespace osu.Game.Modes.Taiko.Scoring { case HitResult.Miss: // Missing ticks shouldn't drop HP - if (tickJudgement == null) + if (!isTick) Health.Value += hpIncreaseMiss; break; case HitResult.Hit: @@ -232,8 +232,7 @@ namespace osu.Game.Modes.Taiko.Scoring Health.Value += hpIncreaseGood; break; case TaikoHitResult.Great: - // Ticks only give out a different portion of HP because they're more spammable - if (tickJudgement != null) + if (isTick) Health.Value += hpIncreaseTick; else Health.Value += hpIncreaseGreat; From 5e34c2497afe976384c557354d337eb6c1022249 Mon Sep 17 00:00:00 2001 From: smoogipooo Date: Fri, 24 Mar 2017 11:24:31 +0900 Subject: [PATCH 15/17] More accented renaming + improve comments. --- .../Scoring/TaikoScoreProcessor.cs | 37 +++++++++++-------- 1 file changed, 21 insertions(+), 16 deletions(-) diff --git a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs index 33db88bdde..e43acfa4ae 100644 --- a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs +++ b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs @@ -42,31 +42,36 @@ namespace osu.Game.Modes.Taiko.Scoring private const double hp_hit_great = 0.03; /// - /// The HP awarded for a hit at HP >= 5. + /// The minimum HP awarded for a hit. + /// This occurs when HP Drain >= 5. /// - private const double hp_hit_good = 0.011; + private const double hp_hit_good_min = 0.011; /// - /// The HP awarded for a hit at HP = 0. + /// The maximum HP awarded for a hit. + /// This occurs when HP Drain = 0. /// /// Yes, this is incorrect, and goods at HP = 0 will award more HP than greats. /// This is legacy and should be fixed, but is kept as is for now for compatibility. /// /// - private const double hp_hit_good_max = hp_hit_good * 8; + private const double hp_hit_good_max = hp_hit_good_min * 8; /// - /// The HP deducted for a at HP = 0. + /// The minimum HP deducted for a . + /// This occurs when HP Drain = 0. /// private const double hp_miss_min = -0.0018; /// - /// The HP deducted for a at HP = 5. + /// The median HP deducted for a . + /// This occurs when HP Drain = 5. /// private const double hp_miss_mid = -0.0075; /// - /// The HP deducted for a at HP = 10. + /// The maximum HP deducted for a . + /// This occurs when HP Drain = 10. /// private const double hp_miss_max = -0.12; @@ -102,9 +107,9 @@ namespace osu.Game.Modes.Taiko.Scoring /// /// The multiple of the original score added to the combo portion of the score - /// for correctly hitting a finisher with both keys. + /// for correctly hitting an accented hit object with both keys. /// - private double finisherScoreScale; + private double accentedHitScale; private double hpIncreaseTick; private double hpIncreaseGreat; @@ -131,15 +136,15 @@ namespace osu.Game.Modes.Taiko.Scoring hpIncreaseTick = hp_hit_tick; hpIncreaseGreat = hpMultiplierNormal * hp_hit_great; - hpIncreaseGood = hpMultiplierNormal * BeatmapDifficulty.DifficultyRange(beatmap.BeatmapInfo.Difficulty.DrainRate, hp_hit_good_max, hp_hit_good, hp_hit_good); + hpIncreaseGood = hpMultiplierNormal * BeatmapDifficulty.DifficultyRange(beatmap.BeatmapInfo.Difficulty.DrainRate, hp_hit_good_max, hp_hit_good_min, hp_hit_good_min); hpIncreaseMiss = BeatmapDifficulty.DifficultyRange(beatmap.BeatmapInfo.Difficulty.DrainRate, hp_miss_min, hp_miss_mid, hp_miss_max); - var finishers = beatmap.HitObjects.FindAll(o => o is Hit && o.Accented); + var accentedHits = beatmap.HitObjects.FindAll(o => o is Hit && o.Accented); // This is a linear function that awards: - // 10 times bonus points for hitting a finisher with both keys with 30 finishers in the map - // 3 times bonus points for hitting a finisher with both keys with 120 finishers in the map - finisherScoreScale = -7d / 90d * MathHelper.Clamp(finishers.Count, 30, 120) + 111d / 9d; + // 10 times bonus points for hitting an accented hit object with both keys with 30 accented hit objects in the map + // 3 times bonus points for hitting an accented hit object with both keys with 120 accented hit objects in the map + accentedHitScale = -7d / 90d * MathHelper.Clamp(accentedHits.Count, 30, 120) + 111d / 9d; foreach (var obj in beatmap.HitObjects) { @@ -198,9 +203,9 @@ namespace osu.Game.Modes.Taiko.Scoring { double baseValue = newJudgement.ResultValueForScore; - // Add bonus points for hitting a finisher with the second key + // Add bonus points for hitting an accented hit object with the second key if (newJudgement.SecondHit) - baseValue += baseValue * finisherScoreScale; + baseValue += baseValue * accentedHitScale; // Add score to portions if (isTick) From 59ba497952669302b2b3b64f19b2750119e2ae07 Mon Sep 17 00:00:00 2001 From: smoogipooo Date: Fri, 24 Mar 2017 11:28:52 +0900 Subject: [PATCH 16/17] Remove linear interpolation of hp_hit_good. I think this is an okay compromise because hp_hit_great doesn't use linear interpolation here. I am tentative on this change, but I need to code up the rest of taiko before I can test this further. --- .../Scoring/TaikoScoreProcessor.cs | 17 +++-------------- 1 file changed, 3 insertions(+), 14 deletions(-) diff --git a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs index e43acfa4ae..698a617bdc 100644 --- a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs +++ b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs @@ -42,20 +42,9 @@ namespace osu.Game.Modes.Taiko.Scoring private const double hp_hit_great = 0.03; /// - /// The minimum HP awarded for a hit. - /// This occurs when HP Drain >= 5. + /// The HP awarded for a hit. /// - private const double hp_hit_good_min = 0.011; - - /// - /// The maximum HP awarded for a hit. - /// This occurs when HP Drain = 0. - /// - /// Yes, this is incorrect, and goods at HP = 0 will award more HP than greats. - /// This is legacy and should be fixed, but is kept as is for now for compatibility. - /// - /// - private const double hp_hit_good_max = hp_hit_good_min * 8; + private const double hp_hit_good = 0.011; /// /// The minimum HP deducted for a . @@ -136,7 +125,7 @@ namespace osu.Game.Modes.Taiko.Scoring hpIncreaseTick = hp_hit_tick; hpIncreaseGreat = hpMultiplierNormal * hp_hit_great; - hpIncreaseGood = hpMultiplierNormal * BeatmapDifficulty.DifficultyRange(beatmap.BeatmapInfo.Difficulty.DrainRate, hp_hit_good_max, hp_hit_good_min, hp_hit_good_min); + hpIncreaseGood = hpMultiplierNormal * hp_hit_good; hpIncreaseMiss = BeatmapDifficulty.DifficultyRange(beatmap.BeatmapInfo.Difficulty.DrainRate, hp_miss_min, hp_miss_mid, hp_miss_max); var accentedHits = beatmap.HitObjects.FindAll(o => o is Hit && o.Accented); From 2a6da0751da6f82be6c1c1062db13427df4d41aa Mon Sep 17 00:00:00 2001 From: smoogipooo Date: Fri, 24 Mar 2017 11:32:48 +0900 Subject: [PATCH 17/17] Rename UpdateJudgement -> OnNewJugement + rename judgement parameter. --- .../Scoring/CatchScoreProcessor.cs | 2 +- .../Scoring/ManiaScoreProcessor.cs | 2 +- osu.Game.Modes.Osu/Scoring/OsuScoreProcessor.cs | 2 +- .../Scoring/TaikoScoreProcessor.cs | 14 +++++++------- osu.Game/Modes/Scoring/ScoreProcessor.cs | 6 +++--- 5 files changed, 13 insertions(+), 13 deletions(-) diff --git a/osu.Game.Modes.Catch/Scoring/CatchScoreProcessor.cs b/osu.Game.Modes.Catch/Scoring/CatchScoreProcessor.cs index 101f442b31..766a492bf4 100644 --- a/osu.Game.Modes.Catch/Scoring/CatchScoreProcessor.cs +++ b/osu.Game.Modes.Catch/Scoring/CatchScoreProcessor.cs @@ -19,7 +19,7 @@ namespace osu.Game.Modes.Catch.Scoring { } - protected override void UpdateCalculations(CatchJudgement newJudgement) + protected override void OnNewJugement(CatchJudgement judgement) { } } diff --git a/osu.Game.Modes.Mania/Scoring/ManiaScoreProcessor.cs b/osu.Game.Modes.Mania/Scoring/ManiaScoreProcessor.cs index 72592a5278..c6b223af6d 100644 --- a/osu.Game.Modes.Mania/Scoring/ManiaScoreProcessor.cs +++ b/osu.Game.Modes.Mania/Scoring/ManiaScoreProcessor.cs @@ -19,7 +19,7 @@ namespace osu.Game.Modes.Mania.Scoring { } - protected override void UpdateCalculations(ManiaJudgement newJudgement) + protected override void OnNewJugement(ManiaJudgement judgement) { } } diff --git a/osu.Game.Modes.Osu/Scoring/OsuScoreProcessor.cs b/osu.Game.Modes.Osu/Scoring/OsuScoreProcessor.cs index cdaa7b465c..b71e7dbadd 100644 --- a/osu.Game.Modes.Osu/Scoring/OsuScoreProcessor.cs +++ b/osu.Game.Modes.Osu/Scoring/OsuScoreProcessor.cs @@ -28,7 +28,7 @@ namespace osu.Game.Modes.Osu.Scoring Accuracy.Value = 1; } - protected override void UpdateCalculations(OsuJudgement judgement) + protected override void OnNewJugement(OsuJudgement judgement) { if (judgement != null) { diff --git a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs index 698a617bdc..3007411230 100644 --- a/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs +++ b/osu.Game.Modes.Taiko/Scoring/TaikoScoreProcessor.cs @@ -179,21 +179,21 @@ namespace osu.Game.Modes.Taiko.Scoring maxComboPortion = comboPortion; } - protected override void UpdateCalculations(TaikoJudgement newJudgement) + protected override void OnNewJugement(TaikoJudgement judgement) { - bool isTick = newJudgement is TaikoDrumRollTickJudgement; + bool isTick = judgement is TaikoDrumRollTickJudgement; // Don't consider ticks as a type of hit that counts towards map completion if (!isTick) totalHits++; // Apply score changes - if (newJudgement.Result == HitResult.Hit) + if (judgement.Result == HitResult.Hit) { - double baseValue = newJudgement.ResultValueForScore; + double baseValue = judgement.ResultValueForScore; // Add bonus points for hitting an accented hit object with the second key - if (newJudgement.SecondHit) + if (judgement.SecondHit) baseValue += baseValue * accentedHitScale; // Add score to portions @@ -212,7 +212,7 @@ namespace osu.Game.Modes.Taiko.Scoring } // Apply HP changes - switch (newJudgement.Result) + switch (judgement.Result) { case HitResult.Miss: // Missing ticks shouldn't drop HP @@ -220,7 +220,7 @@ namespace osu.Game.Modes.Taiko.Scoring Health.Value += hpIncreaseMiss; break; case HitResult.Hit: - switch (newJudgement.TaikoResult) + switch (judgement.TaikoResult) { case TaikoHitResult.Good: Health.Value += hpIncreaseGood; diff --git a/osu.Game/Modes/Scoring/ScoreProcessor.cs b/osu.Game/Modes/Scoring/ScoreProcessor.cs index d881d830fa..f14b306e18 100644 --- a/osu.Game/Modes/Scoring/ScoreProcessor.cs +++ b/osu.Game/Modes/Scoring/ScoreProcessor.cs @@ -143,7 +143,7 @@ namespace osu.Game.Modes.Scoring { Judgements.Add(judgement); - UpdateCalculations(judgement); + OnNewJugement(judgement); judgement.ComboAtHit = (ulong)Combo.Value; @@ -158,7 +158,7 @@ namespace osu.Game.Modes.Scoring /// /// Update any values that potentially need post-processing on a judgement change. /// - /// A new Judgement that triggered this calculation. May be null. - protected abstract void UpdateCalculations(TJudgement newJudgement); + /// The judgement that triggered this calculation. + protected abstract void OnNewJugement(TJudgement judgement); } } \ No newline at end of file