Skip to content

Commit

Permalink
Enable NRT in KeyBindingRow
Browse files Browse the repository at this point in the history
  • Loading branch information
bdach committed Oct 11, 2023
1 parent 0b2b065 commit 797109c
Showing 1 changed file with 34 additions and 15 deletions.
49 changes: 34 additions & 15 deletions osu.Game/Overlays/Settings/Sections/Input/KeyBindingRow.cs
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
// 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.

#nullable disable

using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using osu.Framework.Allocation;
using osu.Framework.Bindables;
using osu.Framework.Extensions;
using osu.Framework.Extensions.Color4Extensions;
using osu.Framework.Extensions.ObjectExtensions;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Effects;
Expand Down Expand Up @@ -37,7 +37,7 @@ public partial class KeyBindingRow : Container, IFilterable
/// <summary>
/// Invoked when the binding of this row is updated with a change being written.
/// </summary>
public Action<KeyBindingRow> BindingUpdated { get; init; }
public Action<KeyBindingRow>? BindingUpdated { get; init; }

/// <summary>
/// Whether left and right mouse button clicks should be included in the edited bindings.
Expand All @@ -47,7 +47,7 @@ public partial class KeyBindingRow : Container, IFilterable
/// <summary>
/// The default key bindings for this row.
/// </summary>
public IEnumerable<KeyCombination> Defaults { get; init; }
public IEnumerable<KeyCombination> Defaults { get; init; } = Array.Empty<KeyCombination>();

#region IFilterable

Expand Down Expand Up @@ -75,18 +75,18 @@ public bool MatchingFilter
private Bindable<bool> isDefault { get; } = new BindableBool(true);

[Resolved]
private ReadableKeyCombinationProvider keyCombinationProvider { get; set; }
private ReadableKeyCombinationProvider keyCombinationProvider { get; set; } = null!;

[Resolved]
private RealmAccess realm { get; set; }
private RealmAccess realm { get; set; } = null!;

private Container content;
private Container content = null!;

private OsuSpriteText text;
private FillFlowContainer cancelAndClearButtons;
private FillFlowContainer<KeyButton> buttons;
private OsuSpriteText text = null!;
private FillFlowContainer cancelAndClearButtons = null!;
private FillFlowContainer<KeyButton> buttons = null!;

private KeyButton bindTarget;
private KeyButton? bindTarget;

private const float transition_time = 150;
private const float height = 20;
Expand Down Expand Up @@ -232,7 +232,12 @@ protected override void OnHoverLost(HoverLostEvent e)

protected override bool OnMouseDown(MouseDownEvent e)
{
if (!HasFocus || !bindTarget.IsHovered)
if (!HasFocus)
return base.OnMouseDown(e);

Debug.Assert(bindTarget != null);

if (!bindTarget.IsHovered)
return base.OnMouseDown(e);

if (!AllowMainMouseButtons)
Expand All @@ -258,6 +263,8 @@ protected override void OnMouseUp(MouseUpEvent e)
return;
}

Debug.Assert(bindTarget != null);

if (bindTarget.IsHovered)
finalise(false);
// prevent updating bind target before clear button's action
Expand All @@ -269,6 +276,8 @@ protected override bool OnScroll(ScrollEvent e)
{
if (HasFocus)
{
Debug.Assert(bindTarget != null);

if (bindTarget.IsHovered)
{
bindTarget.UpdateKeyCombination(KeyCombination.FromInputState(e.CurrentState, e.ScrollDelta), KeyCombination.FromScrollDelta(e.ScrollDelta).First());
Expand All @@ -285,6 +294,8 @@ protected override bool OnKeyDown(KeyDownEvent e)
if (!HasFocus || e.Repeat)
return false;

Debug.Assert(bindTarget != null);

bindTarget.UpdateKeyCombination(KeyCombination.FromInputState(e.CurrentState), KeyCombination.FromKey(e.Key));
if (!isModifier(e.Key)) finalise();

Expand All @@ -307,6 +318,8 @@ protected override bool OnJoystickPress(JoystickPressEvent e)
if (!HasFocus)
return false;

Debug.Assert(bindTarget != null);

bindTarget.UpdateKeyCombination(KeyCombination.FromInputState(e.CurrentState), KeyCombination.FromJoystickButton(e.Button));
finalise();

Expand All @@ -329,6 +342,8 @@ protected override bool OnMidiDown(MidiDownEvent e)
if (!HasFocus)
return false;

Debug.Assert(bindTarget != null);

bindTarget.UpdateKeyCombination(KeyCombination.FromInputState(e.CurrentState), KeyCombination.FromMidiKey(e.Key));
finalise();

Expand All @@ -351,6 +366,8 @@ protected override bool OnTabletAuxiliaryButtonPress(TabletAuxiliaryButtonPressE
if (!HasFocus)
return false;

Debug.Assert(bindTarget != null);

bindTarget.UpdateKeyCombination(KeyCombination.FromInputState(e.CurrentState), KeyCombination.FromTabletAuxiliaryButton(e.Button));
finalise();

Expand All @@ -373,6 +390,8 @@ protected override bool OnTabletPenButtonPress(TabletPenButtonPressEvent e)
if (!HasFocus)
return false;

Debug.Assert(bindTarget != null);

bindTarget.UpdateKeyCombination(KeyCombination.FromInputState(e.CurrentState), KeyCombination.FromTabletPenButton(e.Button));
finalise();

Expand Down Expand Up @@ -486,10 +505,10 @@ public partial class KeyButton : Container
public readonly OsuSpriteText Text;

[Resolved]
private OverlayColourProvider colourProvider { get; set; }
private OverlayColourProvider colourProvider { get; set; } = null!;

[Resolved]
private ReadableKeyCombinationProvider keyCombinationProvider { get; set; }
private ReadableKeyCombinationProvider keyCombinationProvider { get; set; } = null!;

private bool isBinding;

Expand Down Expand Up @@ -612,7 +631,7 @@ protected override void Dispose(bool isDisposing)
{
base.Dispose(isDisposing);

if (keyCombinationProvider != null)
if (keyCombinationProvider.IsNotNull())
keyCombinationProvider.KeymapChanged -= updateKeyCombinationText;
}
}
Expand Down

0 comments on commit 797109c

Please sign in to comment.