aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.HLE/Input
diff options
context:
space:
mode:
Diffstat (limited to 'Ryujinx.HLE/Input')
-rw-r--r--Ryujinx.HLE/Input/Hid.cs28
1 files changed, 19 insertions, 9 deletions
diff --git a/Ryujinx.HLE/Input/Hid.cs b/Ryujinx.HLE/Input/Hid.cs
index 27e6a308..5cb7f09d 100644
--- a/Ryujinx.HLE/Input/Hid.cs
+++ b/Ryujinx.HLE/Input/Hid.cs
@@ -1,5 +1,7 @@
using Ryujinx.Common;
+using Ryujinx.Configuration.Hid;
using Ryujinx.HLE.HOS;
+using System;
namespace Ryujinx.HLE.Input
{
@@ -47,18 +49,31 @@ namespace Ryujinx.HLE.Input
_keyboardOffset = HidPosition + HidKeyboardOffset;
}
- public void InitializePrimaryController(ControllerStatus controllerType)
+ private static ControllerStatus ConvertControllerTypeToState(ControllerType controllerType)
{
- ControllerId controllerId = controllerType == ControllerStatus.Handheld ?
+ switch (controllerType)
+ {
+ case ControllerType.Handheld: return ControllerStatus.Handheld;
+ case ControllerType.NpadLeft: return ControllerStatus.NpadLeft;
+ case ControllerType.NpadRight: return ControllerStatus.NpadRight;
+ case ControllerType.NpadPair: return ControllerStatus.NpadPair;
+ case ControllerType.ProController: return ControllerStatus.ProController;
+ default: throw new NotImplementedException();
+ }
+ }
+
+ public void InitializePrimaryController(ControllerType controllerType)
+ {
+ ControllerId controllerId = controllerType == ControllerType.Handheld ?
ControllerId.ControllerHandheld : ControllerId.ControllerPlayer1;
- if (controllerType == ControllerStatus.ProController)
+ if (controllerType == ControllerType.ProController)
{
PrimaryController = new ProController(_device, NpadColor.Black, NpadColor.Black);
}
else
{
- PrimaryController = new NpadController(controllerType,
+ PrimaryController = new NpadController(ConvertControllerTypeToState(controllerType),
_device,
(NpadColor.BodyNeonRed, NpadColor.BodyNeonRed),
(NpadColor.ButtonsNeonBlue, NpadColor.ButtonsNeonBlue));
@@ -67,11 +82,6 @@ namespace Ryujinx.HLE.Input
PrimaryController.Connect(controllerId);
}
- public void InitializeKeyboard()
- {
- _device.Memory.FillWithZeros(HidPosition + HidKeyboardOffset, HidKeyboardSize);
- }
-
public ControllerButtons UpdateStickButtons(
JoystickPosition leftStick,
JoystickPosition rightStick)