mirror of
https://github.com/drewcassidy/KSP-Conformal-Decals.git
synced 2024-09-01 18:23:54 +00:00
Make range and adjustability of tweakables configurable
This commit is contained in:
parent
ed9553d1fd
commit
921a159262
@ -1,3 +1,3 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
version https://git-lfs.github.com/spec/v1
|
||||||
oid sha256:b7bca0055ccf123563b0f98713febc87961848cdfb73c3616300c7de77405442
|
oid sha256:a87abea70a75c8e4c1317f25f400276203608a8a6b1ddbeff91014a7986e0f74
|
||||||
size 26624
|
size 27648
|
||||||
|
@ -4,6 +4,9 @@ using UnityEngine;
|
|||||||
|
|
||||||
namespace ConformalDecals.MaterialModifiers {
|
namespace ConformalDecals.MaterialModifiers {
|
||||||
public class MaterialPropertyCollection : ScriptableObject {
|
public class MaterialPropertyCollection : ScriptableObject {
|
||||||
|
private static int _opacityID = Shader.PropertyToID("_Opacity");
|
||||||
|
private static int _cutoffID = Shader.PropertyToID("_Cutoff");
|
||||||
|
|
||||||
public TextureMaterialProperty MainTextureProperty { get; set; }
|
public TextureMaterialProperty MainTextureProperty { get; set; }
|
||||||
|
|
||||||
public Material parsedMaterial;
|
public Material parsedMaterial;
|
||||||
@ -105,10 +108,18 @@ namespace ConformalDecals.MaterialModifiers {
|
|||||||
module.Log($"Parsed {_materialProperties.Count} properties");
|
module.Log($"Parsed {_materialProperties.Count} properties");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void UpdateMaterial(Vector2 scale) {
|
public void SetScale(Vector2 scale) {
|
||||||
foreach (var textureProperty in _textureMaterialProperties) {
|
foreach (var textureProperty in _textureMaterialProperties) {
|
||||||
textureProperty.UpdateScale(parsedMaterial, scale);
|
textureProperty.UpdateScale(parsedMaterial, scale);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void SetOpacity(float opacity) {
|
||||||
|
parsedMaterial.SetFloat(_opacityID, opacity);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetCutoff(float cutoff) {
|
||||||
|
parsedMaterial.SetFloat(_cutoffID, cutoff);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -34,10 +34,15 @@ namespace ConformalDecals {
|
|||||||
[KSPField] public Transform decalModelTransform;
|
[KSPField] public Transform decalModelTransform;
|
||||||
[KSPField] public Transform decalProjectorTransform;
|
[KSPField] public Transform decalProjectorTransform;
|
||||||
|
|
||||||
[KSPField] public bool adjustableScale = true;
|
[KSPField] public bool scaleAdjustable = true;
|
||||||
[KSPField] public bool adjustableDepth = true;
|
[KSPField] public bool depthAdjustable = true;
|
||||||
[KSPField] public bool adjustableOpacity = true;
|
[KSPField] public bool opacityAdjustable = true;
|
||||||
[KSPField] public bool adjustableCutoff = true;
|
[KSPField] public bool cutoffAdjustable = true;
|
||||||
|
|
||||||
|
[KSPField] public Vector2 scaleRange = new Vector2(0, 4);
|
||||||
|
[KSPField] public Vector2 depthRange = new Vector2(0, 4);
|
||||||
|
[KSPField] public Vector2 opacityRange = new Vector2(0, 1);
|
||||||
|
[KSPField] public Vector2 cutoffRange = new Vector2(0, 1);
|
||||||
|
|
||||||
[KSPField] public bool updateBackScale = true;
|
[KSPField] public bool updateBackScale = true;
|
||||||
|
|
||||||
@ -52,6 +57,7 @@ namespace ConformalDecals {
|
|||||||
private Vector2 _backTextureBaseScale;
|
private Vector2 _backTextureBaseScale;
|
||||||
private Material _backMaterial;
|
private Material _backMaterial;
|
||||||
|
|
||||||
|
|
||||||
public override void OnLoad(ConfigNode node) {
|
public override void OnLoad(ConfigNode node) {
|
||||||
this.Log("Loading module");
|
this.Log("Loading module");
|
||||||
try {
|
try {
|
||||||
@ -121,8 +127,49 @@ namespace ConformalDecals {
|
|||||||
if ((state & StartState.Editor) != 0) {
|
if ((state & StartState.Editor) != 0) {
|
||||||
GameEvents.onEditorPartEvent.Add(OnEditorEvent);
|
GameEvents.onEditorPartEvent.Add(OnEditorEvent);
|
||||||
GameEvents.onVariantApplied.Add(OnVariantApplied);
|
GameEvents.onVariantApplied.Add(OnVariantApplied);
|
||||||
Fields[nameof(scale)].uiControlEditor.onFieldChanged = OnScaleTweakEvent;
|
|
||||||
Fields[nameof(depth)].uiControlEditor.onFieldChanged = OnScaleTweakEvent;
|
// setup tweakable fields
|
||||||
|
var scaleField = Fields[nameof(scale)];
|
||||||
|
var depthField = Fields[nameof(depth)];
|
||||||
|
var opacityField = Fields[nameof(opacity)];
|
||||||
|
var cutoffField = Fields[nameof(cutoff)];
|
||||||
|
|
||||||
|
if (scaleField.guiActiveEditor = scaleAdjustable) {
|
||||||
|
var minValue = Mathf.Max(Mathf.Epsilon, scaleRange.x);
|
||||||
|
var maxValue = Mathf.Max(minValue, scaleRange.y);
|
||||||
|
|
||||||
|
(scaleField.uiControlEditor as UI_FloatRange).minValue = minValue;
|
||||||
|
(scaleField.uiControlEditor as UI_FloatRange).maxValue = maxValue;
|
||||||
|
scaleField.uiControlEditor.onFieldChanged = OnSizeTweakEvent;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (depthField.guiActiveEditor = depthAdjustable) {
|
||||||
|
var minValue = Mathf.Max(Mathf.Epsilon, depthRange.x);
|
||||||
|
var maxValue = Mathf.Max(minValue, depthRange.y);
|
||||||
|
(depthField.uiControlEditor as UI_FloatRange).minValue = minValue;
|
||||||
|
(depthField.uiControlEditor as UI_FloatRange).maxValue = maxValue;
|
||||||
|
depthField.uiControlEditor.onFieldChanged = OnSizeTweakEvent;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (opacityField.guiActiveEditor = opacityAdjustable) {
|
||||||
|
var minValue = Mathf.Max(0, opacityRange.x);
|
||||||
|
var maxValue = Mathf.Max(minValue, opacityRange.y);
|
||||||
|
maxValue = Mathf.Min(1, maxValue);
|
||||||
|
|
||||||
|
(opacityField.uiControlEditor as UI_FloatRange).minValue = minValue;
|
||||||
|
(opacityField.uiControlEditor as UI_FloatRange).maxValue = maxValue;
|
||||||
|
opacityField.uiControlEditor.onFieldChanged = OnMaterialTweakEvent;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cutoffField.guiActiveEditor = cutoffAdjustable) {
|
||||||
|
var minValue = Mathf.Max(0, cutoffRange.x);
|
||||||
|
var maxValue = Mathf.Max(minValue, cutoffRange.y);
|
||||||
|
maxValue = Mathf.Min(1, maxValue);
|
||||||
|
|
||||||
|
(cutoffField.uiControlEditor as UI_FloatRange).minValue = minValue;
|
||||||
|
(cutoffField.uiControlEditor as UI_FloatRange).maxValue = maxValue;
|
||||||
|
cutoffField.uiControlEditor.onFieldChanged = OnMaterialTweakEvent;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// get back material if necessary
|
// get back material if necessary
|
||||||
@ -159,13 +206,18 @@ namespace ConformalDecals {
|
|||||||
Camera.onPreCull -= Render;
|
Camera.onPreCull -= Render;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnScaleTweakEvent(BaseField field, object obj) {
|
private void OnSizeTweakEvent(BaseField field, object obj) {
|
||||||
// scale or depth values have been changed, so update scale
|
// scale or depth values have been changed, so update scale
|
||||||
// and update projection matrices if attached
|
// and update projection matrices if attached
|
||||||
UpdateScale();
|
UpdateScale();
|
||||||
if (_isAttached) UpdateProjection();
|
if (_isAttached) UpdateProjection();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void OnMaterialTweakEvent(BaseField field, object obj) {
|
||||||
|
materialProperties.SetOpacity(opacity);
|
||||||
|
materialProperties.SetCutoff(cutoff);
|
||||||
|
}
|
||||||
|
|
||||||
private void OnVariantApplied(Part eventPart, PartVariant variant) {
|
private void OnVariantApplied(Part eventPart, PartVariant variant) {
|
||||||
if (_isAttached && eventPart == part.parent) {
|
if (_isAttached && eventPart == part.parent) {
|
||||||
OnDetach();
|
OnDetach();
|
||||||
@ -274,7 +326,7 @@ namespace ConformalDecals {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// update material scale
|
// update material scale
|
||||||
materialProperties.UpdateMaterial(size);
|
materialProperties.SetScale(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void UpdateProjection() {
|
private void UpdateProjection() {
|
||||||
|
Loading…
Reference in New Issue
Block a user