mirror of
https://github.com/ppy/osu.git
synced 2025-01-28 05:22:54 +08:00
Simplify code/language
This commit is contained in:
parent
b8d7b78b55
commit
ea1bec85ae
@ -1,7 +1,6 @@
|
||||
// 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.Extensions.IEnumerableExtensions;
|
||||
using osuTK;
|
||||
using osu.Framework.Graphics;
|
||||
@ -87,10 +86,10 @@ namespace osu.Game.Rulesets.Osu.UI
|
||||
{
|
||||
DrawableHitObject lastObject = osuHitObject;
|
||||
|
||||
// Get the last hitobject that contributes to note lock
|
||||
// Get the last hitobject that can block future hits
|
||||
while ((lastObject = HitObjectContainer.AliveObjects.GetPrevious(lastObject)) != null)
|
||||
{
|
||||
if (contributesToNoteLock(lastObject.HitObject))
|
||||
if (canBlockFutureHits(lastObject.HitObject))
|
||||
break;
|
||||
}
|
||||
|
||||
@ -108,7 +107,9 @@ namespace osu.Game.Rulesets.Osu.UI
|
||||
|
||||
private void onNewResult(DrawableHitObject judgedObject, JudgementResult result)
|
||||
{
|
||||
missAllEarlier(result.HitObject);
|
||||
// Hitobjects that block future hits should miss previous hitobjects if they're hit out-of-order.
|
||||
if (canBlockFutureHits(result.HitObject))
|
||||
missAllEarlierObjects(result.HitObject);
|
||||
|
||||
if (!judgedObject.DisplayResult || !DisplayJudgements.Value)
|
||||
return;
|
||||
@ -127,12 +128,8 @@ namespace osu.Game.Rulesets.Osu.UI
|
||||
/// Misses all <see cref="OsuHitObject"/>s occurring earlier than the start time of a judged <see cref="OsuHitObject"/>.
|
||||
/// </summary>
|
||||
/// <param name="hitObject">The marker <see cref="HitObject"/>, which all <see cref="HitObject"/>s earlier than will get missed.</param>
|
||||
private void missAllEarlier(HitObject hitObject)
|
||||
private void missAllEarlierObjects(HitObject hitObject)
|
||||
{
|
||||
if (!causesNoteLockMisses(hitObject))
|
||||
return;
|
||||
|
||||
// The minimum start time required for hitobjects so that they aren't missed.
|
||||
double minimumTime = hitObject.StartTime;
|
||||
|
||||
foreach (var obj in HitObjectContainer.AliveObjects)
|
||||
@ -140,50 +137,36 @@ namespace osu.Game.Rulesets.Osu.UI
|
||||
if (obj.HitObject.StartTime >= minimumTime)
|
||||
break;
|
||||
|
||||
performMiss(obj);
|
||||
|
||||
foreach (var n in obj.NestedHitObjects)
|
||||
switch (obj)
|
||||
{
|
||||
if (n.HitObject.StartTime >= minimumTime)
|
||||
case DrawableHitCircle circle:
|
||||
miss(circle);
|
||||
break;
|
||||
|
||||
performMiss(n);
|
||||
}
|
||||
case DrawableSlider slider:
|
||||
miss(slider.HeadCircle);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
private void performMiss(DrawableHitObject obj)
|
||||
static void miss(DrawableOsuHitObject obj)
|
||||
{
|
||||
if (!(obj is DrawableOsuHitObject osuObject))
|
||||
throw new InvalidOperationException($"{obj.GetType()} is not a {nameof(DrawableOsuHitObject)}.");
|
||||
|
||||
// Hitobjects that have already been judged cannot be missed.
|
||||
if (osuObject.Judged)
|
||||
if (obj.Judged)
|
||||
return;
|
||||
|
||||
if (!causesNoteLockMisses(obj.HitObject))
|
||||
return;
|
||||
|
||||
osuObject.MissForcefully();
|
||||
obj.MissForcefully();
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Whether a <see cref="HitObject"/> is contributes to note lock.
|
||||
/// Future contributing <see cref="HitObject"/>s will not be hittable until the start time of the last contributing <see cref="HitObject"/> is reached.
|
||||
/// Whether a <see cref="HitObject"/> can block hits on future <see cref="HitObject"/>s until its start time is reached.
|
||||
/// </summary>
|
||||
/// <param name="hitObject">The <see cref="HitObject"/> to test.</param>
|
||||
/// <returns>Whether <paramref name="hitObject"/> causes note lock.</returns>
|
||||
private bool contributesToNoteLock(HitObject hitObject)
|
||||
/// <returns>Whether <paramref name="hitObject"/> can block hits on future <see cref="HitObject"/>s.</returns>
|
||||
private bool canBlockFutureHits(HitObject hitObject)
|
||||
=> hitObject is HitCircle || hitObject is Slider;
|
||||
|
||||
/// <summary>
|
||||
/// Whether a <see cref="HitObject"/> can be missed and causes other <see cref="HitObject"/>s to be missed when hit out-of-order during note lock.
|
||||
/// </summary>
|
||||
/// <param name="hitObject">The <see cref="HitObject"/> to test.</param>
|
||||
/// <returns>Whether <paramref name="hitObject"/> contributes to note lock misses.</returns>
|
||||
private bool causesNoteLockMisses(HitObject hitObject)
|
||||
=> hitObject is HitCircle && !(hitObject is SliderTailCircle);
|
||||
|
||||
public override bool ReceivePositionalInputAt(Vector2 screenSpacePos) => HitObjectContainer.ReceivePositionalInputAt(screenSpacePos);
|
||||
|
||||
private class ApproachCircleProxyContainer : LifetimeManagementContainer
|
||||
|
Loading…
Reference in New Issue
Block a user