2019-01-13 06:13:59 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections;
|
|
|
|
|
using UnityEngine;
|
2019-02-28 06:46:39 +00:00
|
|
|
|
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))
|
|
|
|
|
{
|
2019-03-01 08:06:59 +00:00
|
|
|
|
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)
|
|
|
|
|
{
|
2019-03-01 08:06:59 +00:00
|
|
|
|
this.LogError("No fairing module found on part!");
|
2019-01-13 06:13:59 +00:00
|
|
|
|
yield break;
|
|
|
|
|
}
|
|
|
|
|
|
2019-02-28 06:46:39 +00:00
|
|
|
|
MaterialModifierParser parser = new MaterialModifierParser();
|
2019-01-13 06:13:59 +00:00
|
|
|
|
|
|
|
|
|
foreach (ConfigNode node2 in node.nodes)
|
|
|
|
|
{
|
2019-02-28 06:46:39 +00:00
|
|
|
|
IMaterialModifier modifier;
|
|
|
|
|
try
|
2019-01-13 06:13:59 +00:00
|
|
|
|
{
|
2019-02-28 06:46:39 +00:00
|
|
|
|
modifier = parser.Parse(node2);
|
2019-01-13 06:13:59 +00:00
|
|
|
|
}
|
2019-02-28 06:46:39 +00:00
|
|
|
|
catch (Exception ex)
|
2019-01-13 06:13:59 +00:00
|
|
|
|
{
|
2019-03-01 08:06:59 +00:00
|
|
|
|
this.LogException($"cannot parse node as material modifier: \n{node2.ToString()}\n", ex);
|
2019-02-28 06:46:39 +00:00
|
|
|
|
continue;
|
|
|
|
|
}
|
2019-01-13 06:13:59 +00:00
|
|
|
|
|
2019-02-28 06:46:39 +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
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|