mirror of
https://github.com/drewcassidy/KSP-Conformal-Decals.git
synced 2024-09-01 18:23:54 +00:00
flag aspect ratio overrides are now configurable
no longer hard coded to Squad/Flags
This commit is contained in:
parent
dfdf280564
commit
ece9d959fd
@ -13,6 +13,8 @@ All notable changes to this project will be documented in this file
|
|||||||
### Changed
|
### Changed
|
||||||
|
|
||||||
- Updated bundled Shabby to 0.3.0. Does not affect CKAN users
|
- Updated bundled Shabby to 0.3.0. Does not affect CKAN users
|
||||||
|
- Made flag aspect ratio overrides configurable with `ASPECTRATIO` nodes in the config. User flags added to Squad/Flags should now be the correct aspect ratio
|
||||||
|
- All decal aspect ratios can now be overriden with the `aspectRatio` field
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
|
||||||
|
@ -49,4 +49,309 @@ CONFORMALDECALS {
|
|||||||
style = 32
|
style = 32
|
||||||
styleMask = 4
|
styleMask = 4
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/09
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/Sentinel_Flag
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/blorbs
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/bullseye
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/capsule
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/circles
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/default
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/hexagon
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/hexagonCircles
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/kerbal1
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/kerbal2
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/kerbin
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/kerbinmunflag
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/line
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/minimalistic
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/orbit
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/orbs
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/retro
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/rings
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/rocketScience
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/satellite
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/spheres
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/squadLogo
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/squadLogo2
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/stripes
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/trees
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Flags/trippy
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/FlagsAgency/NASA
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/FlagsAgency/esa_dark_blue
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/FlagsAgency/uk_space_agency
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/FlagsOrganization/B612_Foundation_flag
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/FlagsOrganization/ESA_Arianespace
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/FlagsOrganization/electron
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/FlagsOrganization/rocketlab
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/C7AerospaceDivision
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/DinkelsteinKermansConstructionEmporium
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/ExperimentalEngineering
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/FlooydResearchLab
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/GoliathNationalProducts
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/IntegratedIntegrals
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/IonicSymphonicProtonicElectronics
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/JebsJunkyard
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/KerbalMotion
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/KerbinWorldFirstRecordKeepingSociety
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/Kerbodyne
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/Kerlington
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/MaxoConstructionToys
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/MovingPartsExpertsGroup
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/OMBDemolition
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/PeriapsisCo
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/Probodobodyne
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/R&D
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/ReactionSystemsLtd
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/Rockomax
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/Rokea
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/SeansCannery
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/SteadlerEngineeringCorps
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/StrutCo
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/Vac-Co
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/WinterOwl
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
|
|
||||||
|
ASPECTRATIO {
|
||||||
|
path = Squad/Agencies/ZaltonicElectronics
|
||||||
|
aspectRatio = 0.625
|
||||||
|
}
|
||||||
}
|
}
|
@ -15,6 +15,7 @@ namespace ConformalDecals {
|
|||||||
private static Dictionary<string, DecalFont> _fontList;
|
private static Dictionary<string, DecalFont> _fontList;
|
||||||
private static int _decalLayer = 31;
|
private static int _decalLayer = 31;
|
||||||
private static bool _selectableInFlight;
|
private static bool _selectableInFlight;
|
||||||
|
private static Dictionary<string, float> _aspectRatios;
|
||||||
|
|
||||||
private struct LegacyShaderEntry {
|
private struct LegacyShaderEntry {
|
||||||
public string name;
|
public string name;
|
||||||
@ -53,6 +54,8 @@ namespace ConformalDecals {
|
|||||||
|
|
||||||
public static IEnumerable<DecalFont> Fonts => _fontList.Values;
|
public static IEnumerable<DecalFont> Fonts => _fontList.Values;
|
||||||
|
|
||||||
|
public static Dictionary<string, float> AspectRatios => _aspectRatios;
|
||||||
|
|
||||||
public static bool IsBlacklisted(Shader shader) {
|
public static bool IsBlacklisted(Shader shader) {
|
||||||
return IsBlacklisted(shader.name);
|
return IsBlacklisted(shader.name);
|
||||||
}
|
}
|
||||||
@ -86,8 +89,7 @@ namespace ConformalDecals {
|
|||||||
public static DecalFont GetFont(string name) {
|
public static DecalFont GetFont(string name) {
|
||||||
if (_fontList.TryGetValue(name, out var font)) {
|
if (_fontList.TryGetValue(name, out var font)) {
|
||||||
return font;
|
return font;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
throw new KeyNotFoundException($"Font {name} not found");
|
throw new KeyNotFoundException($"Font {name} not found");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -113,8 +115,17 @@ namespace ConformalDecals {
|
|||||||
try {
|
try {
|
||||||
var font = new DecalFont(fontNode, allFonts);
|
var font = new DecalFont(fontNode, allFonts);
|
||||||
_fontList.Add(font.Name, font);
|
_fontList.Add(font.Name, font);
|
||||||
|
} catch (Exception e) {
|
||||||
|
Debug.LogException(e);
|
||||||
}
|
}
|
||||||
catch (Exception e) {
|
}
|
||||||
|
|
||||||
|
foreach (var ratioNode in node.GetNodes("ASPECTRATIO")) {
|
||||||
|
try {
|
||||||
|
var path = ParseUtil.ParseString(ratioNode, "path");
|
||||||
|
var ratio = ParseUtil.ParseFloat(ratioNode, "aspectRatio");
|
||||||
|
_aspectRatios[path] = ratio;
|
||||||
|
} catch (Exception e) {
|
||||||
Debug.LogException(e);
|
Debug.LogException(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -144,6 +155,7 @@ namespace ConformalDecals {
|
|||||||
_shaderBlacklist = new List<string>();
|
_shaderBlacklist = new List<string>();
|
||||||
_shaderRegexBlacklist = new List<Regex>();
|
_shaderRegexBlacklist = new List<Regex>();
|
||||||
_fontList = new Dictionary<string, DecalFont>();
|
_fontList = new Dictionary<string, DecalFont>();
|
||||||
|
_aspectRatios = new Dictionary<string, float>();
|
||||||
|
|
||||||
var configs = GameDatabase.Instance.GetConfigs("CONFORMALDECALS");
|
var configs = GameDatabase.Instance.GetConfigs("CONFORMALDECALS");
|
||||||
|
|
||||||
|
@ -75,7 +75,12 @@ namespace ConformalDecals.MaterialProperties {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public float AspectRatio => MainTexture == null ? 1 : MainTexture.AspectRatio;
|
public float AspectRatio {
|
||||||
|
get => MainTexture == null ? 1 : MainTexture.AspectRatio;
|
||||||
|
set {
|
||||||
|
if (MainTexture != null) MainTexture.AspectRatio = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void OnBeforeSerialize() {
|
public void OnBeforeSerialize() {
|
||||||
if (_materialProperties == null) throw new SerializationException("Tried to serialize an uninitialized MaterialPropertyCollection");
|
if (_materialProperties == null) throw new SerializationException("Tried to serialize an uninitialized MaterialPropertyCollection");
|
||||||
@ -136,8 +141,7 @@ namespace ConformalDecals.MaterialProperties {
|
|||||||
public T GetProperty<T>(string propertyName) where T : MaterialProperty {
|
public T GetProperty<T>(string propertyName) where T : MaterialProperty {
|
||||||
if (_materialProperties.ContainsKey(propertyName) && _materialProperties[propertyName] is T property) {
|
if (_materialProperties.ContainsKey(propertyName) && _materialProperties[propertyName] is T property) {
|
||||||
return property;
|
return property;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -145,8 +149,7 @@ namespace ConformalDecals.MaterialProperties {
|
|||||||
public T AddOrGetProperty<T>(string propertyName) where T : MaterialProperty {
|
public T AddOrGetProperty<T>(string propertyName) where T : MaterialProperty {
|
||||||
if (_materialProperties.ContainsKey(propertyName) && _materialProperties[propertyName] is T property) {
|
if (_materialProperties.ContainsKey(propertyName) && _materialProperties[propertyName] is T property) {
|
||||||
return property;
|
return property;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
return AddProperty<T>(propertyName);
|
return AddProperty<T>(propertyName);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -156,9 +159,10 @@ namespace ConformalDecals.MaterialProperties {
|
|||||||
foreach (var material in Materials) {
|
foreach (var material in Materials) {
|
||||||
property.Remove(material);
|
property.Remove(material);
|
||||||
}
|
}
|
||||||
|
|
||||||
_materialProperties.Remove(propertyName);
|
_materialProperties.Remove(propertyName);
|
||||||
Destroy(property);
|
Destroy(property);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -204,8 +208,7 @@ namespace ConformalDecals.MaterialProperties {
|
|||||||
if (_shader == null) {
|
if (_shader == null) {
|
||||||
Logging.Log("Using default decal shader");
|
Logging.Log("Using default decal shader");
|
||||||
shaderName = "ConformalDecals/Decal/Standard";
|
shaderName = "ConformalDecals/Decal/Standard";
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,6 +19,8 @@ namespace ConformalDecals.MaterialProperties {
|
|||||||
[SerializeField] private Vector2 _textureOffset;
|
[SerializeField] private Vector2 _textureOffset;
|
||||||
[SerializeField] private Vector2 _textureScale = Vector2.one;
|
[SerializeField] private Vector2 _textureScale = Vector2.one;
|
||||||
|
|
||||||
|
[SerializeField] private float _aspectRatioOverride = -1.0f;
|
||||||
|
|
||||||
public Texture2D Texture {
|
public Texture2D Texture {
|
||||||
get => _texture;
|
get => _texture;
|
||||||
set => _texture = value;
|
set => _texture = value;
|
||||||
@ -43,10 +45,12 @@ namespace ConformalDecals.MaterialProperties {
|
|||||||
|
|
||||||
public float AspectRatio {
|
public float AspectRatio {
|
||||||
get {
|
get {
|
||||||
|
if (_aspectRatioOverride > 0) return _aspectRatioOverride;
|
||||||
if (_texture == null) return 1;
|
if (_texture == null) return 1;
|
||||||
if (_textureUrl?.Contains("Squad/Flags") == true) return 0.625f;
|
|
||||||
return MaskedHeight / (float) MaskedWidth;
|
return MaskedHeight / (float) MaskedWidth;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
set => _aspectRatioOverride = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void ParseNode(ConfigNode node) {
|
public override void ParseNode(ConfigNode node) {
|
||||||
@ -64,7 +68,7 @@ namespace ConformalDecals.MaterialProperties {
|
|||||||
if (ParseUtil.ParseStringIndirect(ref _textureUrl, node, "textureUrl")) {
|
if (ParseUtil.ParseStringIndirect(ref _textureUrl, node, "textureUrl")) {
|
||||||
_texture = LoadTexture(_textureUrl, isNormal);
|
_texture = LoadTexture(_textureUrl, isNormal);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_texture == null) {
|
if (_texture == null) {
|
||||||
_texture = isNormal ? DecalConfig.BlankNormal : Texture2D.whiteTexture;
|
_texture = isNormal ? DecalConfig.BlankNormal : Texture2D.whiteTexture;
|
||||||
}
|
}
|
||||||
|
@ -35,6 +35,8 @@ namespace ConformalDecals {
|
|||||||
|
|
||||||
[KSPField] public DecalScaleMode scaleMode = DecalScaleMode.HEIGHT;
|
[KSPField] public DecalScaleMode scaleMode = DecalScaleMode.HEIGHT;
|
||||||
|
|
||||||
|
[KSPField] public float aspectRatio = -1.0f; // < 0 = use texture
|
||||||
|
|
||||||
[KSPField] public bool depthAdjustable = true;
|
[KSPField] public bool depthAdjustable = true;
|
||||||
[KSPField] public float defaultDepth = 0.1f;
|
[KSPField] public float defaultDepth = 0.1f;
|
||||||
[KSPField] public Vector2 depthRange = new Vector2(0, 2);
|
[KSPField] public Vector2 depthRange = new Vector2(0, 2);
|
||||||
@ -201,6 +203,10 @@ namespace ConformalDecals {
|
|||||||
} else if (tileIndex >= 0) {
|
} else if (tileIndex >= 0) {
|
||||||
materialProperties.UpdateTile(tileIndex, tileSize);
|
materialProperties.UpdateTile(tileIndex, tileSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// handle aspect ratio overrides
|
||||||
|
materialProperties.AspectRatio = aspectRatio;
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
this.LogException("Exception parsing partmodule", e);
|
this.LogException("Exception parsing partmodule", e);
|
||||||
}
|
}
|
||||||
@ -393,30 +399,32 @@ namespace ConformalDecals {
|
|||||||
protected void UpdateScale() {
|
protected void UpdateScale() {
|
||||||
scale = Mathf.Max(0.01f, scale);
|
scale = Mathf.Max(0.01f, scale);
|
||||||
depth = Mathf.Max(0.01f, depth);
|
depth = Mathf.Max(0.01f, depth);
|
||||||
var aspectRatio = Mathf.Max(0.01f, materialProperties.AspectRatio);
|
|
||||||
|
var sizeRatio = Mathf.Max(0.01f, materialProperties.AspectRatio);
|
||||||
|
|
||||||
Vector2 size;
|
Vector2 size;
|
||||||
|
|
||||||
switch (scaleMode) {
|
switch (scaleMode) {
|
||||||
default:
|
default:
|
||||||
case DecalScaleMode.HEIGHT:
|
case DecalScaleMode.HEIGHT:
|
||||||
size = new Vector2(scale / aspectRatio, scale);
|
size = new Vector2(scale / sizeRatio, scale);
|
||||||
break;
|
break;
|
||||||
case DecalScaleMode.WIDTH:
|
case DecalScaleMode.WIDTH:
|
||||||
size = new Vector2(scale, scale * aspectRatio);
|
size = new Vector2(scale, scale * sizeRatio);
|
||||||
break;
|
break;
|
||||||
case DecalScaleMode.AVERAGE:
|
case DecalScaleMode.AVERAGE:
|
||||||
var width1 = 2 * scale / (1 + aspectRatio);
|
var width1 = 2 * scale / (1 + sizeRatio);
|
||||||
size = new Vector2(width1, width1 * aspectRatio);
|
size = new Vector2(width1, width1 * sizeRatio);
|
||||||
break;
|
break;
|
||||||
case DecalScaleMode.AREA:
|
case DecalScaleMode.AREA:
|
||||||
var width2 = Mathf.Sqrt(scale / aspectRatio);
|
var width2 = Mathf.Sqrt(scale / sizeRatio);
|
||||||
size = new Vector2(width2, width2 * aspectRatio);
|
size = new Vector2(width2, width2 * sizeRatio);
|
||||||
break;
|
break;
|
||||||
case DecalScaleMode.MINIMUM:
|
case DecalScaleMode.MINIMUM:
|
||||||
if (aspectRatio > 1) goto case DecalScaleMode.WIDTH;
|
if (sizeRatio > 1) goto case DecalScaleMode.WIDTH;
|
||||||
else goto case DecalScaleMode.HEIGHT;
|
else goto case DecalScaleMode.HEIGHT;
|
||||||
case DecalScaleMode.MAXIMUM:
|
case DecalScaleMode.MAXIMUM:
|
||||||
if (aspectRatio > 1) goto case DecalScaleMode.HEIGHT;
|
if (sizeRatio > 1) goto case DecalScaleMode.HEIGHT;
|
||||||
else goto case DecalScaleMode.WIDTH;
|
else goto case DecalScaleMode.WIDTH;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -433,7 +441,7 @@ namespace ConformalDecals {
|
|||||||
|
|
||||||
// update projection
|
// update projection
|
||||||
foreach (var target in _targets) {
|
foreach (var target in _targets) {
|
||||||
if (target == null) {
|
if (target.target == null) {
|
||||||
_targets.Remove(target);
|
_targets.Remove(target);
|
||||||
} else {
|
} else {
|
||||||
target.Project(_orthoMatrix, decalProjectorTransform, _boundsRenderer.bounds, useBaseNormal);
|
target.Project(_orthoMatrix, decalProjectorTransform, _boundsRenderer.bounds, useBaseNormal);
|
||||||
@ -570,13 +578,19 @@ namespace ConformalDecals {
|
|||||||
public void Render(Camera camera) {
|
public void Render(Camera camera) {
|
||||||
if (!_isAttached) return;
|
if (!_isAttached) return;
|
||||||
|
|
||||||
// render on each target object
|
try {
|
||||||
foreach (var target in _targets) {
|
// render on each target object
|
||||||
if (target == null) {
|
foreach (var target in _targets) {
|
||||||
_targets.Remove(target);
|
|
||||||
} else {
|
|
||||||
target.Render(_decalMaterial, part.mpb, camera);
|
target.Render(_decalMaterial, part.mpb, camera);
|
||||||
}
|
}
|
||||||
|
} catch (NullReferenceException) {
|
||||||
|
// catch any NREs and purge null transforms from the target list
|
||||||
|
// comparing Transform to null is expensive, but a try-catch block is much cheaper
|
||||||
|
foreach (var target in _targets) {
|
||||||
|
if (target.target == null) {
|
||||||
|
_targets.Remove(target);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
using ConformalDecals.Util;
|
||||||
using UnityEngine;
|
using UnityEngine;
|
||||||
|
|
||||||
namespace ConformalDecals {
|
namespace ConformalDecals {
|
||||||
@ -48,12 +49,12 @@ namespace ConformalDecals {
|
|||||||
UpdateFlag();
|
UpdateFlag();
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual void OnDestroy() {
|
public override void OnDestroy() {
|
||||||
if (HighLogic.LoadedSceneIsEditor) {
|
if (HighLogic.LoadedSceneIsEditor) {
|
||||||
// Unregister flag change event
|
// Unregister flag change event
|
||||||
GameEvents.onMissionFlagSelect.Remove(OnEditorFlagSelected);
|
GameEvents.onMissionFlagSelect.Remove(OnEditorFlagSelected);
|
||||||
}
|
}
|
||||||
|
|
||||||
base.OnDestroy();
|
base.OnDestroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -106,12 +107,13 @@ namespace ConformalDecals {
|
|||||||
// get the decal material property for the decal texture
|
// get the decal material property for the decal texture
|
||||||
var textureProperty = materialProperties.AddOrGetTextureProperty("_Decal", true);
|
var textureProperty = materialProperties.AddOrGetTextureProperty("_Decal", true);
|
||||||
|
|
||||||
if (useCustomFlag) {
|
string textureURL = useCustomFlag ? flagUrl : MissionFlagUrl;
|
||||||
// set the texture to the custom flag
|
textureProperty.TextureUrl = textureURL;
|
||||||
textureProperty.TextureUrl = flagUrl;
|
|
||||||
} else {
|
if (DecalConfig.AspectRatios.ContainsKey(textureURL)) {
|
||||||
// set the texture to the mission flag
|
var ratio = DecalConfig.AspectRatios[textureURL];
|
||||||
textureProperty.TextureUrl = MissionFlagUrl;
|
this.Log($"Overriding aspect ratio for {textureURL} with {ratio}");
|
||||||
|
textureProperty.AspectRatio = ratio;
|
||||||
}
|
}
|
||||||
|
|
||||||
UpdateMaterials();
|
UpdateMaterials();
|
||||||
|
@ -220,7 +220,7 @@ namespace ConformalDecals {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void OnDestroy() {
|
public override void OnDestroy() {
|
||||||
if (HighLogic.LoadedSceneIsGame && _currentText != null) TextRenderer.UnregisterText(_currentText);
|
if (HighLogic.LoadedSceneIsGame && _currentText != null) TextRenderer.UnregisterText(_currentText);
|
||||||
|
|
||||||
// close all UIs
|
// close all UIs
|
||||||
|
Loading…
Reference in New Issue
Block a user