2018-12-03 07:20:39 +00:00
|
|
|
|
using System;
|
2019-03-01 07:54:33 +00:00
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
2018-12-03 07:20:39 +00:00
|
|
|
|
using UnityEngine;
|
2019-02-28 06:46:39 +00:00
|
|
|
|
using Restock.MaterialModifiers;
|
2018-12-03 07:20:39 +00:00
|
|
|
|
|
|
|
|
|
namespace Restock
|
|
|
|
|
{
|
|
|
|
|
public class ModuleRestockModifyMaterials : PartModule
|
|
|
|
|
{
|
|
|
|
|
public override void OnLoad(ConfigNode node)
|
|
|
|
|
{
|
|
|
|
|
base.OnLoad(node);
|
|
|
|
|
|
|
|
|
|
if (HighLogic.LoadedSceneIsEditor || HighLogic.LoadedSceneIsFlight) return;
|
|
|
|
|
|
|
|
|
|
foreach (ConfigNode node2 in node.GetNodes("MATERIAL"))
|
|
|
|
|
{
|
2019-03-01 07:54:33 +00:00
|
|
|
|
IEnumerable<Renderer> renderers = GetRenderers(node2);
|
|
|
|
|
|
2018-12-03 07:21:02 +00:00
|
|
|
|
if (node2.GetValue("shader") is string newShaderName)
|
2018-12-03 07:20:39 +00:00
|
|
|
|
{
|
2018-12-03 07:21:02 +00:00
|
|
|
|
if (Shader.Find(newShaderName) is Shader newShader)
|
|
|
|
|
{
|
|
|
|
|
foreach (Renderer renderer in renderers)
|
|
|
|
|
{
|
|
|
|
|
renderer.material.shader = newShader;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-03-01 08:06:59 +00:00
|
|
|
|
this.LogError($"Can't find shader {newShaderName}");
|
2018-12-03 07:21:02 +00:00
|
|
|
|
continue;
|
|
|
|
|
}
|
2018-12-03 07:20:39 +00:00
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2019-02-28 06:46:39 +00:00
|
|
|
|
MaterialModifierParser parser = new MaterialModifierParser();
|
2018-12-03 07:20:39 +00:00
|
|
|
|
|
2019-02-28 06:46:39 +00:00
|
|
|
|
foreach (ConfigNode node3 in node2.nodes)
|
|
|
|
|
{
|
|
|
|
|
IMaterialModifier modifier;
|
|
|
|
|
try
|
2018-12-03 07:20:39 +00:00
|
|
|
|
{
|
2019-02-28 06:46:39 +00:00
|
|
|
|
modifier = parser.Parse(node3);
|
2018-12-03 07:20:39 +00:00
|
|
|
|
}
|
2019-02-28 06:46:39 +00:00
|
|
|
|
catch (Exception ex)
|
2018-12-03 07:20:39 +00:00
|
|
|
|
{
|
2019-03-01 08:06:59 +00:00
|
|
|
|
this.LogException($"cannot parse node as material modifier: \n{node3.ToString()}\n", ex);
|
2018-12-03 07:20:39 +00:00
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
foreach (Renderer renderer in renderers)
|
|
|
|
|
{
|
2019-02-28 06:46:39 +00:00
|
|
|
|
modifier.Modify(renderer.material);
|
2018-12-03 07:20:39 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
isEnabled = false;
|
|
|
|
|
moduleIsEnabled = false;
|
|
|
|
|
}
|
2019-03-01 07:54:33 +00:00
|
|
|
|
|
|
|
|
|
private IEnumerable<Renderer> GetRenderers(ConfigNode node)
|
|
|
|
|
{
|
|
|
|
|
IEnumerable<Renderer> renderers = Enumerable.Empty<Renderer>();
|
|
|
|
|
bool useAllRenderers = true;
|
|
|
|
|
|
|
|
|
|
foreach (ConfigNode.Value value in node.values)
|
|
|
|
|
{
|
|
|
|
|
if (value.name == "transform")
|
|
|
|
|
{
|
2019-03-02 07:52:18 +00:00
|
|
|
|
Transform[] modelTransforms = part.FindModelTransforms(value.value);
|
2019-03-01 07:54:33 +00:00
|
|
|
|
|
|
|
|
|
if (modelTransforms.Length == 0)
|
|
|
|
|
{
|
2019-03-01 08:06:59 +00:00
|
|
|
|
this.LogError($"Couldn't find transform named '{value.name}' on part");
|
2019-03-01 07:54:33 +00:00
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
List<Renderer> transformRenderers = new List<Renderer>(modelTransforms.Length);
|
|
|
|
|
foreach (Transform transform in modelTransforms)
|
|
|
|
|
{
|
|
|
|
|
Renderer renderer = transform.GetComponent<Renderer>();
|
|
|
|
|
|
|
|
|
|
if (renderer == null)
|
2019-03-01 08:06:59 +00:00
|
|
|
|
this.LogError($"No renderer found on transform '{transform.name}'");
|
2019-03-01 07:54:33 +00:00
|
|
|
|
else
|
|
|
|
|
transformRenderers.Add(renderer);
|
|
|
|
|
}
|
|
|
|
|
|
2019-03-02 07:52:18 +00:00
|
|
|
|
renderers = renderers.Concat(transformRenderers);
|
2019-03-01 07:54:33 +00:00
|
|
|
|
useAllRenderers = false;
|
|
|
|
|
}
|
|
|
|
|
else if (value.name == "baseTransform")
|
|
|
|
|
{
|
2019-03-02 07:52:18 +00:00
|
|
|
|
Transform[] modelTransforms = part.FindModelTransforms(value.value);
|
2019-03-01 07:54:33 +00:00
|
|
|
|
|
|
|
|
|
if (modelTransforms.Length == 0)
|
|
|
|
|
{
|
2019-03-01 08:06:59 +00:00
|
|
|
|
this.LogError($"Couldn't find transform named '{value.name}' on part");
|
2019-03-01 07:54:33 +00:00
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
foreach (Transform transform in modelTransforms)
|
|
|
|
|
{
|
|
|
|
|
Renderer[] transformRenderers = transform.GetComponentsInChildren<Renderer>();
|
|
|
|
|
|
|
|
|
|
if (transformRenderers.Length == 0)
|
2019-03-01 08:06:59 +00:00
|
|
|
|
this.LogError($"No renderers found on transform '{transform.name}' or its children");
|
2019-03-01 07:54:33 +00:00
|
|
|
|
else
|
2019-03-02 07:52:18 +00:00
|
|
|
|
renderers = renderers.Concat(transform.GetComponentsInChildren<Renderer>());
|
2019-03-01 07:54:33 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
useAllRenderers = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (useAllRenderers)
|
|
|
|
|
{
|
|
|
|
|
Transform modelTransform = part.partTransform.Find("model");
|
|
|
|
|
|
|
|
|
|
if (modelTransform == null)
|
2019-03-01 08:06:59 +00:00
|
|
|
|
this.LogError("Couldn't find model transform");
|
2019-03-01 07:54:33 +00:00
|
|
|
|
else
|
|
|
|
|
renderers = modelTransform.GetComponentsInChildren<Renderer>();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return renderers;
|
|
|
|
|
}
|
2018-12-03 07:20:39 +00:00
|
|
|
|
}
|
|
|
|
|
}
|