mirror of
https://github.com/ppy/osu.git
synced 2025-02-19 13:12:54 +08:00
Tidy up Add
method logic
This commit is contained in:
parent
8f6df5ea0f
commit
15d65059b5
@ -3,7 +3,6 @@
|
|||||||
|
|
||||||
#nullable disable
|
#nullable disable
|
||||||
|
|
||||||
using System.Linq;
|
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Utils;
|
using osu.Framework.Utils;
|
||||||
@ -21,15 +20,16 @@ namespace osu.Game.Tests.Visual.Gameplay
|
|||||||
{
|
{
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Triggers = new InputTrigger[]
|
|
||||||
{
|
|
||||||
new KeyCounterKeyboardTrigger(Key.X),
|
|
||||||
new KeyCounterKeyboardTrigger(Key.X),
|
|
||||||
new KeyCounterMouseTrigger(MouseButton.Left),
|
|
||||||
new KeyCounterMouseTrigger(MouseButton.Right),
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
kc.AddTriggerRange(new InputTrigger[]
|
||||||
|
{
|
||||||
|
new KeyCounterKeyboardTrigger(Key.X),
|
||||||
|
new KeyCounterKeyboardTrigger(Key.X),
|
||||||
|
new KeyCounterMouseTrigger(MouseButton.Left),
|
||||||
|
new KeyCounterMouseTrigger(MouseButton.Right),
|
||||||
|
});
|
||||||
|
|
||||||
var testCounter = (DefaultKeyCounter)kc.Children.First();
|
var testCounter = (DefaultKeyCounter)kc.Children.First();
|
||||||
|
|
||||||
AddStep("Add random", () =>
|
AddStep("Add random", () =>
|
||||||
|
@ -25,16 +25,6 @@ namespace osu.Game.Screens.Play
|
|||||||
|
|
||||||
public Bindable<bool> IsCounting { get; } = new BindableBool(true);
|
public Bindable<bool> IsCounting { get; } = new BindableBool(true);
|
||||||
|
|
||||||
public IReadOnlyList<InputTrigger> Triggers
|
|
||||||
{
|
|
||||||
get => Children.Select(c => c.Trigger).ToArray();
|
|
||||||
set
|
|
||||||
{
|
|
||||||
Clear();
|
|
||||||
value.ForEach(AddTrigger);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected readonly Bindable<bool> ConfigVisibility = new Bindable<bool>();
|
protected readonly Bindable<bool> ConfigVisibility = new Bindable<bool>();
|
||||||
|
|
||||||
protected abstract void UpdateVisibility();
|
protected abstract void UpdateVisibility();
|
||||||
@ -60,17 +50,17 @@ namespace osu.Game.Screens.Play
|
|||||||
|
|
||||||
public void AddTriggerRange(IEnumerable<InputTrigger> triggers) => triggers.ForEach(AddTrigger);
|
public void AddTriggerRange(IEnumerable<InputTrigger> triggers) => triggers.ForEach(AddTrigger);
|
||||||
|
|
||||||
private bool checkType(KeyCounter key) => acceptedTypes.Length == 0 || acceptedTypes.Any(t => t.IsInstanceOfType(key));
|
public override void Add(KeyCounter counter)
|
||||||
|
|
||||||
public override void Add(KeyCounter key)
|
|
||||||
{
|
{
|
||||||
if (!checkType(key))
|
if (!checkType(counter))
|
||||||
throw new InvalidOperationException($"{key.GetType()} is not a supported counter type. (hint: you may want to use {nameof(AddTrigger)} instead.)");
|
throw new InvalidOperationException($"{counter.GetType()} is not a supported counter type. (hint: you may want to use {nameof(AddTrigger)} instead.)");
|
||||||
|
|
||||||
base.Add(key);
|
base.Add(counter);
|
||||||
key.IsCounting.BindTo(IsCounting);
|
counter.IsCounting.BindTo(IsCounting);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private bool checkType(KeyCounter counter) => acceptedTypes.Length == 0 || acceptedTypes.Any(t => t.IsInstanceOfType(counter));
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(OsuConfigManager config)
|
private void load(OsuConfigManager config)
|
||||||
{
|
{
|
||||||
@ -110,7 +100,7 @@ namespace osu.Game.Screens.Play
|
|||||||
case KeyUpEvent:
|
case KeyUpEvent:
|
||||||
case MouseDownEvent:
|
case MouseDownEvent:
|
||||||
case MouseUpEvent:
|
case MouseUpEvent:
|
||||||
return Target.Children.Any(c => c.TriggerEvent(e));
|
return Target.InternalChildren.Any(c => c.TriggerEvent(e));
|
||||||
}
|
}
|
||||||
|
|
||||||
return base.Handle(e);
|
return base.Handle(e);
|
||||||
|
Loading…
Reference in New Issue
Block a user