ReStocked/Source/Restock/ModuleRestockModifyFairingMaterials.cs

77 lines
2.3 KiB
C#
Raw Permalink Normal View History

2019-01-13 06:13:59 +00:00
using System;
using System.Collections;
using UnityEngine;
using Restock.MaterialModifiers;
2019-01-13 06:13:59 +00:00
namespace Restock
{
public class ModuleRestockModifyFairingMaterials : PartModule
{
[SerializeField]
private string serializedNode;
public override void OnLoad(ConfigNode node)
{
base.OnLoad(node);
if (serializedNode == null)
serializedNode = node.ToString();
}
public override void OnStart(StartState state)
{
base.OnStart(state);
StartCoroutine(WaitAndUpdateMaterials());
}
private IEnumerator WaitAndUpdateMaterials()
{
yield return null;
if (string.IsNullOrEmpty(serializedNode))
{
this.LogError("Serialized node is null or empty!");
2019-01-13 06:13:59 +00:00
yield break;
}
ConfigNode node = ConfigNode.Parse(serializedNode).nodes[0];
ModuleProceduralFairing fairingModule = part.FindModuleImplementing<ModuleProceduralFairing>();
if (fairingModule == null)
{
this.LogError("No fairing module found on part!");
2019-01-13 06:13:59 +00:00
yield break;
}
MaterialModifierParser parser = new MaterialModifierParser();
2019-01-13 06:13:59 +00:00
foreach (ConfigNode node2 in node.nodes)
{
IMaterialModifier modifier;
try
2019-01-13 06:13:59 +00:00
{
modifier = parser.Parse(node2);
2019-01-13 06:13:59 +00:00
}
catch (Exception ex)
2019-01-13 06:13:59 +00:00
{
this.LogException($"cannot parse node as material modifier: \n{node2.ToString()}\n", ex);
continue;
}
2019-01-13 06:13:59 +00:00
modifier.Modify(fairingModule.FairingMaterial);
modifier.Modify(fairingModule.FairingConeMaterial);
modifier.Modify(fairingModule.FairingFlightMaterial);
modifier.Modify(fairingModule.FairingFlightConeMaterial);
foreach (ProceduralFairings.FairingPanel fairingPanel in fairingModule.Panels)
{
MeshRenderer renderer = fairingPanel.go.GetComponent<MeshRenderer>();
modifier.Modify(renderer.material);
2019-01-13 06:13:59 +00:00
}
}
}
}
}