mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 21:13:20 +08:00
Refactor to keep a consistent API
This commit is contained in:
parent
5cd43b3a7f
commit
37e30b00bf
@ -19,12 +19,9 @@ namespace osu.Game.Rulesets.Difficulty.Skills
|
|||||||
protected readonly ReverseQueue<DifficultyHitObject> Previous;
|
protected readonly ReverseQueue<DifficultyHitObject> Previous;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Soft capacity of the <see cref="Previous"/> queue.
|
/// Number of previous <see cref="DifficultyHitObject"/>s to keep inside the <see cref="Previous"/> queue.
|
||||||
/// <see cref="Previous"/> will automatically resize if it exceeds capacity, but will do so at a very slight performance impact.
|
|
||||||
/// The actual capacity will be set to this value + 1 to allow for storage of the current object before the next can be processed.
|
|
||||||
/// Setting to zero (default) will cause <see cref="Previous"/> to be uninstanciated.
|
|
||||||
/// </summary>
|
/// </summary>
|
||||||
protected virtual int PreviousCollectionSoftCapacity => 0;
|
protected virtual int HistoryLength => 1;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Mods for use in skill calculations.
|
/// Mods for use in skill calculations.
|
||||||
@ -36,32 +33,17 @@ namespace osu.Game.Rulesets.Difficulty.Skills
|
|||||||
protected Skill(Mod[] mods)
|
protected Skill(Mod[] mods)
|
||||||
{
|
{
|
||||||
this.mods = mods;
|
this.mods = mods;
|
||||||
|
Previous = new ReverseQueue<DifficultyHitObject>(HistoryLength + 1);
|
||||||
if (PreviousCollectionSoftCapacity > 0)
|
|
||||||
Previous = new ReverseQueue<DifficultyHitObject>(PreviousCollectionSoftCapacity + 1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void ProcessInternal(DifficultyHitObject current)
|
internal void ProcessInternal(DifficultyHitObject current)
|
||||||
{
|
{
|
||||||
RemoveExtraneousHistory(current);
|
while (Previous.Count > HistoryLength)
|
||||||
|
Previous.Dequeue();
|
||||||
|
|
||||||
Process(current);
|
Process(current);
|
||||||
AddToHistory(current);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
Previous.Enqueue(current);
|
||||||
/// Remove objects from <see cref="Previous"/> that are no longer needed for calculations from the current object onwards.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="current">The <see cref="DifficultyHitObject"/> to be processed.</param>
|
|
||||||
protected virtual void RemoveExtraneousHistory(DifficultyHitObject current)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Add the current <see cref="DifficultyHitObject"/> to the <see cref="Previous"/> queue (if required).
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="current">The <see cref="DifficultyHitObject"/> that was just processed.</param>
|
|
||||||
protected virtual void AddToHistory(DifficultyHitObject current)
|
|
||||||
{
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -20,8 +20,6 @@ namespace osu.Game.Rulesets.Difficulty.Skills
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
protected abstract double SkillMultiplier { get; }
|
protected abstract double SkillMultiplier { get; }
|
||||||
|
|
||||||
protected override int PreviousCollectionSoftCapacity => 1;
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Determines how quickly strain decays for the given skill.
|
/// Determines how quickly strain decays for the given skill.
|
||||||
/// For example a value of 0.15 indicates that strain decays to 15% of its original value in one second.
|
/// For example a value of 0.15 indicates that strain decays to 15% of its original value in one second.
|
||||||
@ -54,17 +52,6 @@ namespace osu.Game.Rulesets.Difficulty.Skills
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void RemoveExtraneousHistory(DifficultyHitObject current)
|
|
||||||
{
|
|
||||||
while (Previous.Count > 1)
|
|
||||||
Previous.Dequeue();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void AddToHistory(DifficultyHitObject current)
|
|
||||||
{
|
|
||||||
Previous.Enqueue(current);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Process a <see cref="DifficultyHitObject"/> and update current strain values accordingly.
|
/// Process a <see cref="DifficultyHitObject"/> and update current strain values accordingly.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
Loading…
Reference in New Issue
Block a user