mirror of
https://github.com/ppy/osu.git
synced 2025-02-13 19:12:54 +08:00
Merge pull request #2794 from smoogipoo/legacy-slider-offset
Add legacy slider offsets to osu!/osu!catch
This commit is contained in:
commit
2bb1550040
@ -13,11 +13,12 @@ using osu.Game.Tests.Beatmaps;
|
||||
|
||||
namespace osu.Game.Rulesets.Catch.Tests
|
||||
{
|
||||
internal class CatchBeatmapConversionTest : BeatmapConversionTest<ConvertValue>
|
||||
[TestFixture]
|
||||
public class CatchBeatmapConversionTest : BeatmapConversionTest<ConvertValue>
|
||||
{
|
||||
protected override string ResourceAssembly => "osu.Game.Rulesets.Catch";
|
||||
|
||||
[TestCase("basic"), Ignore("See: https://github.com/ppy/osu/issues/2232")]
|
||||
[TestCase("basic")]
|
||||
[TestCase("spinner")]
|
||||
[TestCase("spinner-and-circles")]
|
||||
public new void Test(string name)
|
||||
@ -44,7 +45,7 @@ namespace osu.Game.Rulesets.Catch.Tests
|
||||
protected override Ruleset CreateRuleset() => new CatchRuleset();
|
||||
}
|
||||
|
||||
internal struct ConvertValue : IEquatable<ConvertValue>
|
||||
public struct ConvertValue : IEquatable<ConvertValue>
|
||||
{
|
||||
/// <summary>
|
||||
/// A sane value to account for osu!stable using ints everwhere.
|
||||
|
@ -26,6 +26,7 @@ namespace osu.Game.Rulesets.Catch.Beatmaps
|
||||
var positionData = obj as IHasXPosition;
|
||||
var comboData = obj as IHasCombo;
|
||||
var endTime = obj as IHasEndTime;
|
||||
var legacyOffset = obj as IHasLegacyLastTickOffset;
|
||||
|
||||
if (curveData != null)
|
||||
{
|
||||
@ -39,7 +40,8 @@ namespace osu.Game.Rulesets.Catch.Beatmaps
|
||||
RepeatSamples = curveData.RepeatSamples,
|
||||
RepeatCount = curveData.RepeatCount,
|
||||
X = (positionData?.X ?? 0) / CatchPlayfield.BASE_WIDTH,
|
||||
NewCombo = comboData?.NewCombo ?? false
|
||||
NewCombo = comboData?.NewCombo ?? false,
|
||||
LegacyLastTickOffset = legacyOffset?.LegacyLastTickOffset ?? 0
|
||||
};
|
||||
}
|
||||
else if (endTime != null)
|
||||
|
@ -77,6 +77,13 @@ namespace osu.Game.Rulesets.Catch.Objects
|
||||
|
||||
double time = spanStartTime + timeProgress * spanDuration;
|
||||
|
||||
if (LegacyLastTickOffset != null)
|
||||
{
|
||||
// If we're the last tick, apply the legacy offset
|
||||
if (span == this.SpanCount() - 1 && d + tickDistance > length)
|
||||
time = Math.Max(StartTime + Duration / 2, time - LegacyLastTickOffset.Value);
|
||||
}
|
||||
|
||||
double tinyTickInterval = time - lastDropletTime;
|
||||
while (tinyTickInterval > 100)
|
||||
tinyTickInterval /= 2;
|
||||
@ -152,5 +159,7 @@ namespace osu.Game.Rulesets.Catch.Objects
|
||||
get { return Curve.CurveType; }
|
||||
set { Curve.CurveType = value; }
|
||||
}
|
||||
|
||||
public double? LegacyLastTickOffset { get; set; }
|
||||
}
|
||||
}
|
||||
|
@ -12,7 +12,8 @@ using osu.Game.Tests.Beatmaps;
|
||||
|
||||
namespace osu.Game.Rulesets.Mania.Tests
|
||||
{
|
||||
internal class ManiaBeatmapConversionTest : BeatmapConversionTest<ConvertValue>
|
||||
[TestFixture]
|
||||
public class ManiaBeatmapConversionTest : BeatmapConversionTest<ConvertValue>
|
||||
{
|
||||
protected override string ResourceAssembly => "osu.Game.Rulesets.Mania";
|
||||
|
||||
@ -36,7 +37,7 @@ namespace osu.Game.Rulesets.Mania.Tests
|
||||
protected override Ruleset CreateRuleset() => new ManiaRuleset();
|
||||
}
|
||||
|
||||
internal struct ConvertValue : IEquatable<ConvertValue>
|
||||
public struct ConvertValue : IEquatable<ConvertValue>
|
||||
{
|
||||
/// <summary>
|
||||
/// A sane value to account for osu!stable using ints everwhere.
|
||||
|
@ -8,17 +8,19 @@ using osu.Framework.MathUtils;
|
||||
using osu.Game.Rulesets.Objects;
|
||||
using osu.Game.Rulesets.Objects.Types;
|
||||
using osu.Game.Rulesets.Osu.Objects;
|
||||
using osu.Game.Rulesets.Osu.UI;
|
||||
using osu.Game.Tests.Beatmaps;
|
||||
using OpenTK;
|
||||
|
||||
namespace osu.Game.Rulesets.Osu.Tests
|
||||
{
|
||||
internal class OsuBeatmapConversionTest : BeatmapConversionTest<ConvertValue>
|
||||
[TestFixture]
|
||||
public class OsuBeatmapConversionTest : BeatmapConversionTest<ConvertValue>
|
||||
{
|
||||
protected override string ResourceAssembly => "osu.Game.Rulesets.Osu";
|
||||
|
||||
[TestCase("basic")]
|
||||
[TestCase("colinear-perfect-curve")]
|
||||
[TestCase("slider-ticks")]
|
||||
public new void Test(string name)
|
||||
{
|
||||
base.Test(name);
|
||||
@ -26,24 +28,30 @@ namespace osu.Game.Rulesets.Osu.Tests
|
||||
|
||||
protected override IEnumerable<ConvertValue> CreateConvertValue(HitObject hitObject)
|
||||
{
|
||||
var startPosition = (hitObject as IHasPosition)?.Position ?? new Vector2(256, 192);
|
||||
var endPosition = (hitObject as Slider)?.EndPosition ?? startPosition;
|
||||
|
||||
yield return new ConvertValue
|
||||
switch (hitObject)
|
||||
{
|
||||
StartTime = hitObject.StartTime,
|
||||
EndTime = (hitObject as IHasEndTime)?.EndTime ?? hitObject.StartTime,
|
||||
StartX = startPosition.X,
|
||||
StartY = startPosition.Y,
|
||||
EndX = endPosition.X,
|
||||
EndY = endPosition.Y
|
||||
case Slider slider:
|
||||
foreach (var nested in slider.NestedHitObjects)
|
||||
yield return createConvertValue(nested);
|
||||
break;
|
||||
default:
|
||||
yield return createConvertValue(hitObject);
|
||||
break;
|
||||
}
|
||||
|
||||
ConvertValue createConvertValue(HitObject obj) => new ConvertValue
|
||||
{
|
||||
StartTime = obj.StartTime,
|
||||
EndTime = (obj as IHasEndTime)?.EndTime ?? obj.StartTime,
|
||||
X = (obj as IHasPosition)?.X ?? OsuPlayfield.BASE_SIZE.X / 2,
|
||||
Y = (obj as IHasPosition)?.Y ?? OsuPlayfield.BASE_SIZE.Y / 2,
|
||||
};
|
||||
}
|
||||
|
||||
protected override Ruleset CreateRuleset() => new OsuRuleset();
|
||||
}
|
||||
|
||||
internal struct ConvertValue : IEquatable<ConvertValue>
|
||||
public struct ConvertValue : IEquatable<ConvertValue>
|
||||
{
|
||||
/// <summary>
|
||||
/// A sane value to account for osu!stable using ints everwhere.
|
||||
@ -52,17 +60,13 @@ namespace osu.Game.Rulesets.Osu.Tests
|
||||
|
||||
public double StartTime;
|
||||
public double EndTime;
|
||||
public float StartX;
|
||||
public float StartY;
|
||||
public float EndX;
|
||||
public float EndY;
|
||||
public float X;
|
||||
public float Y;
|
||||
|
||||
public bool Equals(ConvertValue other)
|
||||
=> Precision.AlmostEquals(StartTime, other.StartTime)
|
||||
=> Precision.AlmostEquals(StartTime, other.StartTime, conversion_lenience)
|
||||
&& Precision.AlmostEquals(EndTime, other.EndTime, conversion_lenience)
|
||||
&& Precision.AlmostEquals(StartX, other.StartX)
|
||||
&& Precision.AlmostEquals(StartY, other.StartY, conversion_lenience)
|
||||
&& Precision.AlmostEquals(EndX, other.EndX, conversion_lenience)
|
||||
&& Precision.AlmostEquals(EndY, other.EndY, conversion_lenience);
|
||||
&& Precision.AlmostEquals(X, other.X, conversion_lenience)
|
||||
&& Precision.AlmostEquals(Y, other.Y, conversion_lenience);
|
||||
}
|
||||
}
|
||||
|
@ -27,6 +27,7 @@ namespace osu.Game.Rulesets.Osu.Beatmaps
|
||||
var endTimeData = original as IHasEndTime;
|
||||
var positionData = original as IHasPosition;
|
||||
var comboData = original as IHasCombo;
|
||||
var legacyOffset = original as IHasLegacyLastTickOffset;
|
||||
|
||||
if (curveData != null)
|
||||
{
|
||||
@ -40,7 +41,8 @@ namespace osu.Game.Rulesets.Osu.Beatmaps
|
||||
RepeatSamples = curveData.RepeatSamples,
|
||||
RepeatCount = curveData.RepeatCount,
|
||||
Position = positionData?.Position ?? Vector2.Zero,
|
||||
NewCombo = comboData?.NewCombo ?? false
|
||||
NewCombo = comboData?.NewCombo ?? false,
|
||||
LegacyLastTickOffset = legacyOffset?.LegacyLastTickOffset
|
||||
};
|
||||
}
|
||||
else if (endTimeData != null)
|
||||
|
@ -1,6 +1,7 @@
|
||||
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
||||
|
||||
using System;
|
||||
using OpenTK;
|
||||
using osu.Game.Rulesets.Objects.Types;
|
||||
using System.Collections.Generic;
|
||||
@ -45,6 +46,8 @@ namespace osu.Game.Rulesets.Osu.Objects
|
||||
set { Curve.Distance = value; }
|
||||
}
|
||||
|
||||
public double? LegacyLastTickOffset { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// The position of the cursor at the point of completion of this <see cref="Slider"/> if it was hit
|
||||
/// with as few movements as possible. This is set and used by difficulty calculation.
|
||||
@ -91,6 +94,9 @@ namespace osu.Game.Rulesets.Osu.Objects
|
||||
createSliderEnds();
|
||||
createTicks();
|
||||
createRepeatPoints();
|
||||
|
||||
if (LegacyLastTickOffset != null)
|
||||
TailCircle.StartTime = Math.Max(StartTime + Duration / 2, TailCircle.StartTime - LegacyLastTickOffset.Value);
|
||||
}
|
||||
|
||||
private void createSliderEnds()
|
||||
|
@ -6,6 +6,7 @@ using osu.Game.Beatmaps;
|
||||
using osu.Game.Rulesets.Osu.Objects;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using osu.Game.Rulesets.Osu.UI;
|
||||
using osu.Game.Rulesets.Replays;
|
||||
using osu.Game.Users;
|
||||
|
||||
@ -18,7 +19,7 @@ namespace osu.Game.Rulesets.Osu.Replays
|
||||
/// <summary>
|
||||
/// Constants (for spinners).
|
||||
/// </summary>
|
||||
protected static readonly Vector2 SPINNER_CENTRE = new Vector2(256, 192);
|
||||
protected static readonly Vector2 SPINNER_CENTRE = OsuPlayfield.BASE_SIZE / 2;
|
||||
protected const float SPIN_RADIUS = 50;
|
||||
|
||||
/// <summary>
|
||||
|
@ -1,124 +1,256 @@
|
||||
{
|
||||
"Mappings": [{
|
||||
"StartTime": 500,
|
||||
"StartTime": 500.0,
|
||||
"Objects": [{
|
||||
"StartTime": 500,
|
||||
"EndTime": 2500,
|
||||
"StartX": 96,
|
||||
"StartY": 192,
|
||||
"EndX": 96,
|
||||
"EndY": 192
|
||||
"StartTime": 500.0,
|
||||
"EndTime": 500.0,
|
||||
"X": 96.0,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 1000.0,
|
||||
"EndTime": 1000.0,
|
||||
"X": 256.0,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 1500.0,
|
||||
"EndTime": 1500.0,
|
||||
"X": 416.0,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 2000.0,
|
||||
"EndTime": 2000.0,
|
||||
"X": 256.0,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 2464.0,
|
||||
"EndTime": 2464.0,
|
||||
"X": 96.0,
|
||||
"Y": 192.0
|
||||
}]
|
||||
},
|
||||
{
|
||||
"StartTime": 3000,
|
||||
}, {
|
||||
"StartTime": 3000.0,
|
||||
"Objects": [{
|
||||
"StartTime": 3000,
|
||||
"EndTime": 4000,
|
||||
"StartX": 256,
|
||||
"StartY": 192,
|
||||
"EndX": 256,
|
||||
"EndY": 192
|
||||
"StartTime": 3000.0,
|
||||
"EndTime": 4000.0,
|
||||
"X": 256.0,
|
||||
"Y": 192.0
|
||||
}]
|
||||
},
|
||||
{
|
||||
"StartTime": 4500,
|
||||
}, {
|
||||
"StartTime": 4500.0,
|
||||
"Objects": [{
|
||||
"StartTime": 4500,
|
||||
"EndTime": 5500,
|
||||
"StartX": 256,
|
||||
"StartY": 192,
|
||||
"EndX": 256,
|
||||
"EndY": 192
|
||||
"StartTime": 4500.0,
|
||||
"EndTime": 5500.0,
|
||||
"X": 256.0,
|
||||
"Y": 192.0
|
||||
}]
|
||||
},
|
||||
{
|
||||
"StartTime": 6000,
|
||||
}, {
|
||||
"StartTime": 6000.0,
|
||||
"Objects": [{
|
||||
"StartTime": 6000,
|
||||
"EndTime": 6500,
|
||||
"StartX": 256,
|
||||
"StartY": 192,
|
||||
"EndX": 256,
|
||||
"EndY": 192
|
||||
"StartTime": 6000.0,
|
||||
"EndTime": 6500.0,
|
||||
"X": 256.0,
|
||||
"Y": 192.0
|
||||
}]
|
||||
},
|
||||
{
|
||||
"StartTime": 7000,
|
||||
}, {
|
||||
"StartTime": 7000.0,
|
||||
"Objects": [{
|
||||
"StartTime": 7000,
|
||||
"EndTime": 8000,
|
||||
"StartX": 256,
|
||||
"StartY": 128,
|
||||
"EndX": 256,
|
||||
"EndY": 128
|
||||
"StartTime": 7000.0,
|
||||
"EndTime": 7000.0,
|
||||
"X": 256.0,
|
||||
"Y": 128.0
|
||||
}, {
|
||||
"StartTime": 7250.0,
|
||||
"EndTime": 7250.0,
|
||||
"X": 336.0,
|
||||
"Y": 128.0
|
||||
}, {
|
||||
"StartTime": 7500.0,
|
||||
"EndTime": 7500.0,
|
||||
"X": 256.0,
|
||||
"Y": 128.0
|
||||
}, {
|
||||
"StartTime": 7750.0,
|
||||
"EndTime": 7750.0,
|
||||
"X": 336.0,
|
||||
"Y": 128.0
|
||||
}, {
|
||||
"StartTime": 7964.0,
|
||||
"EndTime": 7964.0,
|
||||
"X": 256.0,
|
||||
"Y": 128.0
|
||||
}]
|
||||
},
|
||||
{
|
||||
"StartTime": 8500,
|
||||
}, {
|
||||
"StartTime": 8500.0,
|
||||
"Objects": [{
|
||||
"StartTime": 8500,
|
||||
"EndTime": 10999,
|
||||
"StartX": 32,
|
||||
"StartY": 192,
|
||||
"EndX": 508.166229,
|
||||
"EndY": 153.299271
|
||||
"StartTime": 8500.0,
|
||||
"EndTime": 8500.0,
|
||||
"X": 32.0,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 9000.0,
|
||||
"EndTime": 9000.0,
|
||||
"X": 101.81015,
|
||||
"Y": 326.4915
|
||||
}, {
|
||||
"StartTime": 9500.0,
|
||||
"EndTime": 9500.0,
|
||||
"X": 237.2304,
|
||||
"Y": 276.282928
|
||||
}, {
|
||||
"StartTime": 10000.0,
|
||||
"EndTime": 10000.0,
|
||||
"X": 270.339874,
|
||||
"Y": 121.1423
|
||||
}, {
|
||||
"StartTime": 10500.0,
|
||||
"EndTime": 10500.0,
|
||||
"X": 401.0588,
|
||||
"Y": 49.1515045
|
||||
}, {
|
||||
"StartTime": 10964.0,
|
||||
"EndTime": 10964.0,
|
||||
"X": 508.166229,
|
||||
"Y": 153.299271
|
||||
}]
|
||||
},
|
||||
{
|
||||
"StartTime": 11500,
|
||||
}, {
|
||||
"StartTime": 11500.0,
|
||||
"Objects": [{
|
||||
"StartTime": 11500,
|
||||
"EndTime": 12000,
|
||||
"StartX": 256,
|
||||
"StartY": 192,
|
||||
"EndX": 256,
|
||||
"EndY": 192
|
||||
"StartTime": 11500.0,
|
||||
"EndTime": 12000.0,
|
||||
"X": 256.0,
|
||||
"Y": 192.0
|
||||
}]
|
||||
},
|
||||
{
|
||||
"StartTime": 12500,
|
||||
}, {
|
||||
"StartTime": 12500.0,
|
||||
"Objects": [{
|
||||
"StartTime": 12500,
|
||||
"EndTime": 16500,
|
||||
"StartX": 512,
|
||||
"StartY": 320,
|
||||
"EndX": 291.1977,
|
||||
"EndY": 40.799427
|
||||
"StartTime": 12500.0,
|
||||
"EndTime": 12500.0,
|
||||
"X": 512.0,
|
||||
"Y": 320.0
|
||||
}, {
|
||||
"StartTime": 13000.0,
|
||||
"EndTime": 13000.0,
|
||||
"X": 353.235535,
|
||||
"Y": 300.154449
|
||||
}, {
|
||||
"StartTime": 13500.0,
|
||||
"EndTime": 13500.0,
|
||||
"X": 194.471069,
|
||||
"Y": 280.3089
|
||||
}, {
|
||||
"StartTime": 14000.0,
|
||||
"EndTime": 14000.0,
|
||||
"X": 35.7066345,
|
||||
"Y": 260.463318
|
||||
}, {
|
||||
"StartTime": 14500.0,
|
||||
"EndTime": 14500.0,
|
||||
"X": 118.370323,
|
||||
"Y": 219.009277
|
||||
}, {
|
||||
"StartTime": 15000.0,
|
||||
"EndTime": 15000.0,
|
||||
"X": 271.087128,
|
||||
"Y": 171.285278
|
||||
}, {
|
||||
"StartTime": 15500.0,
|
||||
"EndTime": 15500.0,
|
||||
"X": 423.803925,
|
||||
"Y": 123.561279
|
||||
}, {
|
||||
"StartTime": 16000.0,
|
||||
"EndTime": 16000.0,
|
||||
"X": 446.420532,
|
||||
"Y": 79.60513
|
||||
}, {
|
||||
"StartTime": 16464.0,
|
||||
"EndTime": 16464.0,
|
||||
"X": 291.1977,
|
||||
"Y": 40.799427
|
||||
}]
|
||||
},
|
||||
{
|
||||
"StartTime": 17000,
|
||||
}, {
|
||||
"StartTime": 17000.0,
|
||||
"Objects": [{
|
||||
"StartTime": 17000,
|
||||
"EndTime": 18000,
|
||||
"StartX": 256,
|
||||
"StartY": 256,
|
||||
"EndX": 256,
|
||||
"EndY": 256
|
||||
"StartTime": 17000.0,
|
||||
"EndTime": 17000.0,
|
||||
"X": 256.0,
|
||||
"Y": 256.0
|
||||
}, {
|
||||
"StartTime": 17250.0,
|
||||
"EndTime": 17250.0,
|
||||
"X": 176.0,
|
||||
"Y": 256.0
|
||||
}, {
|
||||
"StartTime": 17500.0,
|
||||
"EndTime": 17500.0,
|
||||
"X": 256.0,
|
||||
"Y": 256.0
|
||||
}, {
|
||||
"StartTime": 17750.0,
|
||||
"EndTime": 17750.0,
|
||||
"X": 176.0,
|
||||
"Y": 256.0
|
||||
}, {
|
||||
"StartTime": 17964.0,
|
||||
"EndTime": 17964.0,
|
||||
"X": 256.0,
|
||||
"Y": 256.0
|
||||
}]
|
||||
},
|
||||
{
|
||||
"StartTime": 18500,
|
||||
}, {
|
||||
"StartTime": 18500.0,
|
||||
"Objects": [{
|
||||
"StartTime": 18500,
|
||||
"EndTime": 19450,
|
||||
"StartX": 256,
|
||||
"StartY": 192,
|
||||
"EndX": 256,
|
||||
"EndY": 192
|
||||
"StartTime": 18500.0,
|
||||
"EndTime": 19450.0,
|
||||
"X": 256.0,
|
||||
"Y": 192.0
|
||||
}]
|
||||
},
|
||||
{
|
||||
"StartTime": 19875,
|
||||
}, {
|
||||
"StartTime": 19875.0,
|
||||
"Objects": [{
|
||||
"StartTime": 19875,
|
||||
"EndTime": 23874,
|
||||
"StartX": 216,
|
||||
"StartY": 231,
|
||||
"EndX": 408.720825,
|
||||
"EndY": 339.810455
|
||||
"StartTime": 19875.0,
|
||||
"EndTime": 19875.0,
|
||||
"X": 216.0,
|
||||
"Y": 231.0
|
||||
}, {
|
||||
"StartTime": 20375.0,
|
||||
"EndTime": 20375.0,
|
||||
"X": 317.446747,
|
||||
"Y": 171.345245
|
||||
}, {
|
||||
"StartTime": 20875.0,
|
||||
"EndTime": 20875.0,
|
||||
"X": 270.3294,
|
||||
"Y": 310.4395
|
||||
}, {
|
||||
"StartTime": 21375.0,
|
||||
"EndTime": 21375.0,
|
||||
"X": 119.121056,
|
||||
"Y": 322.8657
|
||||
}, {
|
||||
"StartTime": 21875.0,
|
||||
"EndTime": 21875.0,
|
||||
"X": 124.28746,
|
||||
"Y": 165.224731
|
||||
}, {
|
||||
"StartTime": 22375.0,
|
||||
"EndTime": 22375.0,
|
||||
"X": 240.4715,
|
||||
"Y": 62.65587
|
||||
}, {
|
||||
"StartTime": 22875.0,
|
||||
"EndTime": 22875.0,
|
||||
"X": 398.054047,
|
||||
"Y": 39.064167
|
||||
}, {
|
||||
"StartTime": 23375.0,
|
||||
"EndTime": 23375.0,
|
||||
"X": 439.749878,
|
||||
"Y": 183.668091
|
||||
}, {
|
||||
"StartTime": 23839.0,
|
||||
"EndTime": 23839.0,
|
||||
"X": 408.720825,
|
||||
"Y": 339.810455
|
||||
}]
|
||||
}]
|
||||
}
|
||||
]
|
||||
}
|
@ -1,13 +1,16 @@
|
||||
{
|
||||
"Mappings": [{
|
||||
"StartTime": 118858,
|
||||
"StartTime": 118858.0,
|
||||
"Objects": [{
|
||||
"StartTime": 118858,
|
||||
"EndTime": 119088,
|
||||
"StartX": 219,
|
||||
"StartY": 215,
|
||||
"EndX": 239.6507,
|
||||
"EndY": 29.1437378
|
||||
"StartTime": 118858.0,
|
||||
"EndTime": 118858.0,
|
||||
"X": 219.0,
|
||||
"Y": 215.0
|
||||
}, {
|
||||
"StartTime": 119052.0,
|
||||
"EndTime": 119052.0,
|
||||
"X": 239.6507,
|
||||
"Y": 29.1437378
|
||||
}]
|
||||
}]
|
||||
}
|
@ -0,0 +1,331 @@
|
||||
{
|
||||
"Mappings": [{
|
||||
"StartTime": 500.0,
|
||||
"Objects": [{
|
||||
"StartTime": 500.0,
|
||||
"EndTime": 500.0,
|
||||
"X": 96.0,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 624.0,
|
||||
"EndTime": 624.0,
|
||||
"X": 105.921242,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 749.0,
|
||||
"EndTime": 749.0,
|
||||
"X": 115.922493,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 874.0,
|
||||
"EndTime": 874.0,
|
||||
"X": 125.923737,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 999.0,
|
||||
"EndTime": 999.0,
|
||||
"X": 135.924988,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 1124.0,
|
||||
"EndTime": 1124.0,
|
||||
"X": 145.926239,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 1249.0,
|
||||
"EndTime": 1249.0,
|
||||
"X": 155.92749,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 1374.0,
|
||||
"EndTime": 1374.0,
|
||||
"X": 165.928741,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 1499.0,
|
||||
"EndTime": 1499.0,
|
||||
"X": 175.93,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 1624.0,
|
||||
"EndTime": 1624.0,
|
||||
"X": 185.931244,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 1749.0,
|
||||
"EndTime": 1749.0,
|
||||
"X": 195.9325,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 1874.0,
|
||||
"EndTime": 1874.0,
|
||||
"X": 205.933746,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 1999.0,
|
||||
"EndTime": 1999.0,
|
||||
"X": 215.935,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 2124.0,
|
||||
"EndTime": 2124.0,
|
||||
"X": 225.936234,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 2249.0,
|
||||
"EndTime": 2249.0,
|
||||
"X": 235.9375,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 2374.0,
|
||||
"EndTime": 2374.0,
|
||||
"X": 245.938751,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 2499.0,
|
||||
"EndTime": 2499.0,
|
||||
"X": 255.94,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 2624.0,
|
||||
"EndTime": 2624.0,
|
||||
"X": 265.941223,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 2749.0,
|
||||
"EndTime": 2749.0,
|
||||
"X": 275.9425,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 2874.0,
|
||||
"EndTime": 2874.0,
|
||||
"X": 285.943756,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 2999.0,
|
||||
"EndTime": 2999.0,
|
||||
"X": 295.945,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 3124.0,
|
||||
"EndTime": 3124.0,
|
||||
"X": 305.946259,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 3249.0,
|
||||
"EndTime": 3249.0,
|
||||
"X": 315.9475,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 3374.0,
|
||||
"EndTime": 3374.0,
|
||||
"X": 325.94873,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 3499.0,
|
||||
"EndTime": 3499.0,
|
||||
"X": 335.949982,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 3624.0,
|
||||
"EndTime": 3624.0,
|
||||
"X": 345.951233,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 3749.0,
|
||||
"EndTime": 3749.0,
|
||||
"X": 355.952484,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 3874.0,
|
||||
"EndTime": 3874.0,
|
||||
"X": 365.953766,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 3999.0,
|
||||
"EndTime": 3999.0,
|
||||
"X": 375.955,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 4124.0,
|
||||
"EndTime": 4124.0,
|
||||
"X": 385.956238,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 4249.0,
|
||||
"EndTime": 4249.0,
|
||||
"X": 395.9575,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 4374.0,
|
||||
"EndTime": 4374.0,
|
||||
"X": 405.95874,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 4499.0,
|
||||
"EndTime": 4499.0,
|
||||
"X": 415.960022,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 4624.0,
|
||||
"EndTime": 4624.0,
|
||||
"X": 406.038757,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 4749.0,
|
||||
"EndTime": 4749.0,
|
||||
"X": 396.0375,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 4874.0,
|
||||
"EndTime": 4874.0,
|
||||
"X": 386.036255,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 4999.0,
|
||||
"EndTime": 4999.0,
|
||||
"X": 376.035034,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 5124.0,
|
||||
"EndTime": 5124.0,
|
||||
"X": 366.033752,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 5249.0,
|
||||
"EndTime": 5249.0,
|
||||
"X": 356.0325,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 5374.0,
|
||||
"EndTime": 5374.0,
|
||||
"X": 346.03125,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 5499.0,
|
||||
"EndTime": 5499.0,
|
||||
"X": 336.030029,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 5624.0,
|
||||
"EndTime": 5624.0,
|
||||
"X": 326.028748,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 5749.0,
|
||||
"EndTime": 5749.0,
|
||||
"X": 316.0275,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 5874.0,
|
||||
"EndTime": 5874.0,
|
||||
"X": 306.026245,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 5999.0,
|
||||
"EndTime": 5999.0,
|
||||
"X": 296.025,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 6124.0,
|
||||
"EndTime": 6124.0,
|
||||
"X": 286.023773,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 6249.0,
|
||||
"EndTime": 6249.0,
|
||||
"X": 276.022522,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 6374.0,
|
||||
"EndTime": 6374.0,
|
||||
"X": 266.02124,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 6499.0,
|
||||
"EndTime": 6499.0,
|
||||
"X": 256.02,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 6624.0,
|
||||
"EndTime": 6624.0,
|
||||
"X": 246.018768,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 6749.0,
|
||||
"EndTime": 6749.0,
|
||||
"X": 236.017517,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 6874.0,
|
||||
"EndTime": 6874.0,
|
||||
"X": 226.016251,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 6999.0,
|
||||
"EndTime": 6999.0,
|
||||
"X": 216.014984,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 7124.0,
|
||||
"EndTime": 7124.0,
|
||||
"X": 206.013733,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 7249.0,
|
||||
"EndTime": 7249.0,
|
||||
"X": 196.012512,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 7374.0,
|
||||
"EndTime": 7374.0,
|
||||
"X": 186.011261,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 7499.0,
|
||||
"EndTime": 7499.0,
|
||||
"X": 176.01,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 7624.0,
|
||||
"EndTime": 7624.0,
|
||||
"X": 166.008728,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 7749.0,
|
||||
"EndTime": 7749.0,
|
||||
"X": 156.0075,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 7874.0,
|
||||
"EndTime": 7874.0,
|
||||
"X": 146.006256,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 7999.0,
|
||||
"EndTime": 7999.0,
|
||||
"X": 136.005,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 8124.0,
|
||||
"EndTime": 8124.0,
|
||||
"X": 126.003738,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 8249.0,
|
||||
"EndTime": 8249.0,
|
||||
"X": 116.002518,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 8374.0,
|
||||
"EndTime": 8374.0,
|
||||
"X": 106.001259,
|
||||
"Y": 192.0
|
||||
}, {
|
||||
"StartTime": 8463.0,
|
||||
"EndTime": 8463.0,
|
||||
"X": 96.0,
|
||||
"Y": 192.0
|
||||
}]
|
||||
}]
|
||||
}
|
@ -0,0 +1,20 @@
|
||||
osu file format v14
|
||||
|
||||
[General]
|
||||
StackLeniency: 0.7
|
||||
|
||||
[Difficulty]
|
||||
HPDrainRate:6
|
||||
CircleSize:4
|
||||
OverallDifficulty:7
|
||||
ApproachRate:8.3
|
||||
SliderMultiplier:0.400000005960464
|
||||
SliderTickRate:4
|
||||
|
||||
[TimingPoints]
|
||||
500,500,4,2,1,50,1,0
|
||||
13426,-100,4,3,1,45,0,0
|
||||
14884,-100,4,2,1,50,0,0
|
||||
|
||||
[HitObjects]
|
||||
96,192,500,6,0,L|416:192,2,320.000004768372
|
@ -12,7 +12,8 @@ using osu.Game.Tests.Beatmaps;
|
||||
|
||||
namespace osu.Game.Rulesets.Taiko.Tests
|
||||
{
|
||||
internal class TaikoBeatmapConversionTest : BeatmapConversionTest<ConvertValue>
|
||||
[TestFixture]
|
||||
public class TaikoBeatmapConversionTest : BeatmapConversionTest<ConvertValue>
|
||||
{
|
||||
protected override string ResourceAssembly => "osu.Game.Rulesets.Taiko";
|
||||
|
||||
@ -41,7 +42,7 @@ namespace osu.Game.Rulesets.Taiko.Tests
|
||||
protected override Ruleset CreateRuleset() => new TaikoRuleset();
|
||||
}
|
||||
|
||||
internal struct ConvertValue : IEquatable<ConvertValue>
|
||||
public struct ConvertValue : IEquatable<ConvertValue>
|
||||
{
|
||||
/// <summary>
|
||||
/// A sane value to account for osu!stable using ints everwhere.
|
||||
|
@ -10,7 +10,7 @@ using osu.Game.Beatmaps.ControlPoints;
|
||||
|
||||
namespace osu.Game.Rulesets.Objects.Legacy
|
||||
{
|
||||
internal abstract class ConvertSlider : HitObject, IHasCurve
|
||||
internal abstract class ConvertSlider : HitObject, IHasCurve, IHasLegacyLastTickOffset
|
||||
{
|
||||
/// <summary>
|
||||
/// Scoring distance with a speed-adjusted beat length of 1 second.
|
||||
@ -45,5 +45,7 @@ namespace osu.Game.Rulesets.Objects.Legacy
|
||||
|
||||
Velocity = scoringDistance / timingPoint.BeatLength;
|
||||
}
|
||||
|
||||
public double LegacyLastTickOffset => 36;
|
||||
}
|
||||
}
|
||||
|
14
osu.Game/Rulesets/Objects/Types/IHasLegacyLastTickOffset.cs
Normal file
14
osu.Game/Rulesets/Objects/Types/IHasLegacyLastTickOffset.cs
Normal file
@ -0,0 +1,14 @@
|
||||
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
||||
|
||||
namespace osu.Game.Rulesets.Objects.Types
|
||||
{
|
||||
/// <summary>
|
||||
/// A type of <see cref="HitObject"/> which may require the last tick to be offset.
|
||||
/// This is specific to osu!stable conversion, and should not be used elsewhere.
|
||||
/// </summary>
|
||||
public interface IHasLegacyLastTickOffset
|
||||
{
|
||||
double LegacyLastTickOffset { get; }
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user