mirror of
https://github.com/ppy/osu.git
synced 2025-01-02 07:53:21 +08:00
3278a1d7d8
There were two coordinate systems used: - 0..512 (used in osu!stable) - 0..1 (relative coordinate) This commit replaces the usage of the relative coordinate system to the coordinate system of 0..512.
98 lines
3.3 KiB
C#
98 lines
3.3 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.
|
|
|
|
using System;
|
|
using System.Linq;
|
|
using NUnit.Framework;
|
|
using osu.Framework.Testing;
|
|
using osu.Game.Beatmaps;
|
|
using osu.Game.Rulesets.Catch.Objects;
|
|
using osu.Game.Rulesets.Catch.UI;
|
|
using osu.Game.Rulesets.Objects;
|
|
using osuTK;
|
|
|
|
namespace osu.Game.Rulesets.Catch.Tests
|
|
{
|
|
[TestFixture]
|
|
public class TestSceneHyperDash : TestSceneCatchPlayer
|
|
{
|
|
protected override bool Autoplay => true;
|
|
|
|
[Test]
|
|
public void TestHyperDash()
|
|
{
|
|
AddAssert("First note is hyperdash", () => Beatmap.Value.Beatmap.HitObjects[0] is Fruit f && f.HyperDash);
|
|
AddUntilStep("wait for right movement", () => getCatcher().Scale.X > 0); // don't check hyperdashing as it happens too fast.
|
|
|
|
AddUntilStep("wait for left movement", () => getCatcher().Scale.X < 0);
|
|
|
|
for (int i = 0; i < 3; i++)
|
|
{
|
|
AddUntilStep("wait for right hyperdash", () => getCatcher().Scale.X > 0 && getCatcher().HyperDashing);
|
|
AddUntilStep("wait for left hyperdash", () => getCatcher().Scale.X < 0 && getCatcher().HyperDashing);
|
|
}
|
|
}
|
|
|
|
private Catcher getCatcher() => Player.ChildrenOfType<CatcherArea>().First().MovableCatcher;
|
|
|
|
protected override IBeatmap CreateBeatmap(RulesetInfo ruleset)
|
|
{
|
|
var beatmap = new Beatmap
|
|
{
|
|
BeatmapInfo =
|
|
{
|
|
Ruleset = ruleset,
|
|
BaseDifficulty = new BeatmapDifficulty { CircleSize = 3.6f }
|
|
}
|
|
};
|
|
|
|
// Should produce a hyper-dash (edge case test)
|
|
beatmap.HitObjects.Add(new Fruit { StartTime = 1816, X = 56, NewCombo = true });
|
|
beatmap.HitObjects.Add(new Fruit { StartTime = 2008, X = 308, NewCombo = true });
|
|
|
|
double startTime = 3000;
|
|
|
|
const float left_x = 0.02f * CatchPlayfield.WIDTH;
|
|
const float right_x = 0.98f * CatchPlayfield.WIDTH;
|
|
|
|
createObjects(() => new Fruit { X = left_x });
|
|
createObjects(() => new TestJuiceStream(right_x), 1);
|
|
createObjects(() => new TestJuiceStream(left_x), 1);
|
|
createObjects(() => new Fruit { X = right_x });
|
|
createObjects(() => new Fruit { X = left_x });
|
|
createObjects(() => new Fruit { X = right_x });
|
|
createObjects(() => new TestJuiceStream(left_x), 1);
|
|
|
|
return beatmap;
|
|
|
|
void createObjects(Func<CatchHitObject> createObject, int count = 3)
|
|
{
|
|
const float spacing = 140;
|
|
|
|
for (int i = 0; i < count; i++)
|
|
{
|
|
var hitObject = createObject();
|
|
hitObject.StartTime = startTime + i * spacing;
|
|
beatmap.HitObjects.Add(hitObject);
|
|
}
|
|
|
|
startTime += 700;
|
|
}
|
|
}
|
|
|
|
private class TestJuiceStream : JuiceStream
|
|
{
|
|
public TestJuiceStream(float x)
|
|
{
|
|
X = x;
|
|
|
|
Path = new SliderPath(new[]
|
|
{
|
|
new PathControlPoint(Vector2.Zero),
|
|
new PathControlPoint(new Vector2(30, 0)),
|
|
});
|
|
}
|
|
}
|
|
}
|
|
}
|