From 24f59b89e9eabcfe948fc0ba304a8dbec2deda14 Mon Sep 17 00:00:00 2001 From: River Jiang <546213258@qq.com> Date: Tue, 27 Oct 2020 14:09:47 +0800 Subject: [PATCH] Merge branch 'master' of http://172.16.1.52:8090/r/GemBattle into master --- Assets/Scripts/TowerDefense/Level/EndlessWaveManager.cs | 52 ++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 46 insertions(+), 6 deletions(-) diff --git a/Assets/Scripts/TowerDefense/Level/EndlessWaveManager.cs b/Assets/Scripts/TowerDefense/Level/EndlessWaveManager.cs index 54c32b0..4ddc5cb 100644 --- a/Assets/Scripts/TowerDefense/Level/EndlessWaveManager.cs +++ b/Assets/Scripts/TowerDefense/Level/EndlessWaveManager.cs @@ -90,7 +90,9 @@ private string tunelMaterialPath = "UI/Endless/Tunel/tunel_"; - private void OnEnable() + private string faZhenPath = "UI/Endless/Tunel/EndlessFaZhen"; + + private void Start() { HideTunel(); } @@ -160,6 +162,16 @@ return waves[waveline].StartingNode.GetNextNode().transform.position; } + private void RefreshBoss() + { + if (CurrentWaveIndex > 0) + EndlessBossHPManager.instance.SwitchHP(CurrentWaveIndex == TotalWaves - 1); + EndlessBossHPManager.instance.SetBossInfo($"{waveData[0].Config.boss_name} Lv.{Level}"); + EndlessBossHPManager.instance.UpdateWave(TotalWaves - CurrentWaveIndex); + EndlessBossHPManager.instance.SetBossImage(waveData[0].Config.resource); + EndlessBossHPManager.instance.ShowHP(); + } + /// <summary> /// 更新波 /// </summary> @@ -180,14 +192,18 @@ { 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); } - if (CurrentWaveIndex > 0) - EndlessBossHPManager.instance.SwitchHP(CurrentWaveIndex == TotalWaves - 1); - EndlessBossHPManager.instance.SetBossInfo($"{waveData[0].Config.boss_name} Lv.{Level}"); - EndlessBossHPManager.instance.UpdateWave(TotalWaves - CurrentWaveIndex); - EndlessBossHPManager.instance.ShowHP(); + RefreshBoss(); TotalEnemies = EndlessPortData.GetWaveEnemiesCount(Level, CurrentWaveIndex); RemainEnemies = TotalEnemies; @@ -210,6 +226,30 @@ } /// <summary> + /// 暂停所有兵线出兵 + /// </summary> + public void PauseAllWave() + { + foreach (EndlessPortConfig data in waveData) + { + if (waves[data.Config.tunel - 1].LineState == EndlessWaveLineState.Spawning) + waves[data.Config.tunel - 1].PauseWave(); + } + } + + /// <summary> + /// 恢复所有兵线出兵 + /// </summary> + public void RestartAllWave() + { + foreach (EndlessPortConfig data in waveData) + { + if (waves[data.Config.tunel - 1].LineState == EndlessWaveLineState.Spawning) + waves[data.Config.tunel - 1].RestartWave(); + } + } + + /// <summary> /// 一波结束了 /// </summary> private void OneWaveCompleted() -- Gitblit v1.9.1