Refactor FireData configuration to FireDataManager

This commit is contained in:
2025-02-24 09:26:10 +01:00
parent b69db2edc8
commit 9718e254aa
4 changed files with 27 additions and 16 deletions

View File

@@ -49,9 +49,6 @@ namespace TerraTech {
public static ConfigEntry<float> aerofoilAngleTurnSpeedMultiplier;
public static ConfigEntry<float> aerofoilLiftStrengthMultiplier;
public static ConfigEntry<float> fireDataKickbackStrengthMultiplier;
public static ConfigEntry<float> fireDataMuzzleVelocityMultiplier;
public static ConfigEntry<float> boosterFanThrustMultiplier;
public static ConfigEntry<float> boosterJetThrustMultiplier;
@@ -82,17 +79,6 @@ namespace TerraTech {
"General", "Heartbeat Interval Multiplier", 1f,
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(
"Weapons", "Shooting Speed Multiplier", 1f,
new ConfigDescription("Shooting Speed Multiplier", new AcceptableValueRange<float>(min, max)));

View File

@@ -1,4 +1,5 @@
using System;
using BepInEx.Configuration;
using HarmonyLib;
namespace TerraTech {
@@ -7,9 +8,31 @@ namespace TerraTech {
private static readonly MultipliedObjectManager<FireData> manager =
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) {
obj.AddField(new FieldConfiguration<float>("m_MuzzleVelocity", Main.fireDataMuzzleVelocityMultiplier));
obj.AddField(new FieldConfiguration<float>("m_KickbackStrength", Main.fireDataKickbackStrengthMultiplier));
obj.AddField(
new FieldConfiguration<float>("m_MuzzleVelocity", FireDataManager.fireDataMuzzleVelocityMultiplier));
obj.AddField(new FieldConfiguration<float>("m_KickbackStrength",
FireDataManager.fireDataKickbackStrengthMultiplier));
}
[HarmonyPrefix]

View File

@@ -7,6 +7,7 @@ namespace TerraTech {
public class ModuleShieldGeneratorManager {
private static readonly MultipliedObjectManager<ModuleShieldGenerator> manager =
new MultipliedObjectManager<ModuleShieldGenerator>(ConfigureShieldGenerator);
public static ConfigEntry<float> shieldRadiusMultiplier;
public static ConfigEntry<float> shieldRadiusMultiplierHealing;
public static ConfigEntry<float> shieldHeartbeatIntervalMultiplier;

View File

@@ -7,6 +7,7 @@ namespace TerraTech {
public class ModuleWingManager {
private static readonly MultipliedObjectManager<ModuleWing.Aerofoil> manager =
new MultipliedObjectManager<ModuleWing.Aerofoil>(ConfigureAerofoil);
public static ConfigEntry<float> aerofoilAngleRangeMultiplier;
public static ConfigEntry<float> aerofoilAngleTurnSpeedMultiplier;
public static ConfigEntry<float> aerofoilLiftStrengthMultiplier;