Add size calculation modes

This commit is contained in:
Andrew Cassidy 2020-06-11 17:30:31 -07:00
parent a386281fb2
commit e27267c862
3 changed files with 42 additions and 5 deletions

View File

@ -69,6 +69,7 @@ PART
cutoffAdjustable = false cutoffAdjustable = false
scaleRange = 0.1, 4 scaleRange = 0.1, 4
scaleMode = AVERAGE
shader = ConformalDecals/Paint/Specular shader = ConformalDecals/Paint/Specular
@ -504,7 +505,7 @@ PART
IDENTIFIER { name = ModuleConformalDecal } IDENTIFIER { name = ModuleConformalDecal }
DATA { DATA {
shader = ConformalDecals/Paint/SpecularSDF shader = ConformalDecals/Paint/SpecularSDF
tile = 670, 456, 48, 48 tile = 710, 456, 48, 48
} }
} }
} }

View File

@ -6,6 +6,15 @@ using UnityEngine;
namespace ConformalDecals { namespace ConformalDecals {
public class ModuleConformalDecal : PartModule { public class ModuleConformalDecal : PartModule {
public enum DecalScaleMode {
HEIGHT,
WIDTH,
AVERAGE,
AREA,
MINIMUM,
MAXIMUM
}
// CONFIGURABLE VALUES // CONFIGURABLE VALUES
/// <summary> /// <summary>
@ -41,9 +50,10 @@ namespace ConformalDecals {
// Parameters // Parameters
[KSPField] public bool scaleAdjustable = true; [KSPField] public bool scaleAdjustable = true;
[KSPField] public float defaultScale = 1; [KSPField] public float defaultScale = 1;
[KSPField] public Vector2 scaleRange = new Vector2(0, 4); [KSPField] public Vector2 scaleRange = new Vector2(0, 4);
[KSPField] public DecalScaleMode scaleMode = DecalScaleMode.HEIGHT;
[KSPField] public bool depthAdjustable = true; [KSPField] public bool depthAdjustable = true;
[KSPField] public float defaultDepth = 0.1f; [KSPField] public float defaultDepth = 0.1f;
@ -241,6 +251,7 @@ namespace ConformalDecals {
var tileValid = ParseExtensions.TryParseRect(tileString, out tileRect); var tileValid = ParseExtensions.TryParseRect(tileString, out tileRect);
if (!tileValid) throw new FormatException($"Invalid rect value for tile '{tileString}'"); if (!tileValid) throw new FormatException($"Invalid rect value for tile '{tileString}'");
} }
if (tileRect.x >= 0) { if (tileRect.x >= 0) {
materialProperties.UpdateTile(tileRect); materialProperties.UpdateTile(tileRect);
} }
@ -269,6 +280,7 @@ namespace ConformalDecals {
depth = defaultDepth; depth = defaultDepth;
opacity = defaultOpacity; opacity = defaultOpacity;
cutoff = defaultCutoff; cutoff = defaultCutoff;
wear = defaultWear;
} }
} }
@ -405,7 +417,31 @@ namespace ConformalDecals {
protected void UpdateScale() { protected void UpdateScale() {
var aspectRatio = materialProperties.AspectRatio; var aspectRatio = materialProperties.AspectRatio;
var size = new Vector2(scale, scale * aspectRatio); Vector2 size;
switch (scaleMode) {
default:
case DecalScaleMode.HEIGHT:
size = new Vector2(scale, scale * aspectRatio);
break;
case DecalScaleMode.WIDTH:
size = new Vector2(scale / aspectRatio, scale);
break;
case DecalScaleMode.AVERAGE:
var width1 = 2 * scale / (1 + aspectRatio);
size = new Vector2(width1, width1 * aspectRatio);
break;
case DecalScaleMode.AREA:
var width2 = Mathf.Sqrt(scale / aspectRatio);
size = new Vector2(width2, width2 * aspectRatio);
break;
case DecalScaleMode.MINIMUM:
if (aspectRatio > 1) goto case DecalScaleMode.WIDTH;
else goto case DecalScaleMode.HEIGHT;
case DecalScaleMode.MAXIMUM:
if (aspectRatio > 1) goto case DecalScaleMode.HEIGHT;
else goto case DecalScaleMode.WIDTH;
}
// update material scale // update material scale
materialProperties.UpdateScale(size); materialProperties.UpdateScale(size);