1
0
mirror of https://github.com/ppy/osu.git synced 2024-09-24 00:47:26 +08:00
osu-lazer/osu.Game/Modes/Objects/LegacyHitObjectParser.cs

109 lines
4.3 KiB
C#
Raw Normal View History

2017-03-14 12:02:42 +08:00
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
using OpenTK;
using osu.Game.Beatmaps.Samples;
using osu.Game.Modes.Objects.Types;
2016-12-06 17:56:20 +08:00
using System;
using System.Collections.Generic;
2016-11-17 20:29:35 +08:00
using System.Globalization;
namespace osu.Game.Modes.Objects
{
internal class LegacyHitObjectParser : HitObjectParser
{
public override HitObject Parse(string text)
{
string[] split = text.Split(',');
var type = (HitObjectType)int.Parse(split[3]);
bool combo = type.HasFlag(HitObjectType.NewCombo);
type &= (HitObjectType)0xF;
type &= ~HitObjectType.NewCombo;
HitObject result;
switch (type)
{
case HitObjectType.Circle:
result = new Hit
{
Position = new Vector2(int.Parse(split[0]), int.Parse(split[1])),
NewCombo = combo
};
break;
case HitObjectType.Slider:
CurveType curveType = CurveType.Catmull;
2016-11-17 20:29:35 +08:00
double length = 0;
2017-03-07 09:59:19 +08:00
List<Vector2> points = new List<Vector2> { new Vector2(int.Parse(split[0]), int.Parse(split[1])) };
2016-11-17 20:29:35 +08:00
string[] pointsplit = split[5].Split('|');
2017-03-09 13:24:16 +08:00
foreach (string t in pointsplit)
2016-11-17 20:29:35 +08:00
{
2017-03-09 13:24:16 +08:00
if (t.Length == 1)
2016-11-17 20:29:35 +08:00
{
2017-03-09 13:24:16 +08:00
switch (t)
2016-11-17 20:29:35 +08:00
{
case @"C":
curveType = CurveType.Catmull;
2016-11-17 20:29:35 +08:00
break;
case @"B":
curveType = CurveType.Bezier;
2016-11-17 20:29:35 +08:00
break;
case @"L":
curveType = CurveType.Linear;
2016-11-17 20:29:35 +08:00
break;
case @"P":
curveType = CurveType.PerfectCurve;
2016-11-17 20:29:35 +08:00
break;
}
continue;
}
2017-03-09 13:24:16 +08:00
string[] temp = t.Split(':');
2016-11-17 20:29:35 +08:00
Vector2 v = new Vector2(
(int)Convert.ToDouble(temp[0], CultureInfo.InvariantCulture),
(int)Convert.ToDouble(temp[1], CultureInfo.InvariantCulture)
);
points.Add(v);
}
2017-03-07 09:59:19 +08:00
int repeatCount = Convert.ToInt32(split[6], CultureInfo.InvariantCulture);
2016-11-17 20:29:35 +08:00
if (repeatCount > 9000)
2017-03-07 09:59:19 +08:00
throw new ArgumentOutOfRangeException(nameof(repeatCount), @"Repeat count is way too high");
2016-11-17 20:29:35 +08:00
if (split.Length > 7)
length = Convert.ToDouble(split[7], CultureInfo.InvariantCulture);
result = new Slider
2016-11-17 20:29:35 +08:00
{
ControlPoints = points,
Distance = length,
CurveType = curveType,
RepeatCount = repeatCount,
Position = new Vector2(int.Parse(split[0]), int.Parse(split[1])),
NewCombo = combo
2016-11-17 20:29:35 +08:00
};
break;
case HitObjectType.Spinner:
result = new Spinner
{
EndTime = Convert.ToDouble(split[5], CultureInfo.InvariantCulture)
};
break;
default:
2017-02-15 10:37:23 +08:00
throw new InvalidOperationException($@"Unknown hit object type {type}");
}
result.StartTime = Convert.ToDouble(split[2], CultureInfo.InvariantCulture);
result.Sample = new HitSampleInfo
{
2016-12-08 19:00:24 +08:00
Type = (SampleType)int.Parse(split[4]),
2016-12-08 18:54:22 +08:00
Set = SampleSet.Soft,
};
// TODO: "addition" field
return result;
}
}
}