mirror of
https://github.com/ppy/osu.git
synced 2025-02-01 19:13:22 +08:00
Merge pull request #8329 from Fuewburvpoa/MyBranch
Fix beat divisor control selecting invalid divisors on drag end
This commit is contained in:
commit
febf9adabd
@ -3,27 +3,83 @@
|
|||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using osu.Framework.Allocation;
|
using System.Linq;
|
||||||
|
using NUnit.Framework;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Shapes;
|
||||||
|
using osu.Framework.Graphics.UserInterface;
|
||||||
|
using osu.Framework.Testing;
|
||||||
using osu.Game.Screens.Edit;
|
using osu.Game.Screens.Edit;
|
||||||
using osu.Game.Screens.Edit.Compose.Components;
|
using osu.Game.Screens.Edit.Compose.Components;
|
||||||
using osuTK;
|
using osuTK;
|
||||||
|
using osuTK.Input;
|
||||||
|
|
||||||
namespace osu.Game.Tests.Visual.Editor
|
namespace osu.Game.Tests.Visual.Editor
|
||||||
{
|
{
|
||||||
public class TestSceneBeatDivisorControl : OsuTestScene
|
public class TestSceneBeatDivisorControl : ManualInputManagerTestScene
|
||||||
{
|
{
|
||||||
public override IReadOnlyList<Type> RequiredTypes => new[] { typeof(BindableBeatDivisor) };
|
public override IReadOnlyList<Type> RequiredTypes => new[] { typeof(BindableBeatDivisor) };
|
||||||
|
private BeatDivisorControl beatDivisorControl;
|
||||||
|
private BindableBeatDivisor bindableBeatDivisor;
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
private SliderBar<int> tickSliderBar;
|
||||||
private void load()
|
private EquilateralTriangle tickMarkerHead;
|
||||||
|
|
||||||
|
[SetUp]
|
||||||
|
public void SetUp() => Schedule(() =>
|
||||||
{
|
{
|
||||||
Child = new BeatDivisorControl(new BindableBeatDivisor())
|
Child = beatDivisorControl = new BeatDivisorControl(bindableBeatDivisor = new BindableBeatDivisor(16))
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
Size = new Vector2(90, 90)
|
Size = new Vector2(90, 90)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
tickSliderBar = beatDivisorControl.ChildrenOfType<SliderBar<int>>().Single();
|
||||||
|
tickMarkerHead = tickSliderBar.ChildrenOfType<EquilateralTriangle>().Single();
|
||||||
|
});
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestBindableBeatDivisor()
|
||||||
|
{
|
||||||
|
AddRepeatStep("move previous", () => bindableBeatDivisor.Previous(), 4);
|
||||||
|
AddAssert("divisor is 4", () => bindableBeatDivisor.Value == 4);
|
||||||
|
AddRepeatStep("move next", () => bindableBeatDivisor.Next(), 3);
|
||||||
|
AddAssert("divisor is 12", () => bindableBeatDivisor.Value == 12);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestMouseInput()
|
||||||
|
{
|
||||||
|
AddStep("hold marker", () =>
|
||||||
|
{
|
||||||
|
InputManager.MoveMouseTo(tickMarkerHead.ScreenSpaceDrawQuad.Centre);
|
||||||
|
InputManager.PressButton(MouseButton.Left);
|
||||||
|
});
|
||||||
|
AddStep("move to 8 and release", () =>
|
||||||
|
{
|
||||||
|
InputManager.MoveMouseTo(tickSliderBar.ScreenSpaceDrawQuad.Centre);
|
||||||
|
InputManager.ReleaseButton(MouseButton.Left);
|
||||||
|
});
|
||||||
|
AddAssert("divisor is 8", () => bindableBeatDivisor.Value == 8);
|
||||||
|
AddStep("hold marker", () => InputManager.PressButton(MouseButton.Left));
|
||||||
|
AddStep("move to 16", () => InputManager.MoveMouseTo(getPositionForDivisor(16)));
|
||||||
|
AddStep("move to ~10 and release", () =>
|
||||||
|
{
|
||||||
|
InputManager.MoveMouseTo(getPositionForDivisor(10));
|
||||||
|
InputManager.ReleaseButton(MouseButton.Left);
|
||||||
|
});
|
||||||
|
AddAssert("divisor clamped to 8", () => bindableBeatDivisor.Value == 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
private Vector2 getPositionForDivisor(int divisor)
|
||||||
|
{
|
||||||
|
var relativePosition = (float)Math.Clamp(divisor, 0, 16) / 16;
|
||||||
|
var sliderDrawQuad = tickSliderBar.ScreenSpaceDrawQuad;
|
||||||
|
return new Vector2(
|
||||||
|
sliderDrawQuad.TopLeft.X + sliderDrawQuad.Width * relativePosition,
|
||||||
|
sliderDrawQuad.Centre.Y
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -279,6 +279,11 @@ namespace osu.Game.Screens.Edit.Compose.Components
|
|||||||
handleMouseInput(e.ScreenSpaceMousePosition);
|
handleMouseInput(e.ScreenSpaceMousePosition);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected override void OnDragEnd(DragEndEvent e)
|
||||||
|
{
|
||||||
|
handleMouseInput(e.ScreenSpaceMousePosition);
|
||||||
|
}
|
||||||
|
|
||||||
private void handleMouseInput(Vector2 screenSpaceMousePosition)
|
private void handleMouseInput(Vector2 screenSpaceMousePosition)
|
||||||
{
|
{
|
||||||
// copied from SliderBar so we can do custom spacing logic.
|
// copied from SliderBar so we can do custom spacing logic.
|
||||||
|
Loading…
Reference in New Issue
Block a user