summaryrefslogtreecommitdiff
path: root/Thronefall_1_57/Thronefall/Rewired.Internal
diff options
context:
space:
mode:
authorchai <215380520@qq.com>2024-05-19 17:03:57 +0800
committerchai <215380520@qq.com>2024-05-19 17:03:57 +0800
commitcf58771365b5953c6eac548b172aae880d1f0acd (patch)
treea49757a4b5c447cbf877584d482367a6bfe33b10 /Thronefall_1_57/Thronefall/Rewired.Internal
parenteed315deae356ddfb17f28305e7cde6cdfc43313 (diff)
* rename
Diffstat (limited to 'Thronefall_1_57/Thronefall/Rewired.Internal')
-rw-r--r--Thronefall_1_57/Thronefall/Rewired.Internal/ControllerTemplateFactory.cs59
1 files changed, 59 insertions, 0 deletions
diff --git a/Thronefall_1_57/Thronefall/Rewired.Internal/ControllerTemplateFactory.cs b/Thronefall_1_57/Thronefall/Rewired.Internal/ControllerTemplateFactory.cs
new file mode 100644
index 0000000..d1ac2b5
--- /dev/null
+++ b/Thronefall_1_57/Thronefall/Rewired.Internal/ControllerTemplateFactory.cs
@@ -0,0 +1,59 @@
+using System;
+
+namespace Rewired.Internal;
+
+public static class ControllerTemplateFactory
+{
+ private static readonly Type[] _defaultTemplateTypes = new Type[6]
+ {
+ typeof(GamepadTemplate),
+ typeof(RacingWheelTemplate),
+ typeof(HOTASTemplate),
+ typeof(FlightYokeTemplate),
+ typeof(FlightPedalsTemplate),
+ typeof(SixDofControllerTemplate)
+ };
+
+ private static readonly Type[] _defaultTemplateInterfaceTypes = new Type[6]
+ {
+ typeof(IGamepadTemplate),
+ typeof(IRacingWheelTemplate),
+ typeof(IHOTASTemplate),
+ typeof(IFlightYokeTemplate),
+ typeof(IFlightPedalsTemplate),
+ typeof(ISixDofControllerTemplate)
+ };
+
+ public static Type[] templateTypes => _defaultTemplateTypes;
+
+ public static Type[] templateInterfaceTypes => _defaultTemplateInterfaceTypes;
+
+ public static IControllerTemplate Create(Guid typeGuid, object payload)
+ {
+ if (typeGuid == GamepadTemplate.typeGuid)
+ {
+ return new GamepadTemplate(payload);
+ }
+ if (typeGuid == RacingWheelTemplate.typeGuid)
+ {
+ return new RacingWheelTemplate(payload);
+ }
+ if (typeGuid == HOTASTemplate.typeGuid)
+ {
+ return new HOTASTemplate(payload);
+ }
+ if (typeGuid == FlightYokeTemplate.typeGuid)
+ {
+ return new FlightYokeTemplate(payload);
+ }
+ if (typeGuid == FlightPedalsTemplate.typeGuid)
+ {
+ return new FlightPedalsTemplate(payload);
+ }
+ if (typeGuid == SixDofControllerTemplate.typeGuid)
+ {
+ return new SixDofControllerTemplate(payload);
+ }
+ return null;
+ }
+}