Implement auto buying missing blocks for a given tech snapshot
This commit is contained in:
@@ -15,6 +15,7 @@ namespace TerraTech {
|
|||||||
private const string PluginVersion = "1.0.0";
|
private const string PluginVersion = "1.0.0";
|
||||||
|
|
||||||
public static ConfigEntry<bool> debug;
|
public static ConfigEntry<bool> debug;
|
||||||
|
public static ConfigEntry<bool> debugBuyAll;
|
||||||
public static ConfigEntry<float> xpMultiplier;
|
public static ConfigEntry<float> xpMultiplier;
|
||||||
public static ConfigEntry<float> moneyMultiplier;
|
public static ConfigEntry<float> moneyMultiplier;
|
||||||
public static ConfigEntry<float> heartbeatIntervalMultiplier;
|
public static ConfigEntry<float> heartbeatIntervalMultiplier;
|
||||||
@@ -25,6 +26,7 @@ namespace TerraTech {
|
|||||||
|
|
||||||
public void Awake() {
|
public void Awake() {
|
||||||
debug = Config.Bind("General", "Debug", false);
|
debug = Config.Bind("General", "Debug", false);
|
||||||
|
debugBuyAll = Config.Bind("General", "Debug Buy All", false);
|
||||||
float min = 0.01f;
|
float min = 0.01f;
|
||||||
float max = 32f;
|
float max = 32f;
|
||||||
|
|
||||||
|
@@ -60,6 +60,7 @@
|
|||||||
<Compile Include="ModuleFuelTankManager.cs" />
|
<Compile Include="ModuleFuelTankManager.cs" />
|
||||||
<Compile Include="ProjectilePatch.cs" />
|
<Compile Include="ProjectilePatch.cs" />
|
||||||
<Compile Include="TankManager.cs" />
|
<Compile Include="TankManager.cs" />
|
||||||
|
<Compile Include="UISnapshotPanelBuyAll.cs" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Reference Include="0Harmony">
|
<Reference Include="0Harmony">
|
||||||
@@ -74,6 +75,9 @@
|
|||||||
<Reference Include="UnityEngine.CoreModule">
|
<Reference Include="UnityEngine.CoreModule">
|
||||||
<HintPath>$(GAME_MANAGED)/UnityEngine.CoreModule.dll</HintPath>
|
<HintPath>$(GAME_MANAGED)/UnityEngine.CoreModule.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
|
<Reference Include="UnityEngine.UI">
|
||||||
|
<HintPath>$(GAME_MANAGED)/UnityEngine.UI.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
<Reference Include="UnityEngine.Networking">
|
<Reference Include="UnityEngine.Networking">
|
||||||
<HintPath>$(GAME_MANAGED)/UnityEngine.Networking.dll</HintPath>
|
<HintPath>$(GAME_MANAGED)/UnityEngine.Networking.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
|
132
Projects/TerraTech/TerraTech/UISnapshotPanelBuyAll.cs
Normal file
132
Projects/TerraTech/TerraTech/UISnapshotPanelBuyAll.cs
Normal file
@@ -0,0 +1,132 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using HarmonyLib;
|
||||||
|
using Snapshots;
|
||||||
|
using UnityEngine;
|
||||||
|
using UnityEngine.EventSystems;
|
||||||
|
using UnityEngine.UI;
|
||||||
|
|
||||||
|
namespace TerraTech {
|
||||||
|
[HarmonyPatch]
|
||||||
|
public class UISnapshotPanelBuyAll {
|
||||||
|
public static UISnapshotPanel panel;
|
||||||
|
public static Traverse panelTraverse;
|
||||||
|
public static SnapshotLiveData selectedData;
|
||||||
|
|
||||||
|
[HarmonyPostfix]
|
||||||
|
[HarmonyPatch(typeof(UISnapshotPanel), "OnPool")]
|
||||||
|
public static void PostfixCreate(UISnapshotPanel __instance) {
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("UISnapshotPanel.OnPool: {0}", __instance);
|
||||||
|
panel = __instance;
|
||||||
|
panelTraverse = Traverse.Create(__instance);
|
||||||
|
var placeButton = panelTraverse.Field("m_PlaceButton").GetValue<Button>();
|
||||||
|
placeButton.gameObject.AddComponent<RightClickHandler>();
|
||||||
|
}
|
||||||
|
|
||||||
|
[HarmonyPostfix]
|
||||||
|
[HarmonyPatch(typeof(UISnapshotPanel), "OnSelectedChanged")]
|
||||||
|
public static void PostfixCreate(UISnapshotPanel __instance, ref SnapshotLiveData selectedData) {
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("UISnapshotPanel.OnSelectedChanged: {0}", __instance);
|
||||||
|
UISnapshotPanelBuyAll.selectedData = selectedData;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class RightClickHandler : MonoBehaviour, IPointerClickHandler {
|
||||||
|
public static Traverse m_TechAvailLookupTraverse;
|
||||||
|
public static Dictionary<Snapshot, TechDataAvailValidation> m_TechAvailLookup;
|
||||||
|
|
||||||
|
private void Awake() {
|
||||||
|
var trav = Traverse.Create(Singleton.Manager<ManSnapshots>.inst);
|
||||||
|
m_TechAvailLookupTraverse = trav.Field("m_TechAvailLookup");
|
||||||
|
m_TechAvailLookup = m_TechAvailLookupTraverse.GetValue<Dictionary<Snapshot, TechDataAvailValidation>>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void OnPointerClick(PointerEventData eventData) {
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("UISnapshotPanel.OnPointerClick: {0} {1}", gameObject.name, eventData.button);
|
||||||
|
try {
|
||||||
|
if (eventData.button == PointerEventData.InputButton.Right) {
|
||||||
|
SnapshotLiveData selectedSnapshotData = UISnapshotPanelBuyAll.selectedData;
|
||||||
|
if (selectedSnapshotData == null) {
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("Selected snapshot data is null wtf??: {0} {1}", gameObject.name,
|
||||||
|
eventData.button);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Snapshot selectedSnapshot = selectedSnapshotData.m_Snapshot;
|
||||||
|
if (selectedSnapshot == null) {
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("Selected snapshot is null wtf??: {0} {1}", gameObject.name,
|
||||||
|
eventData.button);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
TechDataAvailValidation techDataAvail;
|
||||||
|
bool ok = m_TechAvailLookup.TryGetValue(selectedSnapshot, out techDataAvail);
|
||||||
|
if (!ok) {
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("Failed to find TechDataAvailValidation for snapshot: {0}",
|
||||||
|
selectedSnapshot);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var trav = Traverse.Create(techDataAvail);
|
||||||
|
var m_BlockAvailabilityField = trav.Field("m_BlockAvailability");
|
||||||
|
var m_BlockAvailability =
|
||||||
|
m_BlockAvailabilityField
|
||||||
|
.GetValue<Dictionary<BlockTypes, TechDataAvailValidation.BlockTypeAvailability>>();
|
||||||
|
|
||||||
|
Dictionary<BlockTypes, int> missing = new Dictionary<BlockTypes, int>();
|
||||||
|
int totalCost = 0;
|
||||||
|
RecipeManager recipeManager = Singleton.Manager<RecipeManager>.inst;
|
||||||
|
foreach (var kvp in m_BlockAvailability) {
|
||||||
|
if (kvp.Value.numRequired - kvp.Value.numInInventory > 0) {
|
||||||
|
int numMissing = kvp.Value.numRequired - kvp.Value.numInInventory;
|
||||||
|
missing.Add(kvp.Key, numMissing);
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("Missing {0} of {1}", numMissing, kvp.Key);
|
||||||
|
|
||||||
|
int cost = recipeManager.GetBlockBuyPrice(kvp.Key) * numMissing;
|
||||||
|
totalCost += cost;
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("{0} of {1} would cost {2}, total now {3}", numMissing, kvp.Key, cost,
|
||||||
|
totalCost);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (totalCost > 0) {
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("Total cost: {0}", totalCost);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("No blocks missing, nothing to do");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
ManPlayer player = Singleton.Manager<ManPlayer>.inst;
|
||||||
|
if (player.GetCurrentMoney() < totalCost) {
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("Not enough money, have {0} but need {1}, nothing to do",
|
||||||
|
player.GetCurrentMoney(), totalCost);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
player.PayMoney(totalCost);
|
||||||
|
foreach (var kvp in missing) {
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("Buying {0} of {1}", kvp.Value, kvp.Key);
|
||||||
|
player.PlayerInventory.HostAddItem(kvp.Key, kvp.Value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception e) {
|
||||||
|
if (Main.debugBuyAll.Value)
|
||||||
|
Console.WriteLine("Shit exploded fml: {0}", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user