1
0
mirror of synced 2024-11-23 22:00:56 +01:00

Merge branch 'release/v2.2.0'

This commit is contained in:
Fluto 2022-02-12 13:52:48 +11:00
commit e2aca91f55
3 changed files with 171 additions and 3 deletions

View File

@ -16,6 +16,8 @@ namespace TakoTako
public ConfigEntry<bool> ConfigDisableScreenChangeOnFocus; public ConfigEntry<bool> ConfigDisableScreenChangeOnFocus;
public ConfigEntry<bool> ConfigFixSignInScreen; public ConfigEntry<bool> ConfigFixSignInScreen;
public ConfigEntry<bool> ConfigEnableCustomSongs; public ConfigEntry<bool> ConfigEnableCustomSongs;
public ConfigEntry<bool> ConfigEnableTaikoDrumSupport;
public ConfigEntry<bool> ConfigTaikoDrumUseNintendoLayout;
public ConfigEntry<string> ConfigSongDirectory; public ConfigEntry<string> ConfigSongDirectory;
public ConfigEntry<bool> ConfigSaveEnabled; public ConfigEntry<bool> ConfigSaveEnabled;
@ -89,6 +91,16 @@ namespace TakoTako
"DisableScreenChangeOnFocus", "DisableScreenChangeOnFocus",
false, false,
"When focusing this wont do anything jank, I thnk"); "When focusing this wont do anything jank, I thnk");
ConfigEnableTaikoDrumSupport = Config.Bind("Controller.TaikoDrum",
"ConfigEnableTaikoDrumSupport",
true,
"This will enable support for Taiko drums, current tested with official Hori Drum");
ConfigTaikoDrumUseNintendoLayout = Config.Bind("Controller.TaikoDrum",
"ConfigTaikoDrumUseNintendoLayout",
false,
"This will use the Nintendo layout YX/BA for the Hori Taiko Drum");
} }
private void SetupHarmony() private void SetupHarmony()
@ -105,6 +117,9 @@ namespace TakoTako
if (ConfigDisableScreenChangeOnFocus.Value) if (ConfigDisableScreenChangeOnFocus.Value)
_harmony.PatchAll(typeof(DisableScreenChangeOnFocus)); _harmony.PatchAll(typeof(DisableScreenChangeOnFocus));
if (ConfigEnableTaikoDrumSupport.Value)
_harmony.PatchAll(typeof(TaikoDrumSupport));
if (ConfigEnableCustomSongs.Value) if (ConfigEnableCustomSongs.Value)
{ {
_harmony.PatchAll(typeof(MusicPatch)); _harmony.PatchAll(typeof(MusicPatch));
@ -117,4 +132,4 @@ namespace TakoTako
StartCoroutine(enumerator); StartCoroutine(enumerator);
} }
} }
} }

View File

