1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-02 05:42:54 +08:00
osu-lazer/osu.Game/Overlays/Settings/Sections/Input/KeyBindingsSubsection.cs

100 lines
3.3 KiB
C#
Raw Normal View History

// 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.
2018-04-13 17:19:50 +08:00
2022-06-17 15:37:17 +08:00
#nullable disable
2018-04-13 17:19:50 +08:00
using System.Collections.Generic;
using System.Linq;
using osu.Framework.Allocation;
using osu.Framework.Extensions.IEnumerableExtensions;
using osu.Framework.Graphics;
using osu.Framework.Localisation;
using osu.Game.Database;
using osu.Game.Input.Bindings;
2018-04-13 17:19:50 +08:00
using osu.Game.Rulesets;
using osu.Game.Localisation;
2018-11-20 15:51:59 +08:00
using osuTK;
2018-04-13 17:19:50 +08:00
namespace osu.Game.Overlays.Settings.Sections.Input
2018-04-13 17:19:50 +08:00
{
2022-11-24 13:32:20 +08:00
public abstract partial class KeyBindingsSubsection : SettingsSubsection
2018-04-13 17:19:50 +08:00
{
/// <summary>
/// After a successful binding, automatically select the next binding row to make quickly
/// binding a large set of keys easier on the user.
/// </summary>
protected virtual bool AutoAdvanceTarget => false;
2018-04-13 17:19:50 +08:00
protected IEnumerable<Framework.Input.Bindings.KeyBinding> Defaults;
public RulesetInfo Ruleset { get; protected set; }
2018-04-13 17:19:50 +08:00
private readonly int? variant;
protected KeyBindingsSubsection(int? variant)
{
this.variant = variant;
FlowContent.Spacing = new Vector2(0, 3);
2018-04-13 17:19:50 +08:00
}
[BackgroundDependencyLoader]
private void load(RealmAccess realm)
2018-04-13 17:19:50 +08:00
{
string rulesetName = Ruleset?.ShortName;
2018-04-13 17:19:50 +08:00
var bindings = realm.Run(r => r.All<RealmKeyBinding>()
.Where(b => b.RulesetName == rulesetName && b.Variant == variant)
.Detach());
foreach (var defaultGroup in Defaults.GroupBy(d => d.Action))
2018-04-13 17:19:50 +08:00
{
int intKey = (int)defaultGroup.Key;
2018-04-13 17:19:50 +08:00
// one row per valid action.
Add(new KeyBindingRow(defaultGroup.Key, bindings.Where(b => b.ActionInt.Equals(intKey)).ToList())
2018-04-13 17:19:50 +08:00
{
AllowMainMouseButtons = Ruleset != null,
Defaults = defaultGroup.Select(d => d.KeyCombination),
2022-11-18 12:55:37 +08:00
BindingUpdated = onBindingUpdated
});
2018-04-13 17:19:50 +08:00
}
Add(new ResetButton
{
Action = () => Children.OfType<KeyBindingRow>().ForEach(k => k.RestoreDefaults())
});
}
2022-11-18 12:55:37 +08:00
private void onBindingUpdated(KeyBindingRow sender)
{
if (AutoAdvanceTarget)
{
var next = Children.SkipWhile(c => c != sender).Skip(1).FirstOrDefault();
if (next != null)
GetContainingInputManager().ChangeFocus(next);
}
}
2018-04-13 17:19:50 +08:00
}
2022-11-24 13:32:20 +08:00
public partial class ResetButton : DangerousSettingsButton
2018-04-13 17:19:50 +08:00
{
[BackgroundDependencyLoader]
private void load()
2018-04-13 17:19:50 +08:00
{
Text = InputSettingsStrings.ResetSectionButton;
2018-04-13 17:19:50 +08:00
RelativeSizeAxes = Axes.X;
Width = 0.8f;
Anchor = Anchor.TopCentre;
Origin = Anchor.TopCentre;
Margin = new MarginPadding { Top = 15 };
Height = 30;
2018-04-13 17:19:50 +08:00
Content.CornerRadius = 5;
}
// Empty FilterTerms so that the ResetButton is visible only when the whole subsection is visible.
public override IEnumerable<LocalisableString> FilterTerms => Enumerable.Empty<LocalisableString>();
2018-04-13 17:19:50 +08:00
}
}