mirror of
https://github.com/drewcassidy/KSP-Conformal-Decals.git
synced 2024-09-01 18:23:54 +00:00
Rework decal parameters so they dont reset when changing variants
This commit is contained in:
parent
b3d817e0c3
commit
e42ff52fb5
@ -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
|
||||||
|
Binary file not shown.
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user