Revert "Add fallbacks to all fonts, even squad ones"

This reverts commit ac1289a46e.
This commit is contained in:
Andrew Cassidy 2020-11-13 01:55:42 -08:00
parent d4978b1b3c
commit 981a167864
5 changed files with 18 additions and 30 deletions

View File

@ -21,8 +21,6 @@ CONFORMALDECALS {
shader = Solid Color (Alpha) shader = Solid Color (Alpha)
} }
fallbackFont = NotoSans-Regular SDF
FONT { FONT {
name = LiberationSans SDF name = LiberationSans SDF
title = Liberation Sans title = Liberation Sans

View File

@ -13,7 +13,6 @@ 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 string _fallbackFontName = "NotoSans-Regular SDF";
private struct LegacyShaderEntry { private struct LegacyShaderEntry {
public string name; public string name;
@ -52,7 +51,7 @@ namespace ConformalDecals {
public static IEnumerable<DecalFont> Fonts => _fontList.Values; public static IEnumerable<DecalFont> Fonts => _fontList.Values;
public static TMP_FontAsset FallbackFont { get; private set; } public static DecalFont FallbackFont { get; private set; }
public static bool IsBlacklisted(Shader shader) { public static bool IsBlacklisted(Shader shader) {
return IsBlacklisted(shader.name); return IsBlacklisted(shader.name);
@ -95,27 +94,14 @@ namespace ConformalDecals {
} }
var allFonts = Resources.FindObjectsOfTypeAll<TMP_FontAsset>(); var allFonts = Resources.FindObjectsOfTypeAll<TMP_FontAsset>();
ParseUtil.ParseStringIndirect(ref _fallbackFontName, node, "fallbackFont");
FallbackFont = allFonts.First(o => o.name == _fallbackFontName);
if (FallbackFont == null) Logging.LogError($"could not find find fallback font asset named {_fallbackFontName}");
foreach (var fontNode in node.GetNodes("FONT")) { foreach (var fontNode in node.GetNodes("FONT")) {
try { try {
var name = ParseUtil.ParseString(fontNode, "name"); var font = new DecalFont(fontNode, allFonts);
if (string.IsNullOrEmpty(name)) throw new FormatException();
var fontAsset = allFonts.First(o => o.name == name);
if (fontAsset == null) throw new FormatException($"Could not find font asset named {name}");
if (!fontAsset.fallbackFontAssets.Contains(FallbackFont)) {
fontAsset.fallbackFontAssets.Add(FallbackFont);
}
var font = new DecalFont(name, fontNode, fontAsset);
_fontList.Add(font.Name, font); _fontList.Add(font.Name, font);
} }
catch (Exception e) { catch (Exception e) {
Logging.LogException($"Exception parsing font node:\n{fontNode.ToString()}\n", e); Debug.LogException(e);
} }
} }
} }

View File

@ -40,15 +40,19 @@ namespace ConformalDecals.Text {
public bool SmallCapsMask => (FontStyleMask & FontStyles.SmallCaps) != 0; public bool SmallCapsMask => (FontStyleMask & FontStyles.SmallCaps) != 0;
public DecalFont(string name, ConfigNode node, TMP_FontAsset font) { public DecalFont(ConfigNode node, IEnumerable<TMP_FontAsset> fontAssets) {
if (name == null) throw new ArgumentNullException(nameof(name));
if (node == null) throw new ArgumentNullException(nameof(node)); if (node == null) throw new ArgumentNullException(nameof(node));
if (font == null) throw new ArgumentNullException(nameof(font)); if (fontAssets == null) throw new ArgumentNullException(nameof(fontAssets));
var name = ParseUtil.ParseString(node, "name");
FontAsset = fontAssets.First(o => o.name == name);
if (FontAsset == null) {
throw new FormatException($"Could not find font asset named {name}");
}
Title = ParseUtil.ParseString(node, "title", true, name); Title = ParseUtil.ParseString(node, "title", true, name);
FontStyle = (FontStyles) ParseUtil.ParseInt(node, "style", true); FontStyle = (FontStyles) ParseUtil.ParseInt(node, "style", true);
FontStyleMask = (FontStyles) ParseUtil.ParseInt(node, "styleMask", true); FontStyleMask = (FontStyles) ParseUtil.ParseInt(node, "styleMask", true);
FontAsset = font;
} }

View File

@ -11,13 +11,12 @@ namespace ConformalDecals.Text {
[DatabaseLoaderAttrib(new[] {"decalfont"})] [DatabaseLoaderAttrib(new[] {"decalfont"})]
public class FontLoader : DatabaseLoader<GameDatabase.TextureInfo> { public class FontLoader : DatabaseLoader<GameDatabase.TextureInfo> {
private const string FallbackName = "NotoSans-Regular SDF"; private const string FallbackName = "NotoSans-Regular SDF";
private static TMP_FontAsset _fallbackFont;
public static TMP_FontAsset FallbackFont { get; private set; }
public override IEnumerator Load(UrlDir.UrlFile urlFile, FileInfo fileInfo) { public override IEnumerator Load(UrlDir.UrlFile urlFile, FileInfo fileInfo) {
if (FallbackFont == null) { if (_fallbackFont == null) {
FallbackFont = Resources.FindObjectsOfTypeAll<TMP_FontAsset>().First(o => o.name == FallbackName); _fallbackFont = Resources.FindObjectsOfTypeAll<TMP_FontAsset>().First(o => o.name == FallbackName);
if (FallbackFont == null) Logging.LogError($"Could not find fallback font '{FallbackName}'"); if (_fallbackFont == null) Logging.LogError($"Could not find fallback font '{FallbackName}'");
} }
Logging.Log($"Loading font file '{urlFile.fullPath}'"); Logging.Log($"Loading font file '{urlFile.fullPath}'");
@ -29,6 +28,7 @@ namespace ConformalDecals.Text {
var loadedFonts = bundle.LoadAllAssets<TMP_FontAsset>(); var loadedFonts = bundle.LoadAllAssets<TMP_FontAsset>();
foreach (var font in loadedFonts) { foreach (var font in loadedFonts) {
Logging.Log($"Adding font {font.name}"); Logging.Log($"Adding font {font.name}");
font.fallbackFontAssets.Add(_fallbackFont);
} }
} }