mirror of
https://github.com/ppy/osu.git
synced 2025-02-05 18:35:26 +08:00
Add the UI file
This commit is contained in:
parent
fa2ebe1d5f
commit
757d236e14
280
osu.Game.Rulesets.Catch/UI/TouchInputField.cs
Normal file
280
osu.Game.Rulesets.Catch/UI/TouchInputField.cs
Normal file
@ -0,0 +1,280 @@
|
|||||||
|
// 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.
|
||||||
|
|
||||||
|
using osu.Framework.Allocation;
|
||||||
|
using System.Diagnostics;
|
||||||
|
using osu.Framework.Extensions.Color4Extensions;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Graphics.Shapes;
|
||||||
|
using osu.Framework.Input.Bindings;
|
||||||
|
using osu.Framework.Input.Events;
|
||||||
|
using osu.Game.Graphics;
|
||||||
|
using osuTK.Graphics;
|
||||||
|
using osuTK;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
namespace osu.Game.Rulesets.Catch.UI
|
||||||
|
{
|
||||||
|
public class TouchInputField : VisibilityContainer
|
||||||
|
{
|
||||||
|
public enum TouchCatchAction
|
||||||
|
{
|
||||||
|
MoveLeft = 0,
|
||||||
|
MoveRight = 1,
|
||||||
|
DashLeft = 2,
|
||||||
|
DashRight = 3,
|
||||||
|
None = 4
|
||||||
|
}
|
||||||
|
|
||||||
|
private Dictionary<object, TouchCatchAction> trackedActions = new Dictionary<object, TouchCatchAction>();
|
||||||
|
|
||||||
|
private KeyBindingContainer<CatchAction> keyBindingContainer = null!;
|
||||||
|
|
||||||
|
private Container mainContent = null!;
|
||||||
|
|
||||||
|
// Fill values with null because UI is not declared in constructor
|
||||||
|
private ArrowHitbox leftBox = null!;
|
||||||
|
private ArrowHitbox rightBox = null!;
|
||||||
|
private ArrowHitbox leftDashBox = null!;
|
||||||
|
private ArrowHitbox rightDashBox = null!;
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load(CatchInputManager catchInputManager, OsuColour colours)
|
||||||
|
{
|
||||||
|
Show();
|
||||||
|
Debug.Assert(catchInputManager.KeyBindingContainer != null);
|
||||||
|
|
||||||
|
keyBindingContainer = catchInputManager.KeyBindingContainer;
|
||||||
|
|
||||||
|
// Container should handle input everywhere.
|
||||||
|
RelativeSizeAxes = Axes.Both;
|
||||||
|
|
||||||
|
|
||||||
|
Children = new Drawable[]
|
||||||
|
{
|
||||||
|
mainContent = new Container
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
|
RelativePositionAxes = Axes.Both,
|
||||||
|
Children = new Drawable[]
|
||||||
|
{
|
||||||
|
leftBox = new ArrowHitbox(TouchCatchAction.MoveLeft, ref trackedActions, colours.Blue)
|
||||||
|
{
|
||||||
|
Anchor = Anchor.TopLeft,
|
||||||
|
Origin = Anchor.CentreLeft,
|
||||||
|
X = 0,
|
||||||
|
RelativePositionAxes = Axes.Both,
|
||||||
|
Size = new Vector2(100.0f, 100.0f)
|
||||||
|
},
|
||||||
|
rightBox = new ArrowHitbox(TouchCatchAction.MoveRight, ref trackedActions, colours.Blue)
|
||||||
|
{
|
||||||
|
Anchor = Anchor.TopRight,
|
||||||
|
Origin = Anchor.CentreRight,
|
||||||
|
X = 0,
|
||||||
|
RelativePositionAxes = Axes.Both,
|
||||||
|
Size = new Vector2(100.0f, 100.0f),
|
||||||
|
},
|
||||||
|
leftDashBox = new ArrowHitbox(TouchCatchAction.DashLeft, ref trackedActions, colours.Pink)
|
||||||
|
{
|
||||||
|
Anchor = Anchor.TopLeft,
|
||||||
|
Origin = Anchor.CentreLeft,
|
||||||
|
X = 0.1f,
|
||||||
|
RelativePositionAxes = Axes.Both,
|
||||||
|
Size = new Vector2(100.0f, 100.0f),
|
||||||
|
},
|
||||||
|
rightDashBox = new ArrowHitbox(TouchCatchAction.DashRight, ref trackedActions, colours.Pink)
|
||||||
|
{
|
||||||
|
Anchor = Anchor.TopRight,
|
||||||
|
Origin = Anchor.CentreRight,
|
||||||
|
X = -0.1f,
|
||||||
|
RelativePositionAxes = Axes.Both,
|
||||||
|
Size = new Vector2(100.0f, 100.0f),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override bool OnKeyDown(KeyDownEvent e)
|
||||||
|
{
|
||||||
|
// Hide whenever the keyboard is used.
|
||||||
|
Hide();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override bool OnMouseDown(MouseDownEvent e)
|
||||||
|
{
|
||||||
|
if (getTouchCatchActionFromInput(e.MousePosition) != TouchCatchAction.None)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
handleDown(e.Button, e.ScreenSpaceMousePosition);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void OnMouseUp(MouseUpEvent e)
|
||||||
|
{
|
||||||
|
if (getTouchCatchActionFromInput(e.MousePosition) != TouchCatchAction.None)
|
||||||
|
return;
|
||||||
|
|
||||||
|
handleUp(e.Button);
|
||||||
|
base.OnMouseUp(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void OnTouchMove(TouchMoveEvent e)
|
||||||
|
{
|
||||||
|
// I'm not sure if this is posible but let's be safe
|
||||||
|
if (!trackedActions.ContainsKey(e.Touch.Source))
|
||||||
|
trackedActions.Add(e.Touch.Source, TouchCatchAction.None);
|
||||||
|
|
||||||
|
trackedActions[e.Touch.Source] = getTouchCatchActionFromInput(e.MousePosition);
|
||||||
|
|
||||||
|
calculateActiveKeys();
|
||||||
|
|
||||||
|
base.OnTouchMove(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override bool OnTouchDown(TouchDownEvent e)
|
||||||
|
{
|
||||||
|
handleDown(e.Touch.Source, e.ScreenSpaceTouchDownPosition);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void OnTouchUp(TouchUpEvent e)
|
||||||
|
{
|
||||||
|
handleUp(e.Touch.Source);
|
||||||
|
base.OnTouchUp(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
private CatchAction removeDashFromAction(TouchCatchAction touchCatchAction)
|
||||||
|
{
|
||||||
|
if (touchCatchAction == TouchCatchAction.DashLeft || touchCatchAction == TouchCatchAction.MoveLeft)
|
||||||
|
return CatchAction.MoveLeft;
|
||||||
|
return CatchAction.MoveRight;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void calculateActiveKeys()
|
||||||
|
{
|
||||||
|
if (trackedActions.ContainsValue(TouchCatchAction.DashLeft) || trackedActions.ContainsValue(TouchCatchAction.MoveLeft))
|
||||||
|
keyBindingContainer.TriggerPressed(CatchAction.MoveLeft);
|
||||||
|
else
|
||||||
|
keyBindingContainer.TriggerReleased(CatchAction.MoveLeft);
|
||||||
|
|
||||||
|
if (trackedActions.ContainsValue(TouchCatchAction.DashRight) || trackedActions.ContainsValue(TouchCatchAction.MoveRight))
|
||||||
|
keyBindingContainer.TriggerPressed(CatchAction.MoveRight);
|
||||||
|
else
|
||||||
|
keyBindingContainer.TriggerReleased(CatchAction.MoveRight);
|
||||||
|
|
||||||
|
if (trackedActions.ContainsValue(TouchCatchAction.DashRight) || trackedActions.ContainsValue(TouchCatchAction.DashLeft))
|
||||||
|
keyBindingContainer.TriggerPressed(CatchAction.Dash);
|
||||||
|
else
|
||||||
|
keyBindingContainer.TriggerReleased(CatchAction.Dash);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void handleDown(object source, Vector2 position)
|
||||||
|
{
|
||||||
|
Show();
|
||||||
|
|
||||||
|
TouchCatchAction catchAction = getTouchCatchActionFromInput(position);
|
||||||
|
|
||||||
|
// Not too sure how this can happen, but let's avoid throwing.
|
||||||
|
if (trackedActions.ContainsKey(source))
|
||||||
|
return;
|
||||||
|
|
||||||
|
trackedActions.Add(source, catchAction);
|
||||||
|
calculateActiveKeys();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void handleUp(object source)
|
||||||
|
{
|
||||||
|
trackedActions.Remove(source);
|
||||||
|
|
||||||
|
calculateActiveKeys();
|
||||||
|
}
|
||||||
|
|
||||||
|
private TouchCatchAction getTouchCatchActionFromInput(Vector2 inputPosition)
|
||||||
|
{
|
||||||
|
if (leftDashBox.Contains(inputPosition))
|
||||||
|
return TouchCatchAction.DashLeft;
|
||||||
|
if (rightDashBox.Contains(inputPosition))
|
||||||
|
return TouchCatchAction.DashRight;
|
||||||
|
if (leftBox.Contains(inputPosition))
|
||||||
|
return TouchCatchAction.MoveLeft;
|
||||||
|
if (rightBox.Contains(inputPosition))
|
||||||
|
return TouchCatchAction.MoveRight;
|
||||||
|
return TouchCatchAction.None;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void PopIn()
|
||||||
|
{
|
||||||
|
mainContent.FadeIn(500, Easing.OutQuint);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void PopOut()
|
||||||
|
{
|
||||||
|
mainContent.FadeOut(300);
|
||||||
|
}
|
||||||
|
|
||||||
|
private class ArrowHitbox : CompositeDrawable, IKeyBindingHandler<CatchAction>
|
||||||
|
{
|
||||||
|
private readonly TouchCatchAction handledAction;
|
||||||
|
|
||||||
|
private readonly Box overlay;
|
||||||
|
|
||||||
|
private readonly Dictionary<object, TouchCatchAction> trackedActions;
|
||||||
|
|
||||||
|
private bool isHiglighted = false;
|
||||||
|
|
||||||
|
public ArrowHitbox(TouchCatchAction handledAction, ref Dictionary<object, TouchCatchAction> trackedActions, Color4 colour)
|
||||||
|
{
|
||||||
|
this.handledAction = handledAction;
|
||||||
|
this.trackedActions = trackedActions;
|
||||||
|
|
||||||
|
InternalChildren = new Drawable[]
|
||||||
|
{
|
||||||
|
new Container
|
||||||
|
{
|
||||||
|
Width = 1,
|
||||||
|
Height = 1,
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
|
Children = new Drawable[]
|
||||||
|
{
|
||||||
|
overlay = new Box
|
||||||
|
{
|
||||||
|
Alpha = 0,
|
||||||
|
Colour = colour.Multiply(1.4f).Darken(2.8f),
|
||||||
|
Blending = BlendingParameters.Additive,
|
||||||
|
Size = new Vector2(100.0f, 100.0f),
|
||||||
|
},
|
||||||
|
new Box
|
||||||
|
{
|
||||||
|
Alpha = 0.5f,
|
||||||
|
Colour = colour,
|
||||||
|
Size = new Vector2(100.0f, 100.0f),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool OnPressed(KeyBindingPressEvent<CatchAction> _)
|
||||||
|
{
|
||||||
|
if (trackedActions.ContainsValue(handledAction))
|
||||||
|
{
|
||||||
|
isHiglighted = true;
|
||||||
|
overlay.FadeTo(0.5f, 80, Easing.OutQuint);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void OnReleased(KeyBindingReleaseEvent<CatchAction> _)
|
||||||
|
{
|
||||||
|
if (isHiglighted && !trackedActions.ContainsValue(handledAction))
|
||||||
|
{
|
||||||
|
isHiglighted = false;
|
||||||
|
overlay.FadeOut(1000, Easing.Out);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user