From 9ed56dda66d5e8f6968730a46f908dfe1357c15e Mon Sep 17 00:00:00 2001
From: wangguan <wangguan@kt007.com>
Date: Mon, 16 Nov 2020 15:26:23 +0800
Subject: [PATCH] 修改法阵特效 修改loading适配

---
 Assets/Scripts/TowerDefense/Level/EndlessWaveManager.cs |  216 +++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 183 insertions(+), 33 deletions(-)

diff --git a/Assets/Scripts/TowerDefense/Level/EndlessWaveManager.cs b/Assets/Scripts/TowerDefense/Level/EndlessWaveManager.cs
index 9516ece..c07baf8 100644
--- a/Assets/Scripts/TowerDefense/Level/EndlessWaveManager.cs
+++ b/Assets/Scripts/TowerDefense/Level/EndlessWaveManager.cs
@@ -4,6 +4,8 @@
 using KTGMGemClient;
 using UnityEngine;
 using TowerDefense.UI.HUD;
+using Core.Utilities;
+using Core.Health;
 
 namespace TowerDefense.Level
 {
@@ -98,9 +100,31 @@
 
         private string faZhenPath = "UI/Endless/Tunel/EndlessFaZhen";
 
+        private Timer faZhenRefreshTimer;
+
+
+        /// <summary>
+        /// 管理法阵的对象池
+        /// </summary>
+        /// <returns></returns>
+        private Dictionary<string, List<GameObject>> faZhenDic = new Dictionary<string, List<GameObject>>();
         private void Start()
         {
+            faZhenDic = new Dictionary<string, List<GameObject>>();
             HideTunel();
+            EventCenter.Ins.Add<float>((int)KTGMGemClient.EventType.EndlessAgentTaskDamage, OnHit);
+            EventCenter.Ins.Add<int>((int)KTGMGemClient.EventType.WaveLineFinish, WaveLineFinish);
+
+        }
+
+        /// <summary>
+        /// Agent掉血,不管是中毒还是乱七八糟的掉血,只要掉血就会接收到
+        /// </summary>
+        /// <param name="value"></param>
+        private void OnHit(float value)
+        {
+            float nowHP = EndlessBossHPManager.instance.CurrentHP - value;
+            EndlessBossHPManager.instance.SetCurrentHP(nowHP);
         }
 
         /// <summary>
@@ -132,19 +156,143 @@
         /// 
         public virtual void StartWaves(int level)
         {
+            SummonFaZhen();
+        }
+
+        /// <summary>
+        /// 关卡开始时首先初始化关卡信息
+        /// </summary>
+        /// <param name="level"></param>
+        public void InitPort(int level)
+        {
+            EndlessBuffData.InitEndlessBuffPool(level);
+            InitPortData(level);
+            InitWaveData();
+            RefreshBoss();
+
+            if (!GameConfig.IsNewbie)
+            {
+                endless_boss bossData = EndlessBossData.GetDataById(waveData[0].Config.resource);
+
+                if (bossData != null)
+                    EndlessBossSkillManager.instance.Init(bossData.skill);
+            }
+        }
+
+        /// <summary>
+        /// 初始化关卡数据
+        /// </summary>
+        private void InitPortData(int level)
+        {
             Debug.Log($"--------------------- 开始第 {level} 关 ---------------------");
             Level = level;
             LevelData = EndlessPortData.GetLevelWaveData(level);
             TotalWaves = LevelData.Count;
             CurrentWaveIndex = 0;
-            EndlessBossHPManager.instance.InitHP();
+            EndlessBossHPManager.instance.Init();
             EndlessLevelManager.instance.DecrementEnemies -= DecrementEnemies;
             EndlessLevelManager.instance.DecrementEnemies += DecrementEnemies;
 
             if (LevelData.Count == 0)
                 throw new Exception($"当前关卡:{level}, 没有关卡数据");
+        }
 
-            UpdateWave();
+        /// <summary>
+        /// 召唤法阵
+        /// </summary>
+        private void SummonFaZhen()
+        {
+            EventCenter.Ins.Add((int)KTGMGemClient.EventType.EndlessBossSummonEnd, OnEndlessBossSummonEnd);
+            EndlessBossCtrl.instance.ChangeState(EndlessBossActionState.Summon);
+        }
+
+        /// <summary>
+        /// boss召唤动作结束
+        /// </summary>
+        private void OnEndlessBossSummonEnd()
+        {
+            EventCenter.Ins.Remove((int)KTGMGemClient.EventType.EndlessBossSummonEnd, OnEndlessBossSummonEnd);
+            HideTunel();
+            RefreshFaZhen();
+        }
+
+        /// <summary>
+        /// 刷新法阵显示
+        /// </summary>
+        private void RefreshFaZhen()
+        {
+            float time = 0;
+
+            // 刷新法阵的显示
+            for (int i = 0; i < waveData.Count; ++i)
+            {
+                int tunel = waveData[i].Config.tunel;
+                int tunelBgId = waveData[i].Config.tunel_bg;
+
+                // string key = $"{faZhenPath}{tunelBgId}{tunelBgId}";
+                // List<GameObject> allPS;
+                // GameObject tmpPSObj = null;
+                // if (faZhenDic.ContainsKey(key))
+                // {
+                //     allPS = faZhenDic[key];
+                //     foreach (GameObject item in allPS)
+                //     {
+                //         if (item.activeSelf)
+                //         {
+                //             tmpPSObj = item;
+                //             break;
+                //         }
+                //     }
+                // }
+
+                // if (tmpPSObj == null)
+                // {
+                //     allPS = new List<GameObject>();
+                //     GameObject obj = Resources.Load<GameObject>($"{faZhenPath}{tunelBgId}{tunelBgId}");
+                //     GameObject faZhen = Instantiate(obj);
+                //     tmpPSObj = faZhen;
+                //     allPS.Add(faZhen);
+                //     faZhenDic.Add(key, allPS);
+                // }
+
+                // tmpPSObj.transform.SetParent(TunelList[tunel - 1].gameObject.transform);
+                // tmpPSObj.transform.localPosition = new Vector3(0, 1, 0);
+                // tmpPSObj.transform.localScale = new Vector3(2, 2, 2);
+                // TunelList[tunel - 1].gameObject.SetActive(true);
+                TunelList[tunel - 1].material = Resources.Load<Material>($"{tunelMaterialPath}{tunelBgId}");
+                GameObject obj = Resources.Load<GameObject>($"{faZhenPath}{tunelBgId}{tunelBgId}");
+                GameObject faZhen = Instantiate(obj);
+
+                faZhen.transform.SetParent(TunelList[tunel - 1].gameObject.transform);
+                faZhen.transform.localPosition = new Vector3(0, 1, 0);
+                faZhen.transform.localScale = new Vector3(2, 2, 2);
+                TunelList[tunel - 1].gameObject.SetActive(true);
+
+                ParticleSystem ps = faZhen.transform.GetChild(0).GetComponent<ParticleSystem>();
+                ps.Play();
+                time = ps.main.duration * 3;
+                Destroy(faZhen, time);
+            }
+
+            if (faZhenRefreshTimer == null)
+                faZhenRefreshTimer = new Timer(time, UpdateWave);
+        }
+
+        /// <summary>
+        /// 延迟关闭法阵
+        /// </summary>
+        /// <param name="WaveLineId"></param>
+        private void WaveLineFinish(int WaveLineId)
+        {
+            //StartCoroutine(CloseFaZhen(WaveLineId));
+        }
+
+        IEnumerator CloseFaZhen(int WaveLineId)
+        {
+            yield return new WaitForSeconds(1.0f);
+            Debug.Log("当前列出怪完成,WaveLineId:" + WaveLineId);
+
+            TunelList[WaveLineId - 1].gameObject.SetActive(false);
         }
 
         /// <summary>
@@ -154,8 +302,6 @@
         public void DecrementEnemies(int count)
         {
             RemainEnemies -= count;
-            // 改变血条的进度
-            EndlessBossHPManager.instance.SetCurrentProgress(RemainEnemies * 1f / TotalEnemies);
         }
 
         /// <summary>
@@ -172,10 +318,24 @@
         {
             if (CurrentWaveIndex > 0 || TotalWaves == 1)
                 EndlessBossHPManager.instance.SwitchHP(CurrentWaveIndex == TotalWaves - 1);
-            EndlessBossHPManager.instance.SetBossInfo($"{waveData[0].Config.boss_name}  Lv.{Level}");
+            EndlessBossHPManager.instance.InitHP(EndlessPortData.GetWaveEnemiesTotalHP(Level, CurrentWaveIndex));
+            EndlessBossHPManager.instance.SetBossInfo($"第{Level}关 {waveData[0].Config.boss_name}");
             EndlessBossHPManager.instance.UpdateWave(TotalWaves - CurrentWaveIndex);
-            EndlessBossHPManager.instance.SetBossImage(waveData[0].Config.resource);
             EndlessBossHPManager.instance.ShowHP();
+            EndlessScoreManager.instance.ShowScore();
+        }
+
+        /// <summary>
+        /// 初始化波次数据
+        /// </summary>
+        private void InitWaveData()
+        {
+            waveData = LevelData[CurrentWaveIndex];
+            // 直接取第一条就行了
+            WaveInterval = waveData[0].Config.cooldown / 1000f;
+            TotalWaveLines = waveData.Count;
+            CompletedWaveLine = 0;
+            SpawnedTotalEnemies = 0;
         }
 
         /// <summary>
@@ -185,31 +345,6 @@
         {
             if (EndlessGameUI.instance.state == EndlessGameUI.State.GameOver) return;
 
-            waveData = LevelData[CurrentWaveIndex];
-            // 直接取第一条就行了
-            WaveInterval = waveData[0].Config.cooldown / 1000f;
-            TotalWaveLines = waveData.Count;
-            CompletedWaveLine = 0;
-            SpawnedTotalEnemies = 0;
-            HideTunel();
-
-            // 刷新法阵的显示
-            for (int i = 0; i < waveData.Count; ++i)
-            {
-                int tunel = waveData[i].Config.tunel;
-                TunelList[tunel - 1].material = Resources.Load<Material>($"{tunelMaterialPath}{tunel}");
-                GameObject obj = Resources.Load<GameObject>($"{faZhenPath}{tunel}");
-                GameObject faZhen = Instantiate(obj);
-                faZhen.transform.SetParent(TunelList[tunel - 1].gameObject.transform);
-                faZhen.transform.localPosition = new Vector3(0, 1, 0);
-                faZhen.transform.localScale = new Vector3(2, 2, 2);
-                TunelList[tunel - 1].gameObject.SetActive(true);
-                ParticleSystem ps = faZhen.transform.GetChild(0).GetComponent<ParticleSystem>();
-                ps.Play();
-                Destroy(ps.gameObject, ps.main.duration * 3);
-            }
-
-            RefreshBoss();
             TotalEnemies = EndlessPortData.GetWaveEnemiesCount(Level, CurrentWaveIndex);
             RemainEnemies = TotalEnemies;
 
@@ -231,7 +366,11 @@
             }
 
             if (TotalWaveLines != 0)
+            {
                 isWaveStarted = true;
+                EndlessBossSkillManager.instance.Restart();
+                EventCenter.Ins.BroadCast((int)KTGMGemClient.EventType.EndlessBeginWave);
+            }
         }
 
         /// <summary>