@ -0,0 +1,153 @@
using System;
using System.Diagnostics.CodeAnalysis;
using HarmonyLib;
using UnityEngine;
namespace TakoTako;
[HarmonyPatch]
[SuppressMessage("ReSharper", "InconsistentNaming")]
[SuppressMessage("Member Access", "Publicizer001:Accessing a member that was not originally public")]
public class TaikoDrumSupport
{
private const float analogThreshold = 0.333f;
[HarmonyPatch(typeof(ControllerManager), "GetAxis")]
[HarmonyPostfix]
private static void GetAxis_Postfix(ControllerManager __instance, ref float __result, ControllerManager.ControllerPlayerNo controllerPlayerNo, ControllerManager.Axes axis)
{
int controllerIndex = __instance.GetContollersIndex(controllerPlayerNo);
if (controllerIndex <= 0 || !__instance.Controllers[controllerIndex].joystickName.Contains("Taiko"))
return;
var prefix = $"J{controllerIndex - 1}";
switch (axis)
{
case ControllerManager.Axes.L_Horizontal:
{
__result = Input.GetAxis($"{prefix}H3");
break;
}
case ControllerManager.Axes.L_Vertical:
{
__result = Input.GetAxis($"{prefix}V3");
break;
}
case ControllerManager.Axes.D_Right:
{
var axisValue = Input.GetAxis($"{prefix}H3");
if (axisValue > 0)
__result = axisValue;
break;
}
case ControllerManager.Axes.D_Left:
{
var axisValue = Input.GetAxis($"{prefix}H3");
if (axisValue < 0)
__result = -axisValue;
break;
}
case ControllerManager.Axes.D_Up:
{
var axisValue = Input.GetAxis($"{prefix}V3");
if (axisValue > 0)
__result = axisValue;
break;
}
case ControllerManager.Axes.D_Down:
{
var axisValue = Input.GetAxis($"{prefix}V3");
if (axisValue < 0)
__result = -axisValue;
break;
}
}
}
[HarmonyPatch(typeof(ControllerManager), "GetButtonDown")]
[HarmonyPostfix]
private static void GetButtonDown_Postfix(ControllerManager __instance, ref bool __result, ControllerManager.ControllerPlayerNo controllerPlayerNo, ControllerManager.Buttons btn)
{
int controllerIndex = __instance.GetContollersIndex(controllerPlayerNo);
if (controllerIndex <= 0 || !__instance.Controllers[controllerIndex].joystickName.Contains("Taiko"))
return;
var prefix = $"J{controllerIndex}";
var previous = __instance.prevButtons[(int) (controllerPlayerNo - 1), (int) btn];
__result = btn switch
{
ControllerManager.Buttons.D_Right => Input.GetAxis($"{prefix}H3") > analogThreshold && !previous,
ControllerManager.Buttons.D_Left => Input.GetAxis($"{prefix}H3") < -analogThreshold && !previous,
ControllerManager.Buttons.D_Up => Input.GetAxis($"{prefix}V3") > analogThreshold && !previous,
ControllerManager.Buttons.D_Down => Input.GetAxis($"{prefix}V3") < -analogThreshold && !previous || Input.GetButtonDown($"{prefix}B10"),
_ => RunMethodWithButton(btn, controllerIndex, Input.GetButtonDown)
};
}
[HarmonyPatch(typeof(ControllerManager), "GetButton")]
[HarmonyPostfix]
private static void GetButton_Postfix(ControllerManager __instance, ref bool __result, ControllerManager.ControllerPlayerNo controllerPlayerNo, ControllerManager.Buttons btn)
{
int controllerIndex = __instance.GetContollersIndex(controllerPlayerNo);
if (controllerIndex <= 0 || !__instance.Controllers[controllerIndex].joystickName.Contains("Taiko"))
return;
var prefix = $"J{controllerIndex}";
__result = btn switch
{
ControllerManager.Buttons.D_Right => Input.GetAxis($"{prefix}H3") > analogThreshold,
ControllerManager.Buttons.D_Left => Input.GetAxis($"{prefix}H3") < -analogThreshold,
ControllerManager.Buttons.D_Up => Input.GetAxis($"{prefix}V3") > analogThreshold,
ControllerManager.Buttons.D_Down => Input.GetAxis($"{prefix}V3") < -analogThreshold || Input.GetButton($"{prefix}B10"),
_ => RunMethodWithButton(btn, controllerIndex, Input.GetButton)
};
}
[HarmonyPatch(typeof(ControllerManager), "GetButtonUp")]
[HarmonyPostfix]
private static void GetButtonUp_Postfix(ControllerManager __instance, ref bool __result, ControllerManager.ControllerPlayerNo controllerPlayerNo, ControllerManager.Buttons btn)
{
int controllerIndex = __instance.GetContollersIndex(controllerPlayerNo);
if (controllerIndex <= 0 || !__instance.Controllers[controllerIndex].joystickName.Contains("Taiko"))
return;
var prefix = $"J{controllerIndex}";
var previous = __instance.prevButtons[(int) (controllerPlayerNo - 1), (int) btn];
__result = btn switch
{
ControllerManager.Buttons.D_Right => Input.GetAxis($"{prefix}H3") < analogThreshold && previous,
ControllerManager.Buttons.D_Left => Input.GetAxis($"{prefix}H3") > -analogThreshold && previous,
ControllerManager.Buttons.D_Up => Input.GetAxis($"{prefix}V3") < analogThreshold && previous,
ControllerManager.Buttons.D_Down => (Input.GetAxis($"{prefix}V3") > -analogThreshold && previous) || Input.GetButtonUp($"{prefix}B10"),
_ => RunMethodWithButton(btn, controllerIndex, Input.GetButtonUp)
};
}
private static bool RunMethodWithButton(ControllerManager.Buttons button, int controllerIndex, Func<string, bool> function)
{
var nintendoLayout = Plugin.Instance.ConfigTaikoDrumUseNintendoLayout.Value;
var prefix = $"J{controllerIndex}";
return button switch
{
ControllerManager.Buttons.Menu1 => function($"{prefix}B13"),
ControllerManager.Buttons.Menu2 => function($"{prefix}B12"),
ControllerManager.Buttons.A => (nintendoLayout ? function($"{prefix}B2") : function($"{prefix}B1")) || function($"{prefix}B11"),
ControllerManager.Buttons.B => (nintendoLayout ? function($"{prefix}B1") : function($"{prefix}B2")),
ControllerManager.Buttons.X => nintendoLayout ? function($"{prefix}B3") : function($"{prefix}B0"),
ControllerManager.Buttons.Y => nintendoLayout ? function($"{prefix}B0") : function($"{prefix}B3"),
ControllerManager.Buttons.L1 => function($"{prefix}B4") || function($"{prefix}B6"),
ControllerManager.Buttons.L2 => function($"{prefix}B6"),
ControllerManager.Buttons.R1 => function($"{prefix}B5") || function($"{prefix}B7"),
ControllerManager.Buttons.R2 => function($"{prefix}B7"),
ControllerManager.Buttons.L3 => function($"{prefix}B10"),
ControllerManager.Buttons.R3 => function($"{prefix}B11"),
ControllerManager.Buttons.Start => function($"{prefix}B9"),
ControllerManager.Buttons.Back => function($"{prefix}B8"),
_ => false
};
}
}

View File

@ -4,12 +4,12 @@
<TargetFramework>net48</TargetFramework> <TargetFramework>net48</TargetFramework>
<AssemblyName>com.fluto.takotako</AssemblyName> <AssemblyName>com.fluto.takotako</AssemblyName>
<Description>Fixes Taiko issues and allows custom songs</Description> <Description>Fixes Taiko issues and allows custom songs</Description>
<Version>2.1.0</Version> <Version>2.2.0</Version>
<AllowUnsafeBlocks>true</AllowUnsafeBlocks> <AllowUnsafeBlocks>true</AllowUnsafeBlocks>
<LangVersion>latest</LangVersion> <LangVersion>latest</LangVersion>
<RootNamespace>TakoTako</RootNamespace> <RootNamespace>TakoTako</RootNamespace>
<PackageId>com.fluto.takotako</PackageId> <PackageId>com.fluto.takotako</PackageId>
<PackageVersion>2.1.0</PackageVersion> <PackageVersion>2.2.0</PackageVersion>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>