2021-04-13 16:25:00 +00:00
|
|
|
|
using OWML.Utils;
|
|
|
|
|
using QSB.Events;
|
2021-04-12 10:31:21 +00:00
|
|
|
|
using QSB.Patches;
|
2021-04-13 20:09:26 +00:00
|
|
|
|
using QSB.Utility;
|
2021-04-12 11:02:08 +00:00
|
|
|
|
using UnityEngine;
|
2021-04-12 10:31:21 +00:00
|
|
|
|
|
|
|
|
|
namespace QSB.ShipSync.Patches
|
|
|
|
|
{
|
2021-05-15 20:31:29 +00:00
|
|
|
|
internal class ShipPatches : QSBPatch
|
2021-04-12 10:31:21 +00:00
|
|
|
|
{
|
|
|
|
|
public override QSBPatchTypes Type => QSBPatchTypes.OnClientConnect;
|
|
|
|
|
|
2021-04-12 10:43:22 +00:00
|
|
|
|
public override void DoPatches()
|
|
|
|
|
{
|
2021-06-18 20:54:32 +00:00
|
|
|
|
Prefix(nameof(HatchController_OnPressInteract));
|
|
|
|
|
Prefix(nameof(HatchController_OnEntry));
|
|
|
|
|
Prefix(nameof(ShipTractorBeamSwitch_OnTriggerExit));
|
|
|
|
|
Prefix(nameof(InteractZone_UpdateInteractVolume));
|
2021-06-19 11:14:45 +00:00
|
|
|
|
Prefix(nameof(ShipElectricalComponent_OnEnterShip));
|
|
|
|
|
Prefix(nameof(ShipElectricalComponent_OnExitShip));
|
2021-06-19 14:48:32 +00:00
|
|
|
|
Prefix(nameof(ShipComponent_SetDamaged));
|
2021-06-20 08:48:37 +00:00
|
|
|
|
Prefix(nameof(ShipHull_FixedUpdate));
|
|
|
|
|
Prefix(nameof(ShipDamageController_OnImpact));
|
2021-06-20 09:19:52 +00:00
|
|
|
|
Postfix(nameof(ShipComponent_RepairTick));
|
2021-06-20 11:51:50 +00:00
|
|
|
|
Prefix(nameof(ShipHull_RepairTick));
|
2021-04-12 10:43:22 +00:00
|
|
|
|
}
|
2021-04-12 10:31:21 +00:00
|
|
|
|
|
|
|
|
|
public static bool HatchController_OnPressInteract()
|
|
|
|
|
{
|
2021-04-13 16:25:00 +00:00
|
|
|
|
if (!PlayerState.IsInsideShip())
|
|
|
|
|
{
|
2021-04-13 17:50:15 +00:00
|
|
|
|
ShipManager.Instance.ShipTractorBeam.ActivateTractorBeam();
|
2021-06-14 15:13:32 +00:00
|
|
|
|
QSBEventManager.FireEvent(EventNames.QSBEnableFunnel);
|
2021-04-13 16:25:00 +00:00
|
|
|
|
}
|
2021-06-18 21:38:32 +00:00
|
|
|
|
|
2021-04-12 10:43:22 +00:00
|
|
|
|
QSBEventManager.FireEvent(EventNames.QSBHatchState, true);
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
2021-04-12 11:02:08 +00:00
|
|
|
|
public static bool HatchController_OnEntry(GameObject hitObj)
|
2021-04-12 10:43:22 +00:00
|
|
|
|
{
|
|
|
|
|
if (hitObj.CompareTag("PlayerDetector"))
|
|
|
|
|
{
|
|
|
|
|
QSBEventManager.FireEvent(EventNames.QSBHatchState, false);
|
|
|
|
|
}
|
2021-06-18 21:38:32 +00:00
|
|
|
|
|
2021-04-12 10:31:21 +00:00
|
|
|
|
return true;
|
|
|
|
|
}
|
2021-04-13 16:25:00 +00:00
|
|
|
|
|
|
|
|
|
public static bool ShipTractorBeamSwitch_OnTriggerExit(Collider hitCollider, bool ____isPlayerInShip, bool ____functional)
|
|
|
|
|
{
|
2021-04-13 17:50:15 +00:00
|
|
|
|
if (!____isPlayerInShip && ____functional && hitCollider.CompareTag("PlayerDetector") && !ShipManager.Instance.HatchController.GetValue<GameObject>("_hatchObject").activeSelf)
|
2021-04-13 16:25:00 +00:00
|
|
|
|
{
|
2021-04-13 17:50:15 +00:00
|
|
|
|
ShipManager.Instance.HatchController.Invoke("CloseHatch");
|
|
|
|
|
ShipManager.Instance.ShipTractorBeam.DeactivateTractorBeam();
|
2021-04-13 16:25:00 +00:00
|
|
|
|
QSBEventManager.FireEvent(EventNames.QSBHatchState, false);
|
|
|
|
|
}
|
2021-06-18 21:38:32 +00:00
|
|
|
|
|
2021-04-13 16:25:00 +00:00
|
|
|
|
return false;
|
|
|
|
|
}
|
2021-04-13 20:09:26 +00:00
|
|
|
|
|
|
|
|
|
public static bool InteractZone_UpdateInteractVolume(InteractZone __instance, OWCamera ____playerCam, ref bool ____focused)
|
|
|
|
|
{
|
|
|
|
|
/* Angle for interaction with the ship hatch
|
|
|
|
|
*
|
|
|
|
|
* \ 80° / - If in ship
|
|
|
|
|
* \ /
|
|
|
|
|
* \ /
|
|
|
|
|
* [=====] - Hatch
|
|
|
|
|
* / \
|
|
|
|
|
* / \
|
|
|
|
|
* / 280° \ - If not in ship
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2021-05-10 13:30:38 +00:00
|
|
|
|
if (!QSBCore.WorldObjectsReady || __instance != ShipManager.Instance.HatchInteractZone)
|
2021-04-13 20:09:26 +00:00
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var angle = 2f * Vector3.Angle(____playerCam.transform.forward, __instance.transform.forward);
|
|
|
|
|
|
2021-06-19 10:26:05 +00:00
|
|
|
|
____focused = PlayerState.IsInsideShip()
|
|
|
|
|
? angle <= 80
|
2021-04-13 20:09:26 +00:00
|
|
|
|
: angle >= 280;
|
|
|
|
|
|
|
|
|
|
__instance.CallBase<InteractZone, SingleInteractionVolume>("UpdateInteractVolume");
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
2021-06-19 11:14:45 +00:00
|
|
|
|
|
|
|
|
|
public static bool ShipElectricalComponent_OnEnterShip(ShipElectricalComponent __instance, bool ____damaged, ElectricalSystem ____electricalSystem)
|
|
|
|
|
{
|
|
|
|
|
__instance.CallBase<ShipElectricalComponent, ShipComponent>("OnEnterShip");
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static bool ShipElectricalComponent_OnExitShip(ShipElectricalComponent __instance, bool ____damaged, ElectricalSystem ____electricalSystem)
|
|
|
|
|
{
|
|
|
|
|
__instance.CallBase<ShipElectricalComponent, ShipComponent>("OnExitShip");
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-20 08:48:37 +00:00
|
|
|
|
public static bool ShipComponent_SetDamaged(ShipComponent __instance, bool damaged, ref bool ____damaged, ref float ____repairFraction, DamageEffect ____damageEffect)
|
2021-06-19 14:48:32 +00:00
|
|
|
|
{
|
2021-06-20 08:48:37 +00:00
|
|
|
|
if (____damaged == damaged)
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (damaged)
|
|
|
|
|
{
|
|
|
|
|
____damaged = true;
|
|
|
|
|
____repairFraction = 0f;
|
|
|
|
|
__instance.GetType().GetAnyMethod("OnComponentDamaged").Invoke(__instance, null);
|
2021-07-07 08:00:54 +00:00
|
|
|
|
__instance.RaiseEvent("OnDamaged", __instance);
|
2021-06-20 08:48:37 +00:00
|
|
|
|
QSBEventManager.FireEvent(EventNames.QSBComponentDamaged, __instance);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
____damaged = false;
|
|
|
|
|
____repairFraction = 1f;
|
|
|
|
|
__instance.GetType().GetAnyMethod("OnComponentRepaired").Invoke(__instance, null);
|
2021-07-07 08:00:54 +00:00
|
|
|
|
__instance.RaiseEvent("OnRepaired", __instance);
|
2021-06-20 09:01:50 +00:00
|
|
|
|
QSBEventManager.FireEvent(EventNames.QSBComponentRepaired, __instance);
|
2021-06-20 08:48:37 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
__instance.GetType().GetAnyMethod("UpdateColliderState").Invoke(__instance, null);
|
|
|
|
|
if (____damageEffect)
|
|
|
|
|
{
|
|
|
|
|
____damageEffect.SetEffectBlend(1f - ____repairFraction);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return false;
|
2021-06-19 14:48:32 +00:00
|
|
|
|
}
|
|
|
|
|
|
2021-06-20 08:48:37 +00:00
|
|
|
|
public static bool ShipHull_FixedUpdate(ShipHull __instance, ref ImpactData ____dominantImpact, ref float ____integrity, ref bool ____damaged, DamageEffect ____damageEffect, ShipComponent[] ____components)
|
2021-06-19 14:48:32 +00:00
|
|
|
|
{
|
2021-06-20 08:48:37 +00:00
|
|
|
|
if (____dominantImpact != null)
|
|
|
|
|
{
|
|
|
|
|
var damage = Mathf.InverseLerp(30f, 200f, ____dominantImpact.speed);
|
|
|
|
|
if (damage > 0f)
|
|
|
|
|
{
|
|
|
|
|
var num2 = 0.15f;
|
|
|
|
|
if (damage < num2 && ____integrity > 1f - num2)
|
|
|
|
|
{
|
|
|
|
|
damage = num2;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
____integrity = Mathf.Max(____integrity - damage, 0f);
|
|
|
|
|
if (!____damaged)
|
|
|
|
|
{
|
|
|
|
|
____damaged = true;
|
2021-07-07 08:00:54 +00:00
|
|
|
|
__instance.RaiseEvent("OnDamaged", __instance);
|
2021-06-20 08:48:37 +00:00
|
|
|
|
QSBEventManager.FireEvent(EventNames.QSBHullDamaged, __instance);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (____damageEffect != null)
|
|
|
|
|
{
|
|
|
|
|
____damageEffect.SetEffectBlend(1f - ____integrity);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QSBEventManager.FireEvent(EventNames.QSBHullChangeIntegrity, __instance, ____integrity);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
foreach (var component in ____components)
|
|
|
|
|
{
|
|
|
|
|
if (!(component == null) && !component.isDamaged)
|
|
|
|
|
{
|
|
|
|
|
if (component.ApplyImpact(____dominantImpact))
|
|
|
|
|
{
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-07 08:00:54 +00:00
|
|
|
|
__instance.RaiseEvent("OnImpact", ____dominantImpact, damage);
|
2021-06-20 08:48:37 +00:00
|
|
|
|
QSBEventManager.FireEvent(EventNames.QSBHullImpact, __instance, ____dominantImpact, damage);
|
|
|
|
|
|
|
|
|
|
____dominantImpact = null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
__instance.enabled = false;
|
|
|
|
|
return false;
|
2021-06-19 14:48:32 +00:00
|
|
|
|
}
|
2021-06-20 08:48:37 +00:00
|
|
|
|
|
2021-07-04 21:34:38 +00:00
|
|
|
|
public static bool ShipDamageController_OnImpact()
|
2021-06-20 08:48:37 +00:00
|
|
|
|
=> ShipManager.Instance.HasAuthority;
|
2021-06-20 09:19:52 +00:00
|
|
|
|
|
2021-06-20 09:21:46 +00:00
|
|
|
|
public static void ShipComponent_RepairTick(ShipComponent __instance, float ____repairFraction)
|
2021-06-20 09:19:52 +00:00
|
|
|
|
{
|
|
|
|
|
QSBEventManager.FireEvent(EventNames.QSBComponentRepairTick, __instance, ____repairFraction);
|
2021-06-20 09:21:46 +00:00
|
|
|
|
return;
|
2021-06-20 09:19:52 +00:00
|
|
|
|
}
|
2021-06-20 11:43:02 +00:00
|
|
|
|
|
2021-06-20 11:51:50 +00:00
|
|
|
|
public static bool ShipHull_RepairTick(ShipHull __instance, ref float ____integrity, ref bool ____damaged, DamageEffect ____damageEffect, float ____repairTime)
|
2021-06-20 11:43:02 +00:00
|
|
|
|
{
|
2021-06-20 11:51:50 +00:00
|
|
|
|
if (!____damaged)
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
____integrity = Mathf.Min(____integrity + Time.deltaTime / ____repairTime, 1f);
|
2021-06-20 11:44:26 +00:00
|
|
|
|
QSBEventManager.FireEvent(EventNames.QSBHullRepairTick, __instance, ____integrity);
|
2021-06-20 11:51:50 +00:00
|
|
|
|
|
|
|
|
|
if (____integrity >= 1f)
|
|
|
|
|
{
|
|
|
|
|
____damaged = false;
|
2021-07-07 08:00:54 +00:00
|
|
|
|
__instance.RaiseEvent("OnRepaired", __instance);
|
2021-06-20 11:51:50 +00:00
|
|
|
|
QSBEventManager.FireEvent(EventNames.QSBHullRepaired, __instance);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (____damageEffect != null)
|
|
|
|
|
{
|
|
|
|
|
____damageEffect.SetEffectBlend(1f - ____integrity);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return false;
|
2021-06-20 11:43:02 +00:00
|
|
|
|
}
|
2021-04-12 10:31:21 +00:00
|
|
|
|
}
|
|
|
|
|
}
|