2022-03-07 21:58:20 -08:00
|
|
|
|
using HarmonyLib;
|
2022-03-11 10:21:27 +00:00
|
|
|
|
using QSB.Patches;
|
2022-03-07 21:58:20 -08:00
|
|
|
|
using QSB.Utility;
|
|
|
|
|
using UnityEngine;
|
|
|
|
|
|
|
|
|
|
namespace QSB;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// TODO: remove this when the bug is fixed in vanilla
|
|
|
|
|
/// </summary>
|
|
|
|
|
[HarmonyPatch(typeof(StreamingGroup))]
|
2022-03-11 10:21:27 +00:00
|
|
|
|
internal class TEMP_ShipBugFix : QSBPatch
|
2022-03-07 21:58:20 -08:00
|
|
|
|
{
|
2022-03-11 10:21:27 +00:00
|
|
|
|
public override QSBPatchTypes Type => QSBPatchTypes.OnModStart;
|
2022-03-07 21:58:20 -08:00
|
|
|
|
|
|
|
|
|
[HarmonyPrefix]
|
|
|
|
|
[HarmonyPatch(nameof(StreamingGroup.LoadRequiredColliders))]
|
|
|
|
|
private static bool LoadRequiredColliders(StreamingGroup __instance, int priorityBias)
|
|
|
|
|
{
|
|
|
|
|
StreamingManager.LoadStreamingAssets(__instance._terrainColliderSceneMeshBundle, 18 + priorityBias);
|
|
|
|
|
StreamingManager.LoadStreamingAssets(__instance._structuresColliderSceneMeshBundle, 17 + priorityBias);
|
|
|
|
|
StreamingManager.LoadStreamingAssets(__instance._batchedRenderersColliderBundle, 18 + priorityBias);
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[HarmonyPrefix]
|
|
|
|
|
[HarmonyPatch(nameof(StreamingGroup.UnloadRequiredColliders))]
|
|
|
|
|
private static bool UnloadRequiredColliders(StreamingGroup __instance, float delay)
|
|
|
|
|
{
|
|
|
|
|
StreamingManager.UnloadStreamingAssets(__instance._terrainColliderSceneMeshBundle, delay);
|
|
|
|
|
StreamingManager.UnloadStreamingAssets(__instance._structuresColliderSceneMeshBundle, delay);
|
|
|
|
|
StreamingManager.UnloadStreamingAssets(__instance._batchedRenderersColliderBundle, delay);
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[HarmonyPrefix]
|
|
|
|
|
[HarmonyPatch(nameof(StreamingGroup.LoadRequiredAssets))]
|
|
|
|
|
private static bool LoadRequiredAssets(StreamingGroup __instance, int priorityBias)
|
|
|
|
|
{
|
|
|
|
|
if (__instance._locked)
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StreamingManager.LoadStreamingAssets(__instance._bakedTerrainsBundle, 8 + priorityBias);
|
|
|
|
|
StreamingManager.LoadStreamingAssets(__instance._batchedRenderersBundle, 8 + priorityBias);
|
|
|
|
|
StreamingManager.LoadStreamingAssets(__instance._bakedVISRenderersBundle, 8 + priorityBias);
|
|
|
|
|
StreamingManager.LoadStreamingAssets(__instance._terrainSceneMeshBundle, 8 + priorityBias);
|
|
|
|
|
StreamingManager.LoadStreamingAssets(__instance._structuresSceneMeshBundle, 7 + priorityBias);
|
|
|
|
|
if (!__instance._streamCollidersOnWakeUp)
|
|
|
|
|
{
|
|
|
|
|
StreamingManager.LoadStreamingAssets(__instance._terrainColliderSceneMeshBundle, 18 + priorityBias);
|
|
|
|
|
StreamingManager.LoadStreamingAssets(__instance._structuresColliderSceneMeshBundle, 17 + priorityBias);
|
|
|
|
|
StreamingManager.LoadStreamingAssets(__instance._batchedRenderersColliderBundle, 18 + priorityBias);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
__instance._requiredAssetsPriorityBias = priorityBias;
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[HarmonyPrefix]
|
|
|
|
|
[HarmonyPatch(nameof(StreamingGroup.UnloadRequiredAssets))]
|
|
|
|
|
private static bool UnloadRequiredAssets(StreamingGroup __instance, float delay)
|
|
|
|
|
{
|
|
|
|
|
if (__instance._locked)
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
StreamingManager.UnloadStreamingAssets(__instance._bakedTerrainsBundle, delay);
|
|
|
|
|
StreamingManager.UnloadStreamingAssets(__instance._batchedRenderersBundle, delay);
|
|
|
|
|
StreamingManager.UnloadStreamingAssets(__instance._bakedVISRenderersBundle, delay);
|
|
|
|
|
StreamingManager.UnloadStreamingAssets(__instance._terrainSceneMeshBundle, delay);
|
|
|
|
|
StreamingManager.UnloadStreamingAssets(__instance._structuresSceneMeshBundle, delay);
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|