quantum-space-buddies/QSB/ConversationSync/ConversationPatches.cs

114 lines
5.3 KiB
C#
Raw Normal View History

2020-10-25 13:17:01 +00:00
using OWML.Common;
using QSB.Utility;
using QSB.WorldSync;
2020-09-18 15:32:22 +01:00
using System.Collections.Generic;
2020-10-24 15:31:20 +01:00
using UnityEngine;
2020-09-18 15:32:22 +01:00
namespace QSB.ConversationSync
{
2020-11-03 21:11:10 +00:00
public class ConversationPatches : QSBPatch
2020-09-18 15:32:22 +01:00
{
2020-11-03 21:11:10 +00:00
public override QSBPatchTypes Type => QSBPatchTypes.OnClientConnect;
2020-09-22 21:11:29 +01:00
public static void StartConversation(CharacterDialogueTree __instance)
2020-09-18 15:32:22 +01:00
{
2020-09-22 21:11:29 +01:00
var index = WorldRegistry.OldDialogueTrees.FindIndex(x => x == __instance);
2020-10-25 13:17:01 +00:00
if (index == -1)
{
DebugLog.ToConsole($"Warning - Index for tree {__instance.name} was -1.", MessageType.Warning);
}
2020-11-03 21:18:40 +00:00
QSBPlayerManager.LocalPlayer.CurrentDialogueID = index;
2020-10-25 15:19:23 +00:00
ConversationManager.Instance.SendConvState(index, true);
}
2020-10-25 13:17:01 +00:00
public static bool EndConversation(CharacterDialogueTree __instance)
{
2020-10-25 13:17:01 +00:00
if (!__instance.enabled)
{
return false;
}
2020-11-03 21:18:40 +00:00
if (QSBPlayerManager.LocalPlayer.CurrentDialogueID == -1)
2020-10-25 13:17:01 +00:00
{
DebugLog.ToConsole($"Warning - Ending conversation with CurrentDialogueId of -1! Called from {__instance.name}", MessageType.Warning);
return false;
}
2020-11-03 21:18:40 +00:00
ConversationManager.Instance.SendConvState(QSBPlayerManager.LocalPlayer.CurrentDialogueID, false);
ConversationManager.Instance.CloseBoxCharacter(QSBPlayerManager.LocalPlayer.CurrentDialogueID);
QSBPlayerManager.LocalPlayer.CurrentDialogueID = -1;
2020-10-24 11:20:45 +01:00
ConversationManager.Instance.CloseBoxPlayer();
2020-10-25 13:17:01 +00:00
return true;
2020-09-22 21:11:29 +01:00
}
2020-09-18 15:32:22 +01:00
2020-09-22 21:11:29 +01:00
public static bool InputDialogueOption(int optionIndex, DialogueBoxVer2 ____currentDialogueBox)
{
2020-09-29 20:42:45 +02:00
if (optionIndex < 0)
2020-09-18 15:32:22 +01:00
{
// in a page where there is no selectable options
2020-10-24 11:20:45 +01:00
ConversationManager.Instance.CloseBoxPlayer();
2020-09-29 20:42:45 +02:00
return true;
2020-09-18 15:32:22 +01:00
}
2020-09-29 20:42:45 +02:00
var selectedOption = ____currentDialogueBox.OptionFromUIIndex(optionIndex);
ConversationManager.Instance.SendPlayerOption(selectedOption.Text);
2020-09-22 21:11:29 +01:00
return true;
}
public static void GetNextPage(string ____name, List<string> ____listPagesToDisplay, int ____currentPage)
2020-09-22 21:11:29 +01:00
{
var key = ____name + ____listPagesToDisplay[____currentPage];
// Sending key so translation can be done on client side - should make different language-d clients compatible
2020-11-03 21:18:40 +00:00
QSB.Helper.Events.Unity.RunWhen(() => QSBPlayerManager.LocalPlayer.CurrentDialogueID != -1,
() => ConversationManager.Instance.SendCharacterDialogue(QSBPlayerManager.LocalPlayer.CurrentDialogueID, key));
2020-09-22 21:11:29 +01:00
}
2020-10-24 15:31:20 +01:00
public static bool OnAnimatorIK(float ___headTrackingWeight,
bool ___lookOnlyWhenTalking,
bool ____playerInHeadZone,
bool ____inConversation,
ref float ____currentLookWeight,
ref Vector3 ____currentLookTarget,
DampedSpring3D ___lookSpring,
Animator ____animator,
CharacterDialogueTree ____dialogueTree)
{
var playerId = ConversationManager.Instance.GetPlayerTalkingToTree(____dialogueTree);
Vector3 position;
if (playerId == uint.MaxValue)
{
2020-10-25 17:17:47 +00:00
// TODO : Find closest player and track to that camera.
2020-10-24 15:31:20 +01:00
position = Locator.GetActiveCamera().transform.position;
}
else
{
2020-11-03 21:18:40 +00:00
position = QSBPlayerManager.GetPlayer(playerId).Camera.transform.position;
2020-10-24 15:31:20 +01:00
}
2020-10-24 19:04:50 +01:00
float b = ___headTrackingWeight * Mathf.Min(1, (!___lookOnlyWhenTalking) ? ((!____playerInHeadZone) ? 0 : 1) : ((!____inConversation || !____playerInHeadZone) ? 0 : 1));
2020-10-24 15:31:20 +01:00
____currentLookWeight = Mathf.Lerp(____currentLookWeight, b, Time.deltaTime * 2f);
____currentLookTarget = ___lookSpring.Update(____currentLookTarget, position, Time.deltaTime);
____animator.SetLookAtPosition(____currentLookTarget);
____animator.SetLookAtWeight(____currentLookWeight);
return false;
2020-10-24 19:04:50 +01:00
}
2020-10-24 15:31:20 +01:00
2020-10-24 19:04:50 +01:00
public static bool OnZoneExit(CharacterDialogueTree ____dialogueTree)
{
var playerId = ConversationManager.Instance.GetPlayerTalkingToTree(____dialogueTree);
if (playerId == uint.MaxValue)
{
return true;
}
return false;
2020-10-24 15:31:20 +01:00
}
2020-11-03 21:11:10 +00:00
public override void DoPatches()
2020-09-22 21:11:29 +01:00
{
QSB.Helper.HarmonyHelper.AddPostfix<DialogueNode>("GetNextPage", typeof(ConversationPatches), nameof(GetNextPage));
QSB.Helper.HarmonyHelper.AddPrefix<CharacterDialogueTree>("InputDialogueOption", typeof(ConversationPatches), nameof(InputDialogueOption));
QSB.Helper.HarmonyHelper.AddPostfix<CharacterDialogueTree>("StartConversation", typeof(ConversationPatches), nameof(StartConversation));
2020-10-25 13:17:01 +00:00
QSB.Helper.HarmonyHelper.AddPrefix<CharacterDialogueTree>("EndConversation", typeof(ConversationPatches), nameof(EndConversation));
2020-10-24 15:31:20 +01:00
QSB.Helper.HarmonyHelper.AddPrefix<CharacterAnimController>("OnAnimatorIK", typeof(ConversationPatches), nameof(OnAnimatorIK));
2020-10-24 19:04:50 +01:00
QSB.Helper.HarmonyHelper.AddPrefix<CharacterAnimController>("OnZoneExit", typeof(ConversationPatches), nameof(OnZoneExit));
2020-09-18 15:32:22 +01:00
}
}
}