Skip to content

Commit

Permalink
Merge branch 'release/v2.2.0'
Browse files Browse the repository at this point in the history
  • Loading branch information
Fluto committed Feb 12, 2022
2 parents 9ed3bfd + 112d9a8 commit e2aca91
Show file tree
Hide file tree
Showing 3 changed files with 171 additions and 3 deletions.
17 changes: 16 additions & 1 deletion TakoTako/Plugin.cs
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ public class Plugin : BaseUnityPlugin
public ConfigEntry<bool> ConfigDisableScreenChangeOnFocus;
public ConfigEntry<bool> ConfigFixSignInScreen;
public ConfigEntry<bool> ConfigEnableCustomSongs;
public ConfigEntry<bool> ConfigEnableTaikoDrumSupport;
public ConfigEntry<bool> ConfigTaikoDrumUseNintendoLayout;

public ConfigEntry<string> ConfigSongDirectory;
public ConfigEntry<bool> ConfigSaveEnabled;
Expand Down Expand Up @@ -89,6 +91,16 @@ private void SetupConfig()
"DisableScreenChangeOnFocus",
false,
"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()
Expand All @@ -105,6 +117,9 @@ private void SetupHarmony()
if (ConfigDisableScreenChangeOnFocus.Value)
_harmony.PatchAll(typeof(DisableScreenChangeOnFocus));

if (ConfigEnableTaikoDrumSupport.Value)
_harmony.PatchAll(typeof(TaikoDrumSupport));

if (ConfigEnableCustomSongs.Value)
{
_harmony.PatchAll(typeof(MusicPatch));
Expand All @@ -117,4 +132,4 @@ public void StartCustomCoroutine(IEnumerator enumerator)
StartCoroutine(enumerator);
}
}
}
}
153 changes: 153 additions & 0 deletions TakoTako/TaikoDrumSupport.cs
Original file line number Diff line number Diff line change
@@ -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
};
}
}
4 changes: 2 additions & 2 deletions TakoTako/TakoTako.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,12 @@
<TargetFramework>net48</TargetFramework>
<AssemblyName>com.fluto.takotako</AssemblyName>
<Description>Fixes Taiko issues and allows custom songs</Description>
<Version>2.1.0</Version>
<Version>2.2.0</Version>
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
<LangVersion>latest</LangVersion>
<RootNamespace>TakoTako</RootNamespace>
<PackageId>com.fluto.takotako</PackageId>
<PackageVersion>2.1.0</PackageVersion>
<PackageVersion>2.2.0</PackageVersion>
</PropertyGroup>

<ItemGroup>
Expand Down

0 comments on commit e2aca91

Please sign in to comment.