123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- using System.Collections;
- using System.Collections.Generic;
- using UnityEngine;
- namespace TMPro
- {
-
-
-
- public class TMP_ResourceManager
- {
- private static readonly TMP_ResourceManager s_instance = new TMP_ResourceManager();
- static TMP_ResourceManager() { }
-
-
-
- private static TMP_Settings s_TextSettings;
- internal static TMP_Settings GetTextSettings()
- {
- if (s_TextSettings == null)
- {
-
- s_TextSettings = Resources.Load<TMP_Settings>("TextSettings");
- #if UNITY_EDITOR
- if (s_TextSettings == null)
- {
-
- TMP_PackageResourceImporterWindow.ShowPackageImporterWindow();
- }
- #endif
- }
- return s_TextSettings;
- }
-
-
-
- private static readonly List<TMP_FontAsset> s_FontAssetReferences = new List<TMP_FontAsset>();
- private static readonly Dictionary<int, TMP_FontAsset> s_FontAssetReferenceLookup = new Dictionary<int, TMP_FontAsset>();
-
-
-
-
- public static void AddFontAsset(TMP_FontAsset fontAsset)
- {
- int hashcode = fontAsset.hashCode;
- if (s_FontAssetReferenceLookup.ContainsKey(hashcode))
- return;
- s_FontAssetReferences.Add(fontAsset);
- s_FontAssetReferenceLookup.Add(hashcode, fontAsset);
- }
-
-
-
-
-
-
- public static bool TryGetFontAsset(int hashcode, out TMP_FontAsset fontAsset)
- {
- fontAsset = null;
- return s_FontAssetReferenceLookup.TryGetValue(hashcode, out fontAsset);
- }
- internal static void RebuildFontAssetCache(int instanceID)
- {
-
- for (int i = 0; i < s_FontAssetReferences.Count; i++)
- {
- TMP_FontAsset fontAsset = s_FontAssetReferences[i];
- if (fontAsset.FallbackSearchQueryLookup.Contains(instanceID))
- fontAsset.ReadFontAssetDefinition();
- }
- }
- }
- }
|