1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-07 16:12:55 +08:00
osu-lazer/osu.Game/Beatmaps/Legacy/LegacyControlPointInfo.cs

102 lines
3.7 KiB
C#
Raw Normal View History

2023-06-23 00:37:25 +08:00
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
2021-08-30 13:12:30 +08:00
// See the LICENCE file in the repository root for full licence text.
using System.Collections.Generic;
2021-08-30 13:12:30 +08:00
using Newtonsoft.Json;
using osu.Framework.Lists;
2021-08-30 13:12:30 +08:00
using osu.Game.Beatmaps.ControlPoints;
namespace osu.Game.Beatmaps.Legacy
{
public class LegacyControlPointInfo : ControlPointInfo
{
/// <summary>
/// All sound points.
/// </summary>
[JsonProperty]
public IReadOnlyList<SampleControlPoint> SamplePoints => samplePoints;
2021-08-30 13:12:30 +08:00
private readonly SortedList<SampleControlPoint> samplePoints = new SortedList<SampleControlPoint>(Comparer<SampleControlPoint>.Default);
2021-08-30 13:12:30 +08:00
/// <summary>
/// Finds the sound control point that is active at <paramref name="time"/>.
/// </summary>
/// <param name="time">The time to find the sound control point at.</param>
/// <returns>The sound control point.</returns>
public SampleControlPoint SamplePointAt(double time) => BinarySearchWithFallback(SamplePoints, time, SamplePoints.Count > 0 ? SamplePoints[0] : SampleControlPoint.DEFAULT);
/// <summary>
/// All difficulty points.
/// </summary>
[JsonProperty]
public IReadOnlyList<DifficultyControlPoint> DifficultyPoints => difficultyPoints;
private readonly SortedList<DifficultyControlPoint> difficultyPoints = new SortedList<DifficultyControlPoint>(Comparer<DifficultyControlPoint>.Default);
/// <summary>
/// Finds the difficulty control point that is active at <paramref name="time"/>.
/// </summary>
/// <param name="time">The time to find the difficulty control point at.</param>
/// <returns>The difficulty control point.</returns>
public DifficultyControlPoint DifficultyPointAt(double time) => BinarySearchWithFallback(DifficultyPoints, time, DifficultyControlPoint.DEFAULT);
2021-08-30 13:12:30 +08:00
public override void Clear()
{
base.Clear();
samplePoints.Clear();
difficultyPoints.Clear();
2021-08-30 13:12:30 +08:00
}
protected override bool CheckAlreadyExisting(double time, ControlPoint newPoint)
{
switch (newPoint)
2021-08-30 13:12:30 +08:00
{
2022-06-24 20:25:23 +08:00
case SampleControlPoint:
// intentionally don't use SamplePointAt (we always need to consider the first sample point).
var existing = BinarySearch(SamplePoints, time);
return newPoint.IsRedundant(existing);
2022-06-24 20:25:23 +08:00
case DifficultyControlPoint:
return newPoint.IsRedundant(DifficultyPointAt(time));
2021-08-30 13:12:30 +08:00
default:
return base.CheckAlreadyExisting(time, newPoint);
}
2021-08-30 13:12:30 +08:00
}
protected override void GroupItemAdded(ControlPoint controlPoint)
{
switch (controlPoint)
{
case SampleControlPoint typed:
samplePoints.Add(typed);
return;
case DifficultyControlPoint typed:
difficultyPoints.Add(typed);
return;
default:
base.GroupItemAdded(controlPoint);
break;
}
2021-08-30 13:12:30 +08:00
}
protected override void GroupItemRemoved(ControlPoint controlPoint)
{
switch (controlPoint)
{
case SampleControlPoint typed:
samplePoints.Remove(typed);
break;
case DifficultyControlPoint typed:
difficultyPoints.Remove(typed);
break;
}
2021-08-30 13:12:30 +08:00
base.GroupItemRemoved(controlPoint);
}
}
}