From 841b66ef416a727a0c798ad2263b098247cb4aa7 Mon Sep 17 00:00:00 2001 From: chenxin <chenxin6991@163.com> Date: Fri, 27 Nov 2020 12:00:16 +0800 Subject: [PATCH] buff预览暂停 --- Assets/Scripts/TowerDefense/UI/EndlessBuffSelect.cs | 57 ++++++++++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 48 insertions(+), 9 deletions(-) diff --git a/Assets/Scripts/TowerDefense/UI/EndlessBuffSelect.cs b/Assets/Scripts/TowerDefense/UI/EndlessBuffSelect.cs index 50cadb4..b036506 100644 --- a/Assets/Scripts/TowerDefense/UI/EndlessBuffSelect.cs +++ b/Assets/Scripts/TowerDefense/UI/EndlessBuffSelect.cs @@ -16,13 +16,6 @@ { public List<SelectBuffIcon> IconList; - private string iconPath = "UI/Endless/BuffIcon/BuffIcon_"; - - /// <summary> - /// buff是否选中完成 - /// </summary> - private bool isCompleted; - public event Action<int> BuffSelectCompleted; /// <summary> @@ -31,6 +24,12 @@ private int SelectedIndex = -1; public Button SelectBtn; + + public GameObject EffectPrefabObject; + + private GameObject effectObj; + + private Vector3[] effectPosArr = { new Vector3(-21.6f, 0, 6.6f), new Vector3(0, 0, 6.6f), new Vector3(21.6f, 0, 6.6f) }; // Start is called before the first frame update private void Start() @@ -45,13 +44,20 @@ private void OnEnable() { - isCompleted = false; SelectedIndex = -1; for (int i = 0; i < IconList.Count; ++i) { IconList[i].Reset(); } + + AudioSourceManager.Ins?.Play(AudioEnum.BuffAppear); + } + + private void OnDisable() + { + if (effectObj != null) + Destroy(effectObj); } public void OnClick(int index) @@ -65,6 +71,32 @@ SelectedIndex = index; IconList[index].SetState(true); + //PlayEffect(); + } + + + private void PlayEffect() + { + if (effectObj == null) + { + effectObj = Instantiate(EffectPrefabObject); + GameObject particleSystemObject = GameObject.Find("ParticleSystemObject"); + effectObj.transform.SetParent(particleSystemObject.transform, false); + effectObj.transform.localScale = new Vector3(1.5f, 1.5f, 1.5f); + } + effectObj.transform.localPosition = effectPosArr[SelectedIndex]; + ParticleSystem ps = effectObj.transform.GetChild(0).GetComponent<ParticleSystem>(); + ps.Play(); + } + + private void StopEffect() + { + if (effectObj != null) + { + ParticleSystem ps = effectObj.transform.GetChild(0).GetComponent<ParticleSystem>(); + ps.Stop(); + ps.Clear(); + } } /// <summary> @@ -74,19 +106,26 @@ { if (SelectedIndex == -1) return; + int index = SelectedIndex; + + AudioSourceManager.Ins.Play(AudioEnum.UI); + HideBuffUI(); if (BuffSelectCompleted != null) - BuffSelectCompleted(SelectedIndex); + BuffSelectCompleted(index); } public void ShowBuffUI() { + EndlessMaskUI.instance.Show(); gameObject.SetActive(true); } public void HideBuffUI() { + EndlessMaskUI.instance.Hide(); + StopEffect(); gameObject.SetActive(false); } -- Gitblit v1.9.1