mirror of
https://github.com/ppy/osu.git
synced 2024-11-06 15:17:28 +08:00
52 lines
1.4 KiB
C#
52 lines
1.4 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.
|
|
|
|
#nullable disable
|
|
|
|
using System.Linq;
|
|
using System.Collections.Generic;
|
|
using System.Diagnostics;
|
|
using osu.Game.Rulesets.Objects;
|
|
|
|
namespace osu.Game.Screens.Play
|
|
{
|
|
public class SongProgressGraph : SquareGraph
|
|
{
|
|
private IEnumerable<HitObject> objects;
|
|
|
|
public IEnumerable<HitObject> Objects
|
|
{
|
|
set
|
|
{
|
|
objects = value;
|
|
|
|
const int granularity = 200;
|
|
Values = new int[granularity];
|
|
|
|
if (!objects.Any())
|
|
return;
|
|
|
|
double firstHit = objects.First().StartTime;
|
|
double lastHit = objects.Max(o => o.GetEndTime());
|
|
|
|
if (lastHit == 0)
|
|
lastHit = objects.Last().StartTime;
|
|
|
|
double interval = (lastHit - firstHit + 1) / granularity;
|
|
|
|
foreach (var h in objects)
|
|
{
|
|
double endTime = h.GetEndTime();
|
|
|
|
Debug.Assert(endTime >= h.StartTime);
|
|
|
|
int startRange = (int)((h.StartTime - firstHit) / interval);
|
|
int endRange = (int)((endTime - firstHit) / interval);
|
|
for (int i = startRange; i <= endRange; i++)
|
|
Values[i]++;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|