mirror of
https://github.com/ppy/osu.git
synced 2025-01-19 13:02:54 +08:00
Lookup by control point time rather than control point
Under some situations, such as when there are no control points, ControlPointInfo will return to us a newly-constructed controlpoint with every call to SamplePointAt, which will fail on this key lookup. Between this and overriding GetHashCode, I think this is the more proper fix for this.
This commit is contained in:
parent
b95d7fc2cd
commit
519ef72adf
@ -2,7 +2,6 @@
|
|||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
||||||
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
|
||||||
using osu.Framework.Audio;
|
using osu.Framework.Audio;
|
||||||
using osu.Framework.Audio.Sample;
|
using osu.Framework.Audio.Sample;
|
||||||
using osu.Game.Audio;
|
using osu.Game.Audio;
|
||||||
@ -13,7 +12,7 @@ namespace osu.Game.Rulesets.Taiko.Audio
|
|||||||
public class DrumSampleMapping
|
public class DrumSampleMapping
|
||||||
{
|
{
|
||||||
private readonly ControlPointInfo controlPoints;
|
private readonly ControlPointInfo controlPoints;
|
||||||
private readonly Dictionary<SampleControlPoint, DrumSample> mappings = new Dictionary<SampleControlPoint, DrumSample>();
|
private readonly Dictionary<double, DrumSample> mappings = new Dictionary<double, DrumSample>();
|
||||||
|
|
||||||
public DrumSampleMapping(ControlPointInfo controlPoints, AudioManager audio)
|
public DrumSampleMapping(ControlPointInfo controlPoints, AudioManager audio)
|
||||||
{
|
{
|
||||||
@ -26,9 +25,9 @@ namespace osu.Game.Rulesets.Taiko.Audio
|
|||||||
else
|
else
|
||||||
samplePoints = controlPoints.SamplePoints;
|
samplePoints = controlPoints.SamplePoints;
|
||||||
|
|
||||||
foreach (var s in samplePoints.Distinct())
|
foreach (var s in samplePoints)
|
||||||
{
|
{
|
||||||
mappings[s] = new DrumSample
|
mappings[s.Time] = new DrumSample
|
||||||
{
|
{
|
||||||
Centre = s.GetSampleInfo().GetChannel(audio.Sample, "Taiko"),
|
Centre = s.GetSampleInfo().GetChannel(audio.Sample, "Taiko"),
|
||||||
Rim = s.GetSampleInfo(SampleInfo.HIT_CLAP).GetChannel(audio.Sample, "Taiko")
|
Rim = s.GetSampleInfo(SampleInfo.HIT_CLAP).GetChannel(audio.Sample, "Taiko")
|
||||||
@ -36,7 +35,7 @@ namespace osu.Game.Rulesets.Taiko.Audio
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public DrumSample SampleAt(double time) => mappings[controlPoints.SamplePointAt(time)];
|
public DrumSample SampleAt(double time) => mappings[controlPoints.SamplePointAt(time).Time];
|
||||||
|
|
||||||
public class DrumSample
|
public class DrumSample
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user