1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-14 03:25:11 +08:00

Fix only single sound type being written

This commit is contained in:
smoogipoo 2019-12-12 19:53:30 +09:00
parent dedae69db8
commit ac984423bb

View File

@ -225,7 +225,6 @@ namespace osu.Game.Beatmaps.Formats
LegacyHitObjectType hitObjectType = (LegacyHitObjectType)(comboData.ComboOffset << 4);
if (comboData.NewCombo)
hitObjectType |= LegacyHitObjectType.NewCombo;
if (hitObject is IHasCurve _)
hitObjectType |= LegacyHitObjectType.Slider;
else if (hitObject is IHasEndTime _)
@ -233,16 +232,11 @@ namespace osu.Game.Beatmaps.Formats
else
hitObjectType |= LegacyHitObjectType.Circle;
LegacyHitSoundType soundType = LegacyHitSoundType.Normal;
HitSampleInfo firstAdditionSound = hitObject.Samples.FirstOrDefault(s => s.Name != HitSampleInfo.HIT_NORMAL);
if (firstAdditionSound != null)
soundType |= toLegacyHitSound(firstAdditionSound.Name);
writer.Write(FormattableString.Invariant($"{positionData.X},"));
writer.Write(FormattableString.Invariant($"{positionData.Y},"));
writer.Write(FormattableString.Invariant($"{hitObject.StartTime},"));
writer.Write(FormattableString.Invariant($"{(int)hitObjectType},"));
writer.Write(FormattableString.Invariant($"{(int)soundType},"));
writer.Write(FormattableString.Invariant($"{(int)toLegacyHitSoundType(hitObject.Samples)},"));
if (hitObject is IHasCurve curveData)
{
@ -296,12 +290,7 @@ namespace osu.Game.Beatmaps.Formats
for (int i = 0; i < curveData.NodeSamples.Count; i++)
{
LegacyHitSoundType type = LegacyHitSoundType.None;
foreach (var sample in curveData.NodeSamples[i])
type |= toLegacyHitSound(sample.Name);
writer.Write(FormattableString.Invariant($"{(int)type}"));
writer.Write(FormattableString.Invariant($"{(int)toLegacyHitSoundType(curveData.NodeSamples[i])}"));
writer.Write(i != curveData.NodeSamples.Count - 1 ? "|" : ",");
}
@ -359,27 +348,31 @@ namespace osu.Game.Beatmaps.Formats
return sb.ToString();
}
private LegacyHitSoundType toLegacyHitSound(string hitSoundName)
private LegacyHitSoundType toLegacyHitSoundType(IList<HitSampleInfo> samples)
{
switch (hitSoundName)
{
case HitSampleInfo.HIT_NORMAL:
return LegacyHitSoundType.Normal;
LegacyHitSoundType type = LegacyHitSoundType.None;
foreach (var sample in samples)
{
switch (sample.Name)
{
case HitSampleInfo.HIT_WHISTLE:
return LegacyHitSoundType.Whistle;
type |= LegacyHitSoundType.Whistle;
break;
case HitSampleInfo.HIT_FINISH:
return LegacyHitSoundType.Finish;
type |= LegacyHitSoundType.Finish;
break;
case HitSampleInfo.HIT_CLAP:
return LegacyHitSoundType.Clap;
default:
return LegacyHitSoundType.None;
type |= LegacyHitSoundType.Clap;
break;
}
}
return type;
}
private LegacySampleBank toLegacySampleBank(string sampleBank)
{
switch (sampleBank?.ToLower())