Rework decal parameters so they dont reset when changing variants

This commit is contained in:
Andrew Cassidy 2020-06-08 15:38:36 -07:00
parent b3d817e0c3
commit e42ff52fb5
3 changed files with 76 additions and 103 deletions

View File

@ -58,9 +58,10 @@ PART
tileSize = 64, 64 tileSize = 64, 64
tileIndex = 0 tileIndex = 0
scale = 0.1 defaultScale = 0.1
opacity = 0.8 defaultDepth = 0.1
cutoff = 0 defaultOpacity = 0.8
defaultCutoff = 0
scaleRange = 0.05, 0.5 scaleRange = 0.05, 0.5
cutoffAdjustable = false cutoffAdjustable = false

View File

@ -8,34 +8,6 @@ namespace ConformalDecals {
public class ModuleConformalDecal : PartModule { public class ModuleConformalDecal : PartModule {
// CONFIGURABLE VALUES // CONFIGURABLE VALUES
/// <summary>
/// Decal scale factor, in meters.
/// </summary>
[KSPField(guiName = "#LOC_ConformalDecals_gui-scale", guiActive = false, guiActiveEditor = true, isPersistant = true, guiFormat = "F2", guiUnits = "m"),
UI_FloatRange(stepIncrement = 0.05f)]
public float scale = 1.0f;
/// <summary>
/// Projection depth value for the decal projector, in meters.
/// </summary>
[KSPField(guiName = "#LOC_ConformalDecals_gui-depth", guiActive = false, guiActiveEditor = true, isPersistant = true, guiFormat = "F2", guiUnits = "m"),
UI_FloatRange(stepIncrement = 0.02f)]
public float depth = 0.2f;
/// <summary>
/// Opacity value for the decal shader.
/// </summary>
[KSPField(guiName = "#LOC_ConformalDecals_gui-opacity", guiActive = false, guiActiveEditor = true, isPersistant = true, guiFormat = "P0"),
UI_FloatRange(stepIncrement = 0.05f)]
public float opacity = 1.0f;
/// <summary>
/// Alpha cutoff value for the decal shader.
/// </summary>
[KSPField(guiName = "#LOC_ConformalDecals_gui-cutoff", guiActive = false, guiActiveEditor = true, isPersistant = true, guiFormat = "P0"),
UI_FloatRange(stepIncrement = 0.05f)]
public float cutoff = 0.5f;
/// <summary> /// <summary>
/// Shader name. Should be one that supports decal projection. /// Shader name. Should be one that supports decal projection.
/// </summary> /// </summary>
@ -67,70 +39,26 @@ namespace ConformalDecals {
/// </remarks> /// </remarks>
[KSPField] public string decalProjector = string.Empty; [KSPField] public string decalProjector = string.Empty;
/// <summary> // Parameters
/// Should the scale be adjustable in the editor? Default true.
/// </summary>
[KSPField] public bool scaleAdjustable = true; [KSPField] public bool scaleAdjustable = true;
[KSPField] public float defaultScale = 1;
/// <summary>
/// Should the depth be adjustable in the editor? Default true.
/// </summary>
[KSPField] public bool depthAdjustable = true;
/// <summary>
/// Should the opacity be adjustable in the editor? Default true.
/// </summary>
[KSPField] public bool opacityAdjustable = true;
/// <summary>
/// Should the alpha cutoff be adjustable in the editor? Default true.
/// </summary>
[KSPField] public bool cutoffAdjustable = true;
/// <summary>
/// Available scale range in the editor, in meters. Comma seperated <c>min, max</c>
/// </summary>
[KSPField] public Vector2 scaleRange = new Vector2(0, 4); [KSPField] public Vector2 scaleRange = new Vector2(0, 4);
/// <summary> [KSPField] public bool depthAdjustable = true;
/// Available depth range in the editor, in meters. Comma seperated <c>min, max</c> [KSPField] public float defaultDepth = 0.1f;
/// </summary>
[KSPField] public Vector2 depthRange = new Vector2(0, 2); [KSPField] public Vector2 depthRange = new Vector2(0, 2);
/// <summary> [KSPField] public bool opacityAdjustable = true;
/// Available opacity range in the editor. Comma seperated <c>min, max</c> [KSPField] public float defaultOpacity = 1;
/// </summary>
[KSPField] public Vector2 opacityRange = new Vector2(0, 1); [KSPField] public Vector2 opacityRange = new Vector2(0, 1);
/// <summary> [KSPField] public bool cutoffAdjustable = true;
/// Available alpha cutoff range in the editor. Comma seperated <c>min, max</c> [KSPField] public float defaultCutoff = 0;
/// </summary>
[KSPField] public Vector2 cutoffRange = new Vector2(0, 1); [KSPField] public Vector2 cutoffRange = new Vector2(0, 1);
/// <summary>
/// Rectangle mask to use for any autotile textures, in pixels.
/// </summary>
/// <remarks>
/// Overrides <see cref="tileSize"/> and <see cref="tileIndex"/> if specified. Comma seperated <c>x, y, width, height</c>
/// </remarks>
[KSPField] public Rect tileRect = new Rect(-1, -1, 0, 0); [KSPField] public Rect tileRect = new Rect(-1, -1, 0, 0);
/// <summary>
/// Tile size for texture atlases, in pixels.
/// </summary>
/// <remarks>
/// Overrided by <see cref="tileRect"/>, Comma seperated <c>width, height</c>
/// </remarks>
/// <seealso cref="tileIndex"/>
[KSPField] public Vector2 tileSize; [KSPField] public Vector2 tileSize;
/// <summary>
/// Tile index for texture atlases, 0-indexed.
/// </summary>
/// <remarks>
/// Overrided by <see cref="tileRect"/>, must be a positive integer. Starts with 0 in the upper left corner.
/// </remarks>
/// <seealso cref="tileSize"/>
[KSPField] public int tileIndex = -1; [KSPField] public int tileIndex = -1;
/// <summary> /// <summary>
@ -145,6 +73,34 @@ namespace ConformalDecals {
// INTERNAL VALUES // INTERNAL VALUES
/// <summary>
/// Decal scale factor, in meters.
/// </summary>
[KSPField(guiName = "#LOC_ConformalDecals_gui-scale", guiActive = false, guiActiveEditor = true, isPersistant = true, guiFormat = "F2", guiUnits = "m"),
UI_FloatRange(stepIncrement = 0.05f)]
public float scale = 1.0f;
/// <summary>
/// Projection depth value for the decal projector, in meters.
/// </summary>
[KSPField(guiName = "#LOC_ConformalDecals_gui-depth", guiActive = false, guiActiveEditor = true, isPersistant = true, guiFormat = "F2", guiUnits = "m"),
UI_FloatRange(stepIncrement = 0.02f)]
public float depth = 0.2f;
/// <summary>
/// Opacity value for the decal shader.
/// </summary>
[KSPField(guiName = "#LOC_ConformalDecals_gui-opacity", guiActive = false, guiActiveEditor = true, isPersistant = true, guiFormat = "P0"),
UI_FloatRange(stepIncrement = 0.05f)]
public float opacity = 1.0f;
/// <summary>
/// Alpha cutoff value for the decal shader.
/// </summary>
[KSPField(guiName = "#LOC_ConformalDecals_gui-cutoff", guiActive = false, guiActiveEditor = true, isPersistant = true, guiFormat = "P0"),
UI_FloatRange(stepIncrement = 0.05f)]
public float cutoff = 0.5f;
[KSPField] public MaterialPropertyCollection materialProperties; [KSPField] public MaterialPropertyCollection materialProperties;
[KSPField] public Transform decalFrontTransform; [KSPField] public Transform decalFrontTransform;
@ -163,7 +119,6 @@ namespace ConformalDecals {
private bool _isAttached; private bool _isAttached;
private Matrix4x4 _orthoMatrix; private Matrix4x4 _orthoMatrix;
private Bounds _decalBounds;
private Material _decalMaterial; private Material _decalMaterial;
private Material _previewMaterial; private Material _previewMaterial;
@ -297,6 +252,12 @@ namespace ConformalDecals {
if (HighLogic.LoadedSceneIsGame) { if (HighLogic.LoadedSceneIsGame) {
UpdateScale(); UpdateScale();
} }
else {
scale = defaultScale;
depth = defaultDepth;
opacity = defaultOpacity;
cutoff = defaultCutoff;
}
} }
/// <inheritdoc /> /// <inheritdoc />
@ -500,21 +461,28 @@ namespace ConformalDecals {
opacityField.guiActiveEditor = opacityAdjustable; opacityField.guiActiveEditor = opacityAdjustable;
cutoffField.guiActiveEditor = cutoffAdjustable; cutoffField.guiActiveEditor = cutoffAdjustable;
var steps = 20;
if (scaleAdjustable) { if (scaleAdjustable) {
var minValue = Mathf.Max(Mathf.Epsilon, scaleRange.x); var minValue = Mathf.Max(Mathf.Epsilon, scaleRange.x);
var maxValue = Mathf.Max(minValue, scaleRange.y); var maxValue = Mathf.Max(minValue, scaleRange.y);
((UI_FloatRange) scaleField.uiControlEditor).minValue = minValue; var scaleEditor = (UI_FloatRange) scaleField.uiControlEditor;
((UI_FloatRange) scaleField.uiControlEditor).maxValue = maxValue; scaleEditor.minValue = minValue;
scaleField.uiControlEditor.onFieldChanged = OnSizeTweakEvent; scaleEditor.maxValue = maxValue;
scaleEditor.stepIncrement = (maxValue - minValue) / steps;
scaleEditor.onFieldChanged = OnSizeTweakEvent;
} }
if (depthAdjustable) { if (depthAdjustable) {
var minValue = Mathf.Max(Mathf.Epsilon, depthRange.x); var minValue = Mathf.Max(Mathf.Epsilon, depthRange.x);
var maxValue = Mathf.Max(minValue, depthRange.y); var maxValue = Mathf.Max(minValue, depthRange.y);
((UI_FloatRange) depthField.uiControlEditor).minValue = minValue;
((UI_FloatRange) depthField.uiControlEditor).maxValue = maxValue; var depthEditor = (UI_FloatRange) depthField.uiControlEditor;
depthField.uiControlEditor.onFieldChanged = OnSizeTweakEvent; depthEditor.minValue = minValue;
depthEditor.maxValue = maxValue;
depthEditor.stepIncrement = (maxValue - minValue) / steps;
depthEditor.onFieldChanged = OnSizeTweakEvent;
} }
if (opacityAdjustable) { if (opacityAdjustable) {
@ -522,9 +490,11 @@ namespace ConformalDecals {
var maxValue = Mathf.Max(minValue, opacityRange.y); var maxValue = Mathf.Max(minValue, opacityRange.y);
maxValue = Mathf.Min(1, maxValue); maxValue = Mathf.Min(1, maxValue);
((UI_FloatRange) opacityField.uiControlEditor).minValue = minValue; var opacityEditor = (UI_FloatRange) opacityField.uiControlEditor;
((UI_FloatRange) opacityField.uiControlEditor).maxValue = maxValue; opacityEditor.minValue = minValue;
opacityField.uiControlEditor.onFieldChanged = OnMaterialTweakEvent; opacityEditor.maxValue = maxValue;
opacityEditor.stepIncrement = (maxValue - minValue) / steps;
opacityEditor.onFieldChanged = OnMaterialTweakEvent;
} }
if (cutoffAdjustable) { if (cutoffAdjustable) {
@ -532,9 +502,11 @@ namespace ConformalDecals {
var maxValue = Mathf.Max(minValue, cutoffRange.y); var maxValue = Mathf.Max(minValue, cutoffRange.y);
maxValue = Mathf.Min(1, maxValue); maxValue = Mathf.Min(1, maxValue);
((UI_FloatRange) cutoffField.uiControlEditor).minValue = minValue; var cutoffEditor = (UI_FloatRange) cutoffField.uiControlEditor;
((UI_FloatRange) cutoffField.uiControlEditor).maxValue = maxValue; cutoffEditor.minValue = minValue;
cutoffField.uiControlEditor.onFieldChanged = OnMaterialTweakEvent; cutoffEditor.maxValue = maxValue;
cutoffEditor.stepIncrement = (maxValue - minValue) / steps;
cutoffEditor.onFieldChanged = OnMaterialTweakEvent;
} }
} }