@@ -282,8 +421,15 @@
 
         public void Update()
         {
-            if (!isWaveStarted) return;
+            if (faZhenRefreshTimer != null)
+            {
+                if (faZhenRefreshTimer.Tick(Time.deltaTime))
+                    faZhenRefreshTimer = null;
+            }
 
+            if (!isWaveStarted || EndlessGameUI.instance.state == EndlessGameUI.State.GameOver) return;
+
+            // 所有赛道都完成
             if (CompletedWaveLine >= TotalWaveLines)
             {
                 // 判断所有敌人是否全部清除
@@ -299,6 +445,8 @@
                 // 更新波索引
                 ++CurrentWaveIndex;
                 EndlessBuffManager.instance.UpdateBuffList();
+                EndlessBossSkillManager.instance.Reset();
+                EventCenter.Ins.BroadCast((int)KTGMGemClient.EventType.EndlessCompletedPort, Level, CurrentWaveIndex);
 
                 if (CurrentWaveIndex >= TotalWaves)
                     // 当前关卡的所有波次全部完成
@@ -319,7 +467,9 @@
         private IEnumerator DelayToUpdateWave()
         {
             yield return new WaitForSeconds(WaveInterval);
-            UpdateWave();
+            InitWaveData();
+            RefreshBoss();
+            SummonFaZhen();
         }
 
         /// <summary>

--
Gitblit v1.9.1