Unify material modifiers

Allows float and color properties to be set on actual parts now, not just
fairings
This commit is contained in:
blowfish 2019-02-27 22:46:39 -08:00
parent a5944d8193
commit 8d8795c57d
9 changed files with 171 additions and 35 deletions

View File

@ -0,0 +1,22 @@
using System;
using UnityEngine;
namespace Restock.MaterialModifiers
{
public class ColorPropertyMaterialModifier : IMaterialModifier
{
private readonly string propertyName;
private readonly Color color;
public ColorPropertyMaterialModifier(string propertyName, Color color)
{
this.propertyName = propertyName ?? throw new ArgumentNullException(nameof(propertyName));
this.color = color;
}
public void Modify(Material material)
{
material.SetColor(propertyName, color);
}
}
}

View File

@ -0,0 +1,22 @@
using System;
using UnityEngine;
namespace Restock.MaterialModifiers
{
public class FloatPropertyMaterialModifier : IMaterialModifier
{
private readonly string propertyName;
private readonly float value;
public FloatPropertyMaterialModifier(string propertyName, float value)
{
this.propertyName = propertyName ?? throw new ArgumentNullException(nameof(propertyName));
this.value = value;
}
public void Modify(Material material)
{
material.SetFloat(propertyName, value);
}
}
}

View File

@ -0,0 +1,10 @@
using System;
using UnityEngine;
namespace Restock.MaterialModifiers
{
public interface IMaterialModifier
{
void Modify(Material material);
}
}

View File

@ -0,0 +1,62 @@
using System;
using UnityEngine;
namespace Restock.MaterialModifiers
{
public class MaterialModifierParser
{
private readonly string logContext;
public MaterialModifierParser(string logContext = nameof(MaterialModifierParser))
{
this.logContext = logContext ?? throw new ArgumentNullException(nameof(logContext));
}
public IMaterialModifier Parse(ConfigNode node)
{
string propertyName = node.GetValue("name");
if (propertyName == null)
throw new FormatException("name not found, cannot create material modifier");
else if (propertyName == string.Empty)
throw new FormatException("name is empty, cannot create material modifier");
if (node.name == "FLOAT_PROPERTY")
{
float value = float.Parse(node.GetValue("value"));
return new FloatPropertyMaterialModifier(propertyName, value);
}
else if (node.name == "COLOR_PROPERTY")
{
Color color = ConfigNode.ParseColor(node.GetValue("color"));
return new ColorPropertyMaterialModifier(propertyName, color);
}
else if (node.name == "TEXTURE_PROPERTY")
{
string textureUrl = node.GetValue("textureUrl");
bool normalMapToggle = false;
if (node.GetValue("isNormalMap") is string normalMapToggleString)
normalMapToggle = bool.Parse(normalMapToggleString);
GameDatabase.TextureInfo textureInfo = GameDatabase.Instance.GetTextureInfo(textureUrl);
if (textureInfo == null)
throw new Exception($"Cannot find texture: '{textureUrl}'");
Texture2D texture = normalMapToggle ? textureInfo.normalMap : textureInfo.texture;
if (texture == null)
throw new Exception($"Cannot get texture from texture info '{textureUrl}' isNormalMap = {normalMapToggle}");
return new TexturePropertyMaterialModifier(propertyName, texture);
}
else
{
throw new FormatException($"Can't create material modifier from node: '{node.name}'");
}
}
}
}

View File

@ -0,0 +1,22 @@
using System;
using UnityEngine;
namespace Restock.MaterialModifiers
{
public class TexturePropertyMaterialModifier : IMaterialModifier
{
private readonly string propertyName;
private readonly Texture2D texture;
public TexturePropertyMaterialModifier(string propertyName, Texture2D texture)
{
this.propertyName = propertyName ?? throw new ArgumentNullException(nameof(propertyName));
this.texture = texture ?? throw new ArgumentNullException(nameof(texture));
}
public void Modify(Material material)
{
material.SetTexture(propertyName, texture);
}
}
}

View File

