mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 12:45:09 +08:00
Add visual tests for strong hit explosions
This commit is contained in:
parent
e119b78e81
commit
026fc2023b
44
osu.Game.Rulesets.Taiko.Tests/DrawableTestStrongHit.cs
Normal file
44
osu.Game.Rulesets.Taiko.Tests/DrawableTestStrongHit.cs
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
// 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.Linq;
|
||||||
|
using osu.Game.Beatmaps;
|
||||||
|
using osu.Game.Beatmaps.ControlPoints;
|
||||||
|
using osu.Game.Rulesets.Scoring;
|
||||||
|
using osu.Game.Rulesets.Taiko.Objects;
|
||||||
|
using osu.Game.Rulesets.Taiko.Objects.Drawables;
|
||||||
|
|
||||||
|
namespace osu.Game.Rulesets.Taiko.Tests
|
||||||
|
{
|
||||||
|
public class DrawableTestStrongHit : DrawableHit
|
||||||
|
{
|
||||||
|
private readonly HitResult type;
|
||||||
|
private readonly bool hitBoth;
|
||||||
|
|
||||||
|
public DrawableTestStrongHit(double startTime, HitResult type = HitResult.Great, bool hitBoth = true)
|
||||||
|
: base(new Hit
|
||||||
|
{
|
||||||
|
IsStrong = true,
|
||||||
|
StartTime = startTime,
|
||||||
|
})
|
||||||
|
{
|
||||||
|
// in order to create nested strong hit
|
||||||
|
HitObject.ApplyDefaults(new ControlPointInfo(), new BeatmapDifficulty());
|
||||||
|
|
||||||
|
this.type = type;
|
||||||
|
this.hitBoth = hitBoth;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void LoadAsyncComplete()
|
||||||
|
{
|
||||||
|
base.LoadAsyncComplete();
|
||||||
|
|
||||||
|
Result.Type = type;
|
||||||
|
|
||||||
|
var nestedStrongHit = (DrawableStrongNestedHit)NestedHitObjects.Single();
|
||||||
|
nestedStrongHit.Result.Type = hitBoth ? type : HitResult.Miss;
|
||||||
|
}
|
||||||
|
|
||||||
|
public override bool OnPressed(TaikoAction action) => false;
|
||||||
|
}
|
||||||
|
}
|
@ -2,7 +2,6 @@
|
|||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
using osu.Game.Rulesets.Scoring;
|
using osu.Game.Rulesets.Scoring;
|
||||||
@ -15,24 +14,29 @@ namespace osu.Game.Rulesets.Taiko.Tests.Skinning
|
|||||||
[TestFixture]
|
[TestFixture]
|
||||||
public class TestSceneHitExplosion : TaikoSkinnableTestScene
|
public class TestSceneHitExplosion : TaikoSkinnableTestScene
|
||||||
{
|
{
|
||||||
[BackgroundDependencyLoader]
|
[Test]
|
||||||
private void load()
|
public void TestNormalHit()
|
||||||
{
|
{
|
||||||
AddStep("Great", () => SetContents(() => getContentFor(HitResult.Great)));
|
AddStep("Great", () => SetContents(() => getContentFor(createHit(HitResult.Great))));
|
||||||
AddStep("Good", () => SetContents(() => getContentFor(HitResult.Good)));
|
AddStep("Good", () => SetContents(() => getContentFor(createHit(HitResult.Good))));
|
||||||
AddStep("Miss", () => SetContents(() => getContentFor(HitResult.Miss)));
|
AddStep("Miss", () => SetContents(() => getContentFor(createHit(HitResult.Miss))));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Drawable getContentFor(HitResult type)
|
[Test]
|
||||||
|
public void TestStrongHit([Values(false, true)] bool hitBoth)
|
||||||
{
|
{
|
||||||
DrawableTaikoHitObject hit;
|
AddStep("Great", () => SetContents(() => getContentFor(createStrongHit(HitResult.Great, hitBoth))));
|
||||||
|
AddStep("Good", () => SetContents(() => getContentFor(createStrongHit(HitResult.Good, hitBoth))));
|
||||||
|
}
|
||||||
|
|
||||||
|
private Drawable getContentFor(DrawableTaikoHitObject hit)
|
||||||
|
{
|
||||||
return new Container
|
return new Container
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
Children = new Drawable[]
|
Children = new Drawable[]
|
||||||
{
|
{
|
||||||
hit = createHit(type),
|
hit,
|
||||||
new HitExplosion(hit)
|
new HitExplosion(hit)
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
@ -43,5 +47,8 @@ namespace osu.Game.Rulesets.Taiko.Tests.Skinning
|
|||||||
}
|
}
|
||||||
|
|
||||||
private DrawableTaikoHitObject createHit(HitResult type) => new DrawableTestHit(new Hit { StartTime = Time.Current }, type);
|
private DrawableTaikoHitObject createHit(HitResult type) => new DrawableTestHit(new Hit { StartTime = Time.Current }, type);
|
||||||
|
|
||||||
|
private DrawableTaikoHitObject createStrongHit(HitResult type, bool hitBoth)
|
||||||
|
=> new DrawableTestStrongHit(Time.Current, type, hitBoth);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user