Skip to content

Commit

Permalink
Merge pull request #25230 from bdach/double-click-disabled-slider
Browse files Browse the repository at this point in the history
Do not revert to default value when double-clicking disabled slider
  • Loading branch information
frenzibyte committed Oct 26, 2023
2 parents b078748 + 54b6933 commit 3930e41
Show file tree
Hide file tree
Showing 4 changed files with 64 additions and 26 deletions.
39 changes: 27 additions & 12 deletions osu.Game.Tests/Visual/UserInterface/TestSceneRoundedSliderBar.cs
Original file line number Diff line number Diff line change
Expand Up @@ -18,26 +18,24 @@ public partial class TestSceneRoundedSliderBar : OsuManualInputManagerTestScene
[Cached]
private OverlayColourProvider colourProvider { get; set; } = new OverlayColourProvider(OverlayColourScheme.Purple);

private readonly BindableDouble current = new BindableDouble(5)
{
Precision = 0.1f,
MinValue = 0,
MaxValue = 15
};

private RoundedSliderBar<double> slider = null!;

[BackgroundDependencyLoader]
private void load()
[SetUpSteps]
public void SetUpSteps()
{
Child = slider = new RoundedSliderBar<double>
AddStep("create slider", () => Child = slider = new RoundedSliderBar<double>
{
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
Current = current,
Current = new BindableDouble(5)
{
Precision = 0.1,
MinValue = 0,
MaxValue = 15
},
RelativeSizeAxes = Axes.X,
Width = 0.4f
};
});
}

[Test]
Expand All @@ -55,5 +53,22 @@ public void TestNubDoubleClickRevertToDefault()

AddAssert("slider is default", () => slider.Current.IsDefault);
}

[Test]
public void TestNubDoubleClickOnDisabledSliderDoesNothing()
{
AddStep("set slider to 1", () => slider.Current.Value = 1);
AddStep("disable slider", () => slider.Current.Disabled = true);

AddStep("move mouse to nub", () => InputManager.MoveMouseTo(slider.ChildrenOfType<Nub>().Single()));

AddStep("double click nub", () =>
{
InputManager.Click(MouseButton.Left);
InputManager.Click(MouseButton.Left);
});

AddAssert("slider is still at 1", () => slider.Current.Value, () => Is.EqualTo(1));
}
}
}
39 changes: 27 additions & 12 deletions osu.Game.Tests/Visual/UserInterface/TestSceneShearedSliderBar.cs
Original file line number Diff line number Diff line change
Expand Up @@ -18,26 +18,24 @@ public partial class TestSceneShearedSliderBar : OsuManualInputManagerTestScene
[Cached]
private OverlayColourProvider colourProvider { get; set; } = new OverlayColourProvider(OverlayColourScheme.Purple);

private readonly BindableDouble current = new BindableDouble(5)
{
Precision = 0.1f,
MinValue = 0,
MaxValue = 15
};

private ShearedSliderBar<double> slider = null!;

[BackgroundDependencyLoader]
private void load()
[SetUpSteps]
public void SetUpSteps()
{
Child = slider = new ShearedSliderBar<double>
AddStep("create slider", () => Child = slider = new ShearedSliderBar<double>
{
Anchor = Anchor.Centre,
Origin = Anchor.Centre,
Current = current,
Current = new BindableDouble(5)
{
Precision = 0.1,
MinValue = 0,
MaxValue = 15
},
RelativeSizeAxes = Axes.X,
Width = 0.4f
};
});
}

[Test]
Expand All @@ -55,5 +53,22 @@ public void TestNubDoubleClickRevertToDefault()

AddAssert("slider is default", () => slider.Current.IsDefault);
}

[Test]
public void TestNubDoubleClickOnDisabledSliderDoesNothing()
{
AddStep("set slider to 1", () => slider.Current.Value = 1);
AddStep("disable slider", () => slider.Current.Disabled = true);

AddStep("move mouse to nub", () => InputManager.MoveMouseTo(slider.ChildrenOfType<ShearedNub>().Single()));

AddStep("double click nub", () =>
{
InputManager.Click(MouseButton.Left);
InputManager.Click(MouseButton.Left);
});

AddAssert("slider is still at 1", () => slider.Current.Value, () => Is.EqualTo(1));
}
}
}
6 changes: 5 additions & 1 deletion osu.Game/Graphics/UserInterface/RoundedSliderBar.cs
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,11 @@ public RoundedSliderBar()
Origin = Anchor.TopCentre,
RelativePositionAxes = Axes.X,
Current = { Value = true },
OnDoubleClicked = () => Current.SetDefault(),
OnDoubleClicked = () =>
{
if (!Current.Disabled)
Current.SetDefault();
},
},
},
hoverClickSounds = new HoverClickSounds()
Expand Down
6 changes: 5 additions & 1 deletion osu.Game/Graphics/UserInterface/ShearedSliderBar.cs
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,11 @@ public ShearedSliderBar()
Origin = Anchor.TopCentre,
RelativePositionAxes = Axes.X,
Current = { Value = true },
OnDoubleClicked = () => Current.SetDefault(),
OnDoubleClicked = () =>
{
if (!Current.Disabled)
Current.SetDefault();
},
},
},
hoverClickSounds = new HoverClickSounds()
Expand Down

0 comments on commit 3930e41

Please sign in to comment.