@ -1,6 +1,7 @@
using System; using System;
using System.Collections; using System.Collections;
using UnityEngine; using UnityEngine;
using Restock.MaterialModifiers;
namespace Restock namespace Restock
{ {
@ -44,35 +45,30 @@ namespace Restock
yield break; yield break;
} }
UpdateMaterial(fairingModule.FairingMaterial, node); MaterialModifierParser parser = new MaterialModifierParser();
UpdateMaterial(fairingModule.FairingConeMaterial, node);
UpdateMaterial(fairingModule.FairingFlightMaterial, node); foreach (ConfigNode node2 in node.nodes)
UpdateMaterial(fairingModule.FairingFlightConeMaterial, node); {
IMaterialModifier modifier;
try
{
modifier = parser.Parse(node2);
}
catch (Exception ex)
{
Debug.LogException(new Exception($"[{nameof(ModuleRestockModifyFairingMaterials)}] cannot parse node as material modifier: \n{node2.ToString()}\n", ex));
continue;
}
modifier.Modify(fairingModule.FairingMaterial);
modifier.Modify(fairingModule.FairingConeMaterial);
modifier.Modify(fairingModule.FairingFlightMaterial);
modifier.Modify(fairingModule.FairingFlightConeMaterial);
foreach (ProceduralFairings.FairingPanel fairingPanel in fairingModule.Panels) foreach (ProceduralFairings.FairingPanel fairingPanel in fairingModule.Panels)
{ {
MeshRenderer renderer = fairingPanel.go.GetComponent<MeshRenderer>(); MeshRenderer renderer = fairingPanel.go.GetComponent<MeshRenderer>();
UpdateMaterial(renderer.material, node); modifier.Modify(renderer.material);
}
}
private void UpdateMaterial(Material material, ConfigNode node)
{
foreach (ConfigNode node2 in node.nodes)
{
if (node2.name == "COLOR_PROPERTY")
{
string name = node2.GetValue("name");
Color color = ConfigNode.ParseColor(node2.GetValue("color"));
material.SetColor(name, color);
}
else if (node2.name == "FLOAT_PROPERTY")
{
string name = node2.GetValue("name");
float value = float.Parse(node2.GetValue("value"));
material.SetFloat(name, value);
} }
} }
} }

View File

@ -1,5 +1,6 @@
using System; using System;
using UnityEngine; using UnityEngine;
using Restock.MaterialModifiers;
namespace Restock namespace Restock
{ {
@ -40,28 +41,24 @@ namespace Restock
} }
foreach (ConfigNode node3 in node2.GetNodes("TEXTURE_PROPERTY")) MaterialModifierParser parser = new MaterialModifierParser();
{
string name = node3.GetValue("name");
string textureUrl = node3.GetValue("textureUrl");
bool normalMapToggle = false;
if (node3.GetValue("isNormalMap") is string normalMapToggleString) foreach (ConfigNode node3 in node2.nodes)
{ {
normalMapToggle = bool.Parse(normalMapToggleString); IMaterialModifier modifier;
try
{
modifier = parser.Parse(node3);
} }
catch (Exception ex)
GameDatabase.TextureInfo textureInfo = GameDatabase.Instance.GetTextureInfo(textureUrl);
if (textureInfo == null)
{ {
Debug.LogError($"Cannot find texture: {textureUrl}"); Debug.LogException(new Exception($"[{nameof(ModuleRestockModifyMaterials)}] cannot parse node as material modifier: \n{node3.ToString()}\n", ex));
continue; continue;
} }
foreach (Renderer renderer in renderers) foreach (Renderer renderer in renderers)
{ {
renderer.material.SetTexture(name, normalMapToggle ? textureInfo.normalMap : textureInfo.texture); modifier.Modify(renderer.material);
} }
} }
} }

View File

@ -41,6 +41,11 @@
</Reference> </Reference>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Compile Include="MaterialModifiers\ColorPropertyMaterialModifier.cs" />
<Compile Include="MaterialModifiers\FloatPropertyMaterialModifier.cs" />
<Compile Include="MaterialModifiers\IMaterialModifier.cs" />
<Compile Include="MaterialModifiers\MaterialModifierParser.cs" />
<Compile Include="MaterialModifiers\TexturePropertyMaterialModifier.cs" />
<Compile Include="ModuleRestockModifyFairingMaterials.cs" /> <Compile Include="ModuleRestockModifyFairingMaterials.cs" />
<Compile Include="ModuleRestockModifyMaterials.cs" /> <Compile Include="ModuleRestockModifyMaterials.cs" />
<Compile Include="Properties\AssemblyInfo.cs" /> <Compile Include="Properties\AssemblyInfo.cs" />