diff options
| author | chai <215380520@qq.com> | 2024-05-19 16:05:58 +0800 |
|---|---|---|
| committer | chai <215380520@qq.com> | 2024-05-19 16:05:58 +0800 |
| commit | 8e13e7e2874adc8982e16d1d2ed2e28d7480b45f (patch) | |
| tree | 63ef85c460288891f5a593d69afeca16cba050b3 /Thronefall_1_57/Decompile/Rewired.Internal/ControllerTemplateFactory.cs | |
| parent | c5f145786f4c6d2fe4bea831dfc16e52228920a5 (diff) | |
+1.57
Diffstat (limited to 'Thronefall_1_57/Decompile/Rewired.Internal/ControllerTemplateFactory.cs')
| -rw-r--r-- | Thronefall_1_57/Decompile/Rewired.Internal/ControllerTemplateFactory.cs | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/Thronefall_1_57/Decompile/Rewired.Internal/ControllerTemplateFactory.cs b/Thronefall_1_57/Decompile/Rewired.Internal/ControllerTemplateFactory.cs new file mode 100644 index 0000000..d1ac2b5 --- /dev/null +++ b/Thronefall_1_57/Decompile/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; + } +} |
