Refactor shield configuration to ModuleShieldGeneratorManager
This commit is contained in:
@@ -49,11 +49,6 @@ namespace TerraTech {
|
|||||||
public static ConfigEntry<float> aerofoilAngleTurnSpeedMultiplier;
|
public static ConfigEntry<float> aerofoilAngleTurnSpeedMultiplier;
|
||||||
public static ConfigEntry<float> aerofoilLiftStrengthMultiplier;
|
public static ConfigEntry<float> aerofoilLiftStrengthMultiplier;
|
||||||
|
|
||||||
public static ConfigEntry<float> shieldRadiusMultiplier;
|
|
||||||
public static ConfigEntry<float> shieldRadiusMultiplierHealing;
|
|
||||||
public static ConfigEntry<float> shieldHeartbeatIntervalMultiplier;
|
|
||||||
public static ConfigEntry<float> shieldPowerUpDelayMultiplier;
|
|
||||||
|
|
||||||
public static ConfigEntry<float> fireDataKickbackStrengthMultiplier;
|
public static ConfigEntry<float> fireDataKickbackStrengthMultiplier;
|
||||||
public static ConfigEntry<float> fireDataMuzzleVelocityMultiplier;
|
public static ConfigEntry<float> fireDataMuzzleVelocityMultiplier;
|
||||||
|
|
||||||
@@ -87,25 +82,6 @@ namespace TerraTech {
|
|||||||
"General", "Heartbeat Interval Multiplier", 1f,
|
"General", "Heartbeat Interval Multiplier", 1f,
|
||||||
new ConfigDescription("Heartbeat Interval Multiplier", new AcceptableValueRange<float>(min, max)));
|
new ConfigDescription("Heartbeat Interval Multiplier", new AcceptableValueRange<float>(min, max)));
|
||||||
|
|
||||||
shieldRadiusMultiplier = Config.Bind(
|
|
||||||
"Shield", "Shield Radius Multiplier", 1f,
|
|
||||||
new ConfigDescription("Shield Radius Multiplier", new AcceptableValueRange<float>(min, max)));
|
|
||||||
shieldRadiusMultiplier.SettingChanged += (sender, args) => ModuleShieldGeneratorManager.DoPatch();
|
|
||||||
shieldHeartbeatIntervalMultiplier =
|
|
||||||
Config.Bind("Shield", "Shield Heartbeat Interval Multiplier", 1f,
|
|
||||||
new ConfigDescription("Shield Heartbeat Interval Multiplier",
|
|
||||||
new AcceptableValueRange<float>(min, max)));
|
|
||||||
shieldHeartbeatIntervalMultiplier.SettingChanged += (sender, args) =>
|
|
||||||
ModuleShieldGeneratorManager.DoPatch();
|
|
||||||
shieldPowerUpDelayMultiplier = Config.Bind(
|
|
||||||
"Shield", "Shield Power Up Delay Multiplier", 1f,
|
|
||||||
new ConfigDescription("Shield Power Up Delay Multiplier", new AcceptableValueRange<float>(min, max)));
|
|
||||||
shieldPowerUpDelayMultiplier.SettingChanged += (sender, args) => ModuleShieldGeneratorManager.DoPatch();
|
|
||||||
shieldRadiusMultiplierHealing = Config.Bind(
|
|
||||||
"Shield", "Shield Radius Multiplier Healing", 1f,
|
|
||||||
new ConfigDescription("Shield Radius Multiplier Healing", new AcceptableValueRange<float>(min, max)));
|
|
||||||
shieldRadiusMultiplierHealing.SettingChanged += (sender, args) => ModuleShieldGeneratorManager.DoPatch();
|
|
||||||
|
|
||||||
fireDataKickbackStrengthMultiplier =
|
fireDataKickbackStrengthMultiplier =
|
||||||
Config.Bind("FireData", "Fire Data Kickback Strength Multiplier", 1f,
|
Config.Bind("FireData", "Fire Data Kickback Strength Multiplier", 1f,
|
||||||
new ConfigDescription("Fire Data Kickback Strength Multiplier",
|
new ConfigDescription("Fire Data Kickback Strength Multiplier",
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
using System;
|
using System;
|
||||||
|
using BepInEx.Configuration;
|
||||||
using HarmonyLib;
|
using HarmonyLib;
|
||||||
|
|
||||||
namespace TerraTech {
|
namespace TerraTech {
|
||||||
@@ -6,20 +7,51 @@ namespace TerraTech {
|
|||||||
public class ModuleShieldGeneratorManager {
|
public class ModuleShieldGeneratorManager {
|
||||||
private static readonly MultipliedObjectManager<ModuleShieldGenerator> manager =
|
private static readonly MultipliedObjectManager<ModuleShieldGenerator> manager =
|
||||||
new MultipliedObjectManager<ModuleShieldGenerator>(ConfigureShieldGenerator);
|
new MultipliedObjectManager<ModuleShieldGenerator>(ConfigureShieldGenerator);
|
||||||
|
public static ConfigEntry<float> shieldRadiusMultiplier;
|
||||||
|
public static ConfigEntry<float> shieldRadiusMultiplierHealing;
|
||||||
|
public static ConfigEntry<float> shieldHeartbeatIntervalMultiplier;
|
||||||
|
public static ConfigEntry<float> shieldPowerUpDelayMultiplier;
|
||||||
|
|
||||||
|
public static void Setup(ConfigFile config) {
|
||||||
|
float min = 0.01f;
|
||||||
|
float max = 32f;
|
||||||
|
|
||||||
|
shieldRadiusMultiplier = config.Bind(
|
||||||
|
"Shield", "Shield Radius Multiplier", 1f,
|
||||||
|
new ConfigDescription("Shield Radius Multiplier", new AcceptableValueRange<float>(min, max)));
|
||||||
|
shieldRadiusMultiplier.SettingChanged += (sender, args) => ModuleShieldGeneratorManager.DoPatch();
|
||||||
|
|
||||||
|
shieldHeartbeatIntervalMultiplier =
|
||||||
|
config.Bind("Shield", "Shield Heartbeat Interval Multiplier", 1f,
|
||||||
|
new ConfigDescription("Shield Heartbeat Interval Multiplier",
|
||||||
|
new AcceptableValueRange<float>(min, max)));
|
||||||
|
shieldHeartbeatIntervalMultiplier.SettingChanged += (sender, args) =>
|
||||||
|
|
||||||
|
ModuleShieldGeneratorManager.DoPatch();
|
||||||
|
shieldPowerUpDelayMultiplier = config.Bind(
|
||||||
|
"Shield", "Shield Power Up Delay Multiplier", 1f,
|
||||||
|
new ConfigDescription("Shield Power Up Delay Multiplier", new AcceptableValueRange<float>(min, max)));
|
||||||
|
shieldPowerUpDelayMultiplier.SettingChanged += (sender, args) => ModuleShieldGeneratorManager.DoPatch();
|
||||||
|
|
||||||
|
shieldRadiusMultiplierHealing = config.Bind(
|
||||||
|
"Shield", "Shield Radius Multiplier Healing", 1f,
|
||||||
|
new ConfigDescription("Shield Radius Multiplier Healing", new AcceptableValueRange<float>(min, max)));
|
||||||
|
shieldRadiusMultiplierHealing.SettingChanged += (sender, args) => ModuleShieldGeneratorManager.DoPatch();
|
||||||
|
}
|
||||||
|
|
||||||
private static void ConfigureShieldGenerator(MultipliedObject<ModuleShieldGenerator> obj) {
|
private static void ConfigureShieldGenerator(MultipliedObject<ModuleShieldGenerator> obj) {
|
||||||
// Healing heartbeat interval - no condition
|
obj.AddField(new FieldConfiguration<float>("m_HealingHeartbeatInterval",
|
||||||
obj.AddField(
|
ModuleShieldGeneratorManager.shieldHeartbeatIntervalMultiplier));
|
||||||
new FieldConfiguration<float>("m_HealingHeartbeatInterval", Main.shieldHeartbeatIntervalMultiplier));
|
|
||||||
|
|
||||||
// Radius - conditional based on healing status
|
obj.AddField(new FieldConfiguration<float>(
|
||||||
obj.AddField(new FieldConfiguration<float>("m_Radius", Main.shieldRadiusMultiplier, instance => {
|
"m_Radius", ModuleShieldGeneratorManager.shieldRadiusMultiplier, instance => {
|
||||||
var shield = (ModuleShieldGenerator)instance;
|
var shield = (ModuleShieldGenerator)instance;
|
||||||
return shield.m_Healing ? Main.shieldRadiusMultiplierHealing : Main.shieldRadiusMultiplier;
|
return shield.m_Healing ? ModuleShieldGeneratorManager.shieldRadiusMultiplierHealing
|
||||||
}));
|
: ModuleShieldGeneratorManager.shieldRadiusMultiplier;
|
||||||
|
}));
|
||||||
|
|
||||||
// Power up delay - no condition
|
obj.AddField(new FieldConfiguration<float>("m_PowerUpDelay",
|
||||||
obj.AddField(new FieldConfiguration<float>("m_PowerUpDelay", Main.shieldPowerUpDelayMultiplier));
|
ModuleShieldGeneratorManager.shieldPowerUpDelayMultiplier));
|
||||||
}
|
}
|
||||||
|
|
||||||
[HarmonyPrefix]
|
[HarmonyPrefix]
|
||||||
|
|||||||
Reference in New Issue
Block a user