123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056 |
- using UnityEngine;
- using UnityEngine.UI;
- using UnityEngine.Events;
- using System;
- using System.Collections;
- using System.Linq.Expressions;
- using System.ComponentModel;
- using System.Collections.Generic;
- using Object = UnityEngine.Object;
- using Random = UnityEngine.Random;
- using Component = UnityEngine.Component;
- public enum Folder
- {
- UI,
- Atlas,
- Atlas2,
- Effect,
- Audio,
- Scene,
- Config,
- Discard,
- }
- public enum ObjType
- {
- Null,
- Firework,
- LightwallUI,
- Player,
- Page,
- Flower,
- Garden,
- Tutorial,
- CloseItem,
- DressRoom,
- Canvas,
- GroupA,
- GroupB,
- GroupC,
- GroupD,
- GroupE,
- EventSystem,
- MainCamera,
- HudText,
- MailItem,
- InfoItem,
- SkillItem,
- SignItem,
- FlowerItem,
- AchieveItem,
- Music,
- Star,
- DropGold,
- DropDiamond,
- Bee,
- Beetle,
- Butterfly,
- Dragonfly,
- }
- public class AsyncRequest
- {
- public UnityAction Callback;
- public AssetBundleRequest Request;
- }
- public class ManaReso : Regist
- {
- #region 变量
- public static bool AsyncLoadLock;
- public static bool AsyncInstantiateLock;
- public static Coroutine CoroLoad;
- public static Coroutine CoroInstantiate;
- public static ManaReso Instance;
- public static List<UnityAction> AsyncList = new List<UnityAction>();
- public static List<AssetBundleRequest> RequestList = new List<AssetBundleRequest>();
- public static List<KV<AsyncRequest, UnityAction>> InstantiateList = new List<KV<AsyncRequest, UnityAction>>();
- public static Dictionary<string, Object> ObjDic = new Dictionary<string, Object>();
- public static Dictionary<string, Transform> TraDic = new Dictionary<string, Transform>();
- public static Dictionary<GameObject, ObjType> ObjPoolDic = new Dictionary<GameObject, ObjType>();
- public static Dictionary<ObjType, List<Transform>> ObjectPool = new Dictionary<ObjType, List<Transform>>();
- #endregion
- public override bool RegistImmed()
- {
- if (base.RegistImmed())
- {
- return true;
- }
- Instance = this;
- Transform objPool = new GameObject("ObjPool").transform;
- objPool.parent = transform;
- objPool.SetActive(false);
- TraDic.Add(objPool.name, objPool);
- CoroLoad = StartCoroutine(IAsyncLoad());
- CoroInstantiate = StartCoroutine(IAsyncInstancitate());
- return false;
- }
- #region TraDic
- public static T Get<T>(string goName, bool warn = true)
- {
- Transform tra;
- if (TraDic.TryGetValue(goName, out tra))
- {
- T t = tra.GetComponent<T>();
- if (t == null)
- {
- throw new Exception(goName);
- }
- return t;
- }
- else
- {
- if (warn)
- {
- throw new Exception(goName);
- }
- else
- {
- return default(T);
- }
- }
- }
- public static T[] Gets<T>(string goName, bool warn = true)
- {
- Transform tra;
- if (TraDic.TryGetValue(goName, out tra))
- {
- T[] t = tra.GetComponentsInChildren<T>();
- if (t == null)
- {
- throw new Exception(goName);
- }
- return t;
- }
- else
- {
- if (warn)
- {
- throw new Exception(goName);
- }
- else
- {
- return default(T[]);
- }
- }
- }
- public static Transform Get(string goName, bool warn = true)
- {
- Transform tra;
- if (TraDic.TryGetValue(goName, out tra))
- {
- return tra;
- }
- else
- {
- if (warn)
- {
- throw new Exception(goName);
- }
- else
- {
- return null;
- }
- }
- }
- #endregion
- #region ObjPool
- public static void Release()
- {
- Bundle.Discard.Unload(false);
- }
- public static void Save<T>(T t, bool warn = false) where T : Component
- {
- Save(t.gameObject);
- }
- public static void Save(GameObject go, bool warn = false)
- {
- ObjType objType;
- if (!ObjPoolDic.TryGetValue(go, out objType))
- {
- throw new Exception();
- }
- List<Transform> traList;
- if (ObjectPool.TryGetValue(objType, out traList))
- {
- if (traList.Contains(go.transform))
- {
- if (warn)
- {
- return;
- }
- else
- {
- throw new Exception();
- }
- }
- go.SetActive(false);
- traList.Add(go.transform);
- go.transform.SetParent(Get("ObjPool"));
- }
- else
- {
- throw new Exception();
- }
- }
- public static bool Contains<T>(T t) where T : Component
- {
- return Contains(t.gameObject);
- }
- public static bool Contains(GameObject go)
- {
- foreach (var kv in ObjectPool)
- {
- if (kv.Value.Contains(go.transform))
- {
- return true;
- }
- }
- return false;
- }
- public static Transform Get(ObjType objType)
- {
- List<Transform> traList;
-
- if (ObjectPool.TryGetValue(objType, out traList))
- {
- if (traList.Count > 0)
- {
- Transform tra = traList[0];
- tra.SetActive(true);
- traList.RemoveAt(0);
- return tra.transform;
- }
- }
- return null;
- }
- #endregion
- #region ShortCut
- public static Text SetText(string goName)
- {
- Text text = Get<Text>(goName);
- text.text = Language.GetStr("UI", goName);
- return text;
- }
- public static Text SetText(string goName, string str)
- {
- Text text = Get<Text>(goName);
- text.text = str;
- return text;
- }
- public static Image SetSprite(string goName, Sprite sprite)
- {
- Image image = Get<Image>(goName);
- image.sprite = sprite;
- return image;
- }
- public static Transform SetActive(string goName, bool active)
- {
- Transform tra = Get(goName);
- tra.SetActive(active);
- return tra;
- }
- public static Button SetButtonEvent(string goName, UnityAction onClick)
- {
- Button button = Get<Button>(goName);
- button.onClick = new Button.ButtonClickedEvent();
- button.onClick.AddListener(onClick);
- return button;
- }
- public static Button AddButtonEvent(string goName, UnityAction onClick)
- {
- Button button = Get<Button>(goName);
- button.onClick.AddListener(onClick);
- return button;
- }
- public static Button PushButtonEvent(string goName, UnityAction onClick)
- {
- Button button = Get<Button>(goName);
- Button.ButtonClickedEvent click = button.onClick;
- button.onClick = new Button.ButtonClickedEvent();
- button.onClick.AddListener(onClick);
- button.onClick.AddListener(click.Invoke);
- return button;
- }
- public static Button AddButtonEventOnetime(string goName, UnityAction onClick)
- {
- Button button = Get<Button>(goName);
- onClick += () =>
- {
- button.onClick.RemoveListener(onClick);
- };
- button.onClick.AddListener(onClick);
- return button;
- }
- public static Button PushButtonEventOnetime(string goName, UnityAction onClick)
- {
- Button button = Get<Button>(goName);
- onClick += () =>
- {
- button.onClick.RemoveListener(onClick);
- };
- Button.ButtonClickedEvent click = button.onClick;
- button.onClick = new Button.ButtonClickedEvent();
- button.onClick.AddListener(onClick);
- button.onClick.AddListener(click.Invoke);
- return button;
- }
- #endregion
- public static T Load<T>(string goName, Folder folder, ObjType objType = ObjType.Null) where T : Object
- {
- Object obj;
-
- if (ObjDic.TryGetValue(goName, out obj))
- {
- if (objType != ObjType.Null)
- {
- ObjectPool.UniqueAdd(objType, new List<Transform>());
- }
-
- return (T) obj;
- }
- else
- {
- T t = Bundle.Load<T>(goName, folder);
-
- if (t == null)
- {
- throw new Exception(goName);
- }
- ObjDic.Add(goName, t);
- if (objType != ObjType.Null)
- {
- ObjectPool.UniqueAdd(objType, new List<Transform>());
- }
- return t;
- }
- }
- public static Sprite LoadSprite(string goName, Folder folder)
- {
- return Load<Sprite>(goName, folder);
- }
- public static Transform Get(string goName, Folder folder, bool compile, Transform par, bool worldSpace, ObjType objType = ObjType.Null, Type type = null)
- {
- Transform tra = Get(objType);
- if (tra == null)
- {
- GameObject go = Load<GameObject>(goName, folder, objType);
- go = Instantiate(go, par, worldSpace);
- go.name = go.name.Replace("(Clone)", "");
- if (compile)
- {
- Auxiliary.CompileDic(go.transform, TraDic);
- }
- if (objType != ObjType.Null)
- {
- ObjPoolDic.Add(go, objType);
- }
- if (type != null)
- {
- go.AddComponent(type);
- }
- return go.transform;
- }
- else
- {
- if (compile)
- {
- Auxiliary.CompileDic(tra, TraDic);
- }
- GameObject prefab = Load<GameObject>(goName, folder, objType);
- tra.SetParent(par);
- if (worldSpace)
- {
- tra.position = prefab.transform.position;
- }
- else
- {
- tra.localPosition = prefab.transform.position;
- }
- if (type != null)
- {
- if (tra.GetComponent(type) == null)
- {
- tra.AddComponent(type);
- }
- }
- return tra;
- }
- }
- public static Transform Get(string goName, Folder folder, bool compile, Transform par, Vector3 pos, ObjType objType = ObjType.Null, Type type = null)
- {
- Transform tra = Get(objType);
- if (tra == null)
- {
- GameObject go = Load<GameObject>(goName, folder, objType);
-
- go = Instantiate(go, pos, Quaternion.identity, par);
- go.name = go.name.Replace("(Clone)", "");
- if (compile)
- {
- Auxiliary.CompileDic(go.transform, TraDic);
- }
- if (objType != ObjType.Null)
- {
- ObjPoolDic.Add(go, objType);
- }
- if (type != null)
- {
- go.AddComponent(type);
- }
- return go.transform;
- }
- else
- {
- if (compile)
- {
- Auxiliary.CompileDic(tra, TraDic);
- }
- tra.SetParent(par);
- tra.position = pos;
- if (type != null)
- {
- if (tra.GetComponent(type) == null)
- {
- tra.AddComponent(type);
- }
- }
- return tra;
- }
- }
- public static Star GetStar()
- {
- int slotIndex = Random.Range(0, 9);
- bool forceLeft = slotIndex == 3 || slotIndex == 8;
- bool forceRight = slotIndex == 0 || slotIndex == 4;
- slotIndex += Garden.CurPage*9;
- Slot slot = ManaGarden.SlotList[slotIndex];
- Vector3 pos = slot.transform.position;
- pos.z = -0.35f + Random.Range(-0.01f, 0.01f);
- Transform tra = Get("Star", Folder.UI, false, null, pos, ObjType.Star);
- Star star = tra.GetComponent<Star>();
- tra.parent = slot.transform;
- if (star == null)
- {
- star = tra.AddComponent<Star>();
- star.Initialize(pos.y, forceLeft, forceRight);
- }
- else
- {
- star.Initialize(pos.y, forceLeft, forceRight);
- }
- return star;
- }
- public static Drop GetDrop(ObjType objType)
- {
- ManaAudio.PlayClip(Clip.DropClip);
- Vector3 leftPos = Get("MiniLeft").position;
- Vector3 rightPos;
- if (ManaMiniGame.GameA || ManaMiniGame.GameC)
- {
- rightPos = Get("MiniRight1").position;
- }
- else
- {
- rightPos = Get("MiniRight2").position;
- }
- Vector3 pos = Vector3.Lerp(leftPos, rightPos, Random.Range(0, 1f));
- Transform tra;
- if (objType == ObjType.DropGold)
- {
- tra = Get(objType.ToString(), Folder.UI, false, null, pos, objType, typeof(DropGold));
- }
- else if(objType == ObjType.DropDiamond)
- {
- tra = Get(objType.ToString(), Folder.UI, false, null, pos, objType, typeof(DropDiamond));
- }
- else
- {
- throw new Exception();
- }
- Drop drop = tra.GetComponent<Drop>();
- drop.RegistImmed();
- drop.ResetStatus();
- return drop;
- }
- public static Flower GetFlower(FlowerInfo flowerInfo, Slot slot, bool collider)
- {
- Transform tra = Get("Flower", Folder.Scene, false, slot.transform, false, ObjType.Flower, typeof(Flower));
- tra.localScale = new Vector3(1, 1, 1);
- Flower flower = tra.GetComponent<Flower>();
- flower.RegistImmed();
- flower.FlowerInfo = flowerInfo;
- flower.Slot = slot;
- flower.SetCollider(collider);
- return flower;
- }
- public static Flower GetFlower(FlowerInfo flowerInfo, Transform par)
- {
- Transform tra = Get("Flower", Folder.Scene, false, par, false, ObjType.Flower, typeof(Flower));
- tra.localScale = new Vector3(1, 1, 1);
- Flower flower = tra.GetComponent<Flower>();
- flower.RegistImmed();
- flower.FlowerInfo = flowerInfo;
- flower.SetCollider(false);
- return flower;
- }
- public static Text GetInfoItem()
- {
- Transform tra = Get("InfoItem", Folder.UI, false, Get("J_Info"), false, ObjType.InfoItem);
- tra.SetAsFirstSibling();
- Text text = tra.GetComponent<Text>();
- TweenRoot tween = text.CreateTweenGra(0, 1, 0.25f, true, true, Curve.EaseOutQuad);
- tween.OnBackwardFinish = () =>
- {
- Save(text);
- };
- return text;
- }
- public static HudText GetHudText(string str, Color color, int size, Transform posTra, Transform parTra, bool scene, float speed = 7.5f, float time = 0.5f, float stay = 0.5f)
- {
- Vector3 pos;
- if (scene)
- {
- pos = Camera.main.WorldToScreenPoint(posTra.position);
- }
- else
- {
- pos = posTra.position;
- }
- Transform tra = Get("HudText", Folder.UI, false, parTra, pos, ObjType.HudText, typeof(HudText));
- HudText hudText = tra.GetComponent<HudText>();
- hudText.Show(str, color, size, speed, time, stay);
- return hudText;
- }
- public static Transform GetElf(Flower flower, Vector4 offset, ElfType elfType)
- {
- Transform tra;
- Bounds bounds = flower.FlowerIcon.bounds;
- Vector3 pos = flower.FlowerIcon.transform.position;
- Transform par = flower.transform;
- ObjType obj = elfType.ToString().Split('_')[0].ToEnum<ObjType>();
- pos.z -= Random.Range(0.001f, 0.1f);
- tra = Get(obj.ToString(), Folder.Scene, false, par, pos, obj);
- Elf elf = tra.GetChild(0).GetComponent<Elf>();
- if (elf == null)
- {
- elf = tra.GetChild(0).AddScript<Elf>();
- }
- tra.GetComponentInChildren<SpriteRenderer>().sprite = LoadSprite(elfType.ToString(), Folder.Atlas2);
- if (Random.Range(0f, 1f) <= 0.5f)
- {
- tra.SetEY(180);
- }
- else
- {
- tra.SetEY(0);
- }
- float offsetX = Mathf.Lerp(offset.x*bounds.extents.x, offset.y*bounds.extents.x, Random.Range(0f, 1f));
- float offsetY = Mathf.Lerp(offset.z, offset.w*bounds.extents.y, Random.Range(0f, 1f));
- tra.position += new Vector3(offsetX, offsetY, 0);
- elf.Flower = flower;
- elf.Animator.SetTrigger("Play");
- return tra;
- }
- public static Transform GetSkillItem(SkillRoot skillRoot)
- {
- Transform tra;
- if (skillRoot.SkillTab == SkillTab.Elf)
- {
- tra = Get("SkillItem", Folder.UI, false, Get("Fd_Grid"), false, ObjType.SkillItem);
- }
- else if (skillRoot.SkillTab == SkillTab.Store)
- {
- tra = Get("SkillItem", Folder.UI, false, Get("Fc_Grid"), false, ObjType.SkillItem);
- }
- else if (skillRoot.SkillTab == SkillTab.Magic)
- {
- tra = Get("SkillItem", Folder.UI, false, Get("Fb_Grid"), false, ObjType.SkillItem);
- }
- else if (skillRoot.SkillTab == SkillTab.Garden)
- {
- tra = Get("SkillItem", Folder.UI, false, Get("Fa_Grid"), false, ObjType.SkillItem);
- }
- else
- {
- throw new Exception();
- }
- skillRoot.SkillItem = tra;
- return tra;
- }
- public static Transform GetAchieveItem()
- {
- Transform tra = Get("AchieveItem", Folder.UI, false, ManaReso.Get("M_Grid"), false, ObjType.AchieveItem);
- return tra;
- }
-
- public static ParticleSystem GetFirework(Vector3 pos)
- {
- Transform tra = Get("Firework", Folder.Effect, false, null, pos, ObjType.Firework, typeof(Effect));
- ParticleSystem particle = tra.GetComponent<ParticleSystem>();
- particle.Play();
- return particle;
- }
- public static ParticleSystem GetLightwall()
- {
- Transform tra = Get("LightwallUI", Folder.Effect, false, Get("Canvas"), false, ObjType.LightwallUI, typeof(Effect));
- ParticleSystem particle = tra.GetComponent<ParticleSystem>();
- if(particle != null)
- particle.Play();
- return particle;
- }
- public static void AsyncLoad<T>(string goName, Folder folder, UnityAction callback = null)
- {
- KV<AsyncRequest, UnityAction> kv = new KV<AsyncRequest, UnityAction>();
- AssetBundleRequest bundleRequest = Bundle.LoadAsync<T>(goName, folder);
-
- AsyncRequest asyncRequest = new AsyncRequest();
- asyncRequest.Request = bundleRequest;
- asyncRequest.Callback = callback;
- kv.Key = asyncRequest;
- kv.Value = () =>
- {
- ObjDic.UniqueAdd(goName, bundleRequest.asset);
- };
- RequestList.Add(bundleRequest);
- InstantiateList.Add(kv);
- }
- public static void AsyncLoad(string goName, int amt, Folder folder, ObjType objType, bool ui = false, bool canvas = false, UnityAction callback = null)
- {
- KV<AsyncRequest, UnityAction> kv = new KV<AsyncRequest, UnityAction>();
- AssetBundleRequest bundleRequest = Bundle.LoadAsync<object>(goName, folder);
-
- AsyncRequest asyncRequest = new AsyncRequest();
- asyncRequest.Request = bundleRequest;
- asyncRequest.Callback = callback;
- kv.Key = asyncRequest;
- kv.Value = () =>
- {
- ObjDic.UniqueAdd(goName, bundleRequest.asset);
- if (objType != ObjType.Null)
- {
- ObjectPool.UniqueAdd(objType, new List<Transform>());
- }
- GameObject go;
- if (ui)
- {
- go = (GameObject)Instantiate(bundleRequest.asset, GameObject.Find("ManagerGame").transform.GetChild(0).GetChild(0));
- }
- else
- {
- go = (GameObject)Instantiate(bundleRequest.asset);
- }
- ObjPoolDic.Add(go, objType);
- go.name = go.name.Replace("(Clone)", "");
- Save(go);
- if (ui)
- {
- go.SetParent(GameObject.Find("ManagerGame").transform.GetChild(0).GetChild(0));
- }
- };
- RequestList.Add(bundleRequest);
- for (int i = 0; i < amt; i++)
- {
- InstantiateList.Add(kv);
- }
- }
- public static void AddAsyncLoad<T>(string goName, Folder folder, UnityAction callback = null)
- {
- AsyncList.Add
- (
- () =>
- {
- AsyncLoad<T>(goName, folder, callback);
- }
- );
- }
- public static void AddAsyncLoad(string goName, int amt, Folder folder, ObjType objType, bool ui = false, bool canvas = false, UnityAction callback = null)
- {
- AsyncList.Add
- (
- () =>
- {
- AsyncLoad(goName, amt, folder, objType, ui, canvas, callback);
- }
- );
- }
- public static void AsyncLoadAtlas2()
- {
- KV<AsyncRequest, UnityAction> kv = new KV<AsyncRequest, UnityAction>();
- AssetBundleRequest bundleRequest = Bundle.LoadAllAsync<Sprite>(Folder.Atlas2);
- AsyncRequest asyncRequest = new AsyncRequest();
- asyncRequest.Request = bundleRequest;
- asyncRequest.Callback = null;
- kv.Key = asyncRequest;
- kv.Value = () =>
- {
- for (int i = 0; i < bundleRequest.allAssets.Length; i++)
- {
- Sprite sprite = (Sprite)bundleRequest.allAssets[i];
- ObjDic.UniqueAdd(sprite.name, sprite);
- }
- Bundle.Atlas2Complete = true;
- };
- RequestList.Add(bundleRequest);
- InstantiateList.Add(kv);
- }
- public static void AddAsyncLoadAtlas2()
- {
- AsyncList.Add
- (
- () =>
- {
- AsyncLoadAtlas2();
- }
- );
- }
- public void StopAsync()
- {
- StopCoroutine(CoroLoad);
- StopCoroutine(CoroInstantiate);
- }
- public static IEnumerator IAsyncLoad()
- {
- while (true)
- {
- if (RequestList.Count > 0)
- {
- yield return null;
- }
- else
- {
- if (AsyncList.Valid() && !AsyncLoadLock)
- {
- AsyncLoadLock = true;
- Auxiliary.Instance.DelayCall
- (
- () =>
- {
- AsyncLoadLock = false;
- AsyncList[0].SafeInvoke();
- AsyncList.RemoveAt(0);
- },
- 1
- );
- yield return null;
- }
- else
- {
- yield return null;
- }
- }
- }
- }
- public static IEnumerator IAsyncInstancitate()
- {
- while (true)
- {
- if (AsyncInstantiateLock)
- {
- yield return null;
- }
- if (!InstantiateList.Valid())
- {
- yield return null;
- }
- else
- {
- if (Time.deltaTime > 0.333f)
- {
- yield return null;
- }
- if (!InstantiateList[0].Key.Request.isDone)
- {
- yield return null;
- }
- else
- {
- InstantiateList[0].Key.Callback.SafeInvoke();
- RequestList.Remove(InstantiateList[0].Key.Request);
-
- UnityAction action = InstantiateList[0].Value;
- InstantiateList.RemoveAt(0);
- AsyncInstantiateLock = true;
- Auxiliary.Instance.DelayCall
- (
- () =>
- {
- if (!Logo.Complete)
- {
- action.SafeInvoke();
- AsyncInstantiateLock = false;
- }
- },
- 1
- );
- yield return null;
- }
- }
- }
- }
- }
|