Refactor FireData configuration to FireDataManager
This commit is contained in:
@@ -49,9 +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> fireDataKickbackStrengthMultiplier;
|
|
||||||
public static ConfigEntry<float> fireDataMuzzleVelocityMultiplier;
|
|
||||||
|
|
||||||
public static ConfigEntry<float> boosterFanThrustMultiplier;
|
public static ConfigEntry<float> boosterFanThrustMultiplier;
|
||||||
public static ConfigEntry<float> boosterJetThrustMultiplier;
|
public static ConfigEntry<float> boosterJetThrustMultiplier;
|
||||||
|
|
||||||
@@ -82,17 +79,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)));
|
||||||
|
|
||||||
fireDataKickbackStrengthMultiplier =
|
|
||||||
Config.Bind("FireData", "Fire Data Kickback Strength Multiplier", 1f,
|
|
||||||
new ConfigDescription("Fire Data Kickback Strength Multiplier",
|
|
||||||
new AcceptableValueRange<float>(min, max)));
|
|
||||||
fireDataKickbackStrengthMultiplier.SettingChanged += (sender, args) => FireDataManager.DoPatch();
|
|
||||||
fireDataMuzzleVelocityMultiplier =
|
|
||||||
Config.Bind("FireData", "Fire Data Muzzle Velocity Multiplier", 1f,
|
|
||||||
new ConfigDescription("Fire Data Muzzle Velocity Multiplier",
|
|
||||||
new AcceptableValueRange<float>(min, max)));
|
|
||||||
fireDataMuzzleVelocityMultiplier.SettingChanged += (sender, args) => FireDataManager.DoPatch();
|
|
||||||
|
|
||||||
shootingSpeedMultiplier = Config.Bind(
|
shootingSpeedMultiplier = Config.Bind(
|
||||||
"Weapons", "Shooting Speed Multiplier", 1f,
|
"Weapons", "Shooting Speed Multiplier", 1f,
|
||||||
new ConfigDescription("Shooting Speed Multiplier", new AcceptableValueRange<float>(min, max)));
|
new ConfigDescription("Shooting Speed Multiplier", new AcceptableValueRange<float>(min, max)));
|
||||||
|
@@ -1,4 +1,5 @@
|
|||||||
using System;
|
using System;
|
||||||
|
using BepInEx.Configuration;
|
||||||
using HarmonyLib;
|
using HarmonyLib;
|
||||||
|
|
||||||
namespace TerraTech {
|
namespace TerraTech {
|
||||||
@@ -7,9 +8,31 @@ namespace TerraTech {
|
|||||||
private static readonly MultipliedObjectManager<FireData> manager =
|
private static readonly MultipliedObjectManager<FireData> manager =
|
||||||
new MultipliedObjectManager<FireData>(ConfigureFireData);
|
new MultipliedObjectManager<FireData>(ConfigureFireData);
|
||||||
|
|
||||||
|
public static ConfigEntry<float> fireDataKickbackStrengthMultiplier;
|
||||||
|
public static ConfigEntry<float> fireDataMuzzleVelocityMultiplier;
|
||||||
|
|
||||||
|
public static void Setup(ConfigFile config) {
|
||||||
|
float min = 0.01f;
|
||||||
|
float max = 32f;
|
||||||
|
|
||||||
|
fireDataKickbackStrengthMultiplier =
|
||||||
|
config.Bind("FireData", "Fire Data Kickback Strength Multiplier", 1f,
|
||||||
|
new ConfigDescription("Fire Data Kickback Strength Multiplier",
|
||||||
|
new AcceptableValueRange<float>(min, max)));
|
||||||
|
fireDataKickbackStrengthMultiplier.SettingChanged += (sender, args) => FireDataManager.DoPatch();
|
||||||
|
|
||||||
|
fireDataMuzzleVelocityMultiplier =
|
||||||
|
config.Bind("FireData", "Fire Data Muzzle Velocity Multiplier", 1f,
|
||||||
|
new ConfigDescription("Fire Data Muzzle Velocity Multiplier",
|
||||||
|
new AcceptableValueRange<float>(min, max)));
|
||||||
|
fireDataMuzzleVelocityMultiplier.SettingChanged += (sender, args) => FireDataManager.DoPatch();
|
||||||
|
}
|
||||||
|
|
||||||
private static void ConfigureFireData(MultipliedObject<FireData> obj) {
|
private static void ConfigureFireData(MultipliedObject<FireData> obj) {
|
||||||
obj.AddField(new FieldConfiguration<float>("m_MuzzleVelocity", Main.fireDataMuzzleVelocityMultiplier));
|
obj.AddField(
|
||||||
obj.AddField(new FieldConfiguration<float>("m_KickbackStrength", Main.fireDataKickbackStrengthMultiplier));
|
new FieldConfiguration<float>("m_MuzzleVelocity", FireDataManager.fireDataMuzzleVelocityMultiplier));
|
||||||
|
obj.AddField(new FieldConfiguration<float>("m_KickbackStrength",
|
||||||
|
FireDataManager.fireDataKickbackStrengthMultiplier));
|
||||||
}
|
}
|
||||||
|
|
||||||
[HarmonyPrefix]
|
[HarmonyPrefix]
|
||||||
|
@@ -7,6 +7,7 @@ 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> shieldRadiusMultiplier;
|
||||||
public static ConfigEntry<float> shieldRadiusMultiplierHealing;
|
public static ConfigEntry<float> shieldRadiusMultiplierHealing;
|
||||||
public static ConfigEntry<float> shieldHeartbeatIntervalMultiplier;
|
public static ConfigEntry<float> shieldHeartbeatIntervalMultiplier;
|
||||||
|
@@ -7,6 +7,7 @@ namespace TerraTech {
|
|||||||
public class ModuleWingManager {
|
public class ModuleWingManager {
|
||||||
private static readonly MultipliedObjectManager<ModuleWing.Aerofoil> manager =
|
private static readonly MultipliedObjectManager<ModuleWing.Aerofoil> manager =
|
||||||
new MultipliedObjectManager<ModuleWing.Aerofoil>(ConfigureAerofoil);
|
new MultipliedObjectManager<ModuleWing.Aerofoil>(ConfigureAerofoil);
|
||||||
|
|
||||||
public static ConfigEntry<float> aerofoilAngleRangeMultiplier;
|
public static ConfigEntry<float> aerofoilAngleRangeMultiplier;
|
||||||
public static ConfigEntry<float> aerofoilAngleTurnSpeedMultiplier;
|
public static ConfigEntry<float> aerofoilAngleTurnSpeedMultiplier;
|
||||||
public static ConfigEntry<float> aerofoilLiftStrengthMultiplier;
|
public static ConfigEntry<float> aerofoilLiftStrengthMultiplier;
|
||||||
|
Reference in New Issue
Block a user