mirror of
https://github.com/ppy/osu.git
synced 2026-06-11 21:05:11 +08:00
0c3ee1938e
* Use `normalized_hitobject_radius` during osu!catch buzz slider detection Currently the algorithm considers some buzz sliders as standstills when in reality they require movement. This happens because `HalfCatcherWidth` isn't normalized while `exactDistanceMoved` is, leading to an inaccurate comparison. `normalized_hitobject_radius` is the normalized value of `HalfCatcherWidth` and replacing one with the other fixes the problem. * Rename `normalized_hitobject_radius` to `normalized_half_catcher_width` The current name is confusing because hit objects have no radius in the context of osu!catch difficulty calculation. The new name conveys the actual purpose of the value. * Only set `normalized_half_catcher_width` in `CatchDifficultyHitObject` Prevents potential bugs if the value were to be changed in one of the classes but not in both. * Use `CatchDifficultyHitObject.NORMALIZED_HALF_CATCHER_WIDTH` directly Requested during code review. --------- Co-authored-by: James Wilson <tsunyoku@gmail.com>
42 lines
1.8 KiB
C#
42 lines
1.8 KiB
C#
// 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 System.Collections.Generic;
|
|
using osu.Game.Rulesets.Catch.Objects;
|
|
using osu.Game.Rulesets.Difficulty.Preprocessing;
|
|
using osu.Game.Rulesets.Objects;
|
|
|
|
namespace osu.Game.Rulesets.Catch.Difficulty.Preprocessing
|
|
{
|
|
public class CatchDifficultyHitObject : DifficultyHitObject
|
|
{
|
|
public const float NORMALIZED_HALF_CATCHER_WIDTH = 41.0f;
|
|
|
|
public new PalpableCatchHitObject BaseObject => (PalpableCatchHitObject)base.BaseObject;
|
|
|
|
public new PalpableCatchHitObject LastObject => (PalpableCatchHitObject)base.LastObject;
|
|
|
|
public readonly float NormalizedPosition;
|
|
public readonly float LastNormalizedPosition;
|
|
|
|
/// <summary>
|
|
/// Milliseconds elapsed since the start time of the previous <see cref="CatchDifficultyHitObject"/>, with a minimum of 40ms.
|
|
/// </summary>
|
|
public readonly double StrainTime;
|
|
|
|
public CatchDifficultyHitObject(HitObject hitObject, HitObject lastObject, double clockRate, float halfCatcherWidth, List<DifficultyHitObject> objects, int index)
|
|
: base(hitObject, lastObject, clockRate, objects, index)
|
|
{
|
|
// We will scale everything by this factor, so we can assume a uniform CircleSize among beatmaps.
|
|
float scalingFactor = NORMALIZED_HALF_CATCHER_WIDTH / halfCatcherWidth;
|
|
|
|
NormalizedPosition = BaseObject.EffectiveX * scalingFactor;
|
|
LastNormalizedPosition = LastObject.EffectiveX * scalingFactor;
|
|
|
|
// Every strain interval is hard capped at the equivalent of 375 BPM streaming speed as a safety measure
|
|
StrainTime = Math.Max(40, DeltaTime);
|
|
}
|
|
}
|
|
}
|