From a7956acb794f93fc01e16963efe1f38743b110f9 Mon Sep 17 00:00:00 2001
From: wangguan <wangguan@kt007.com>
Date: Thu, 12 Nov 2020 20:09:41 +0800
Subject: [PATCH] 修改购买宝石特效

---
 Assets/Scripts/Guide/GuidePanel.cs |  156 ++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 121 insertions(+), 35 deletions(-)

diff --git a/Assets/Scripts/Guide/GuidePanel.cs b/Assets/Scripts/Guide/GuidePanel.cs
index d5b1744..ee3dbad 100644
--- a/Assets/Scripts/Guide/GuidePanel.cs
+++ b/Assets/Scripts/Guide/GuidePanel.cs
@@ -3,7 +3,8 @@
 using UnityEngine;
 using UnityEngine.UI;
 using System;
-
+using KTGMGemClient;
+using DG.Tweening;
 /// <summary>
 /// 新手引导UI脚本
 /// </summary>
@@ -20,6 +21,7 @@
     private RectGuidance maskObj;
 
     private RectTransform image_Rim_Rect;//边框
+    private GameObject particle_1, particle_2;//使用粒子特效
     private RectTransform image_Tip_Rect;//可以移动的提示框
     private Text text_Tip;//可以移动的提示框文字
 
@@ -42,6 +44,7 @@
 
     Image backgroundImg;//用来接受空白点击事件的图片
 
+    RectTransform dragHandImg;//拖动标识手指
     /// <summary>
     /// 关闭所有UI
     /// </summary>
@@ -57,9 +60,10 @@
     void Awake()
     {
         tmpMask = GetComponent<Image>();
+        tmpMask.enabled = false;
         backgroundImg = transform.Find("Button").GetComponent<Image>();
-        backgroundImg.color = new Color(1.0f, 1.0f, 1.0f, 0);
-        towerBuyBtn = GameObject.Find("MainUI/TowerBuyBtn");
+
+        towerBuyBtn = GameObject.Find("BottomUI/TowerBuyBtn");
         tipsUI = transform.Find("Tips").gameObject;
         tipsUI.transform.SetAsLastSibling();//把tips放在最下面
 
@@ -79,6 +83,9 @@
         }
 
         image_Rim_Rect = transform.Find("Image_Rim").GetComponent<RectTransform>();
+        particle_1 = image_Rim_Rect.transform.Find("Particle System Small").gameObject;
+        particle_2 = image_Rim_Rect.transform.Find("Particle System Big").gameObject;
+
         image_Tip_Rect = transform.Find("Image_Tip").GetComponent<RectTransform>();
         text_Tip = image_Tip_Rect.transform.Find("Text").GetComponent<Text>();
         image_SkillRim = transform.Find("Image_SkillRim").GetComponent<Image>();
@@ -103,6 +110,9 @@
 
         skill = transform.Find("Image_Skill").GetComponent<ImageSkill>();
         skill.gameObject.SetActive(false);
+
+        dragHandImg = transform.Find("ImageHand").GetComponent<RectTransform>();
+        dragHandImg.gameObject.SetActive(false);
     }
 
     /// <summary>
@@ -111,8 +121,10 @@
     /// <param name="active"></param>
     public void SetGuideUI(bool active)
     {
-        if (backgroundImg.raycastTarget != active) backgroundImg.raycastTarget = active;
-        tipsUI.SetActive(active);
+        if (backgroundImg.enabled != active)
+            backgroundImg.enabled = active;
+        if (tipsUI.activeSelf != active)
+            tipsUI.SetActive(active);
     }
 
     //开始打印文字
@@ -143,9 +155,9 @@
             SetRimActive(true);
             AddButtonListener(towerBuyBtn, ac);
             Image btnImg = towerBuyBtn.GetComponent<Image>();
-            InitRectGuidance(btnImg);
+            InitRectGuidance(btnImg, 189, 73.5f);
             SetRimPos(towerBuyBtn);
-            maskObj.ShowImmediately();
+            //maskObj.ShowImmediately();
 
         }
         else if (currentIndex == 1)
@@ -165,12 +177,20 @@
             fire1.gameObject.SetActive(true);
             fire1.transform.Find("Image_2").gameObject.SetActive(false);
             fire1.enabled = false;
+
+            EventCenter.Ins.BroadCast((int)KTGMGemClient.EventType.PlayAppearEffect, fire1.transform.position);
         }
     }
     public void Step1_2()
     {
         fire2.gameObject.SetActive(true);
         fire2.enabled = false;
+        DestoryButtonListener(towerBuyBtn);
+        SetRimActive(false);
+        CloseMask();
+        EventCenter.Ins.BroadCast((int)KTGMGemClient.EventType.PlayAppearEffect, fire2.transform.position);
+
+        //RemoveButtonListener(towerBuyBtn);
     }
 
     /// <summary>
@@ -180,11 +200,7 @@
     public void Step2(int currentIndex)
     {
         backgroundImg.raycastTarget = true;
-
-        RemoveButtonListener(towerBuyBtn);
-
-        SetRimActive(false);
-        CloseMask();
+        //RemoveButtonListener(towerBuyBtn);
     }
 
     /// <summary>
@@ -194,13 +210,16 @@
     {
         if (currentIndex == 0)
         {
-            backgroundImg.raycastTarget = false;
-            backgroundImg.color = new Color(1.0f, 1.0f, 1.0f, 1.0f);
+
+            tmpMask.enabled = true;
+
             SetGuideUI(false);
 
             SetRimPos(fire2.gameObject);
             fire1.enabled = true;
             fire2.enabled = true;
+            image_Tip_Rect.gameObject.SetActive(false);
+            ShowDragPath(fire2.GetStartP, fire1.GetRect);
             StartCoroutine(ShowRimTip(str));
         }
     }
@@ -209,7 +228,7 @@
     public void Step3_2(string str)
     {
         SetRimPos(fire1.gameObject);
-        StartCoroutine(ShowRimTip(str));
+        //StartCoroutine(ShowRimTip(str));
     }
 
     /// <summary>
@@ -219,18 +238,22 @@
     {
         if (currentIndex == 0)
         {
+            tmpMask.enabled = false;
+
             SetRimActive(true);
             Image btnImg = transform.Find("Image_TowerPos").GetComponent<Image>();
             towerPos.enabled = true;
-            InitRectGuidance(btnImg);
+            InitRectGuidance(btnImg, 75, 80);
             SetRimPos(btnImg.gameObject);
-            maskObj.ShowImmediately();
+            //maskObj.ShowImmediately();
+            ShowDragPath(fire1.GetStartP, btnImg.rectTransform);
             StartCoroutine(ShowRimTip(str));
+
         }
     }
 
     /// <summary>
-    /// 第六步,拖动造塔
+    /// 第六步
     /// </summary>
     public void Step5(int currentIndex, string str)
     {
@@ -238,7 +261,7 @@
         {
             CloseMask();
             SetRimActive(false);
-            backgroundImg.color = new Color(1.0f, 1.0f, 1.0f, 0);
+
         }
     }
 
@@ -254,9 +277,10 @@
             GameObject go = transform.Find("Image_TowerPos2").gameObject;
 
             Image btnImg = go.GetComponent<Image>();
-            InitRectGuidance(btnImg);
+            btnImg.raycastTarget = false;
+            InitRectGuidance(btnImg, 75, 80);
             SetRimPos(go);
-            maskObj.ShowImmediately();
+            //maskObj.ShowImmediately();
             StartCoroutine(ShowRimTip(str));
         }
     }
@@ -264,7 +288,6 @@
     //介绍水元素
     public void Step8()
     {
-        backgroundImg.color = new Color(1.0f, 1.0f, 1.0f, 0);
         SetGuideUI(true);
         SetRimActive(false);
         CloseMask();
@@ -280,32 +303,37 @@
     {
         if (currentIndex == 0)
         {
+
             SetRimActive(true);
+
+            image_Tip_Rect.gameObject.SetActive(false);
             //设置位置
             AddButtonListener(towerBuyBtn, ac);
 
             Image btnImg = towerBuyBtn.GetComponent<Image>();
-            InitRectGuidance(btnImg);
+            InitRectGuidance(btnImg, 189, 73.5f);
             SetRimPos(towerBuyBtn);
-            maskObj.ShowImmediately();
+            //maskObj.ShowImmediately();
         }
         else if (currentIndex == 1)
         {
             GameObject go = transform.Find("Image_TowerPos2").gameObject;
             Image btnImg = go.GetComponent<Image>();
-            InitRectGuidance(btnImg);
+            btnImg.raycastTarget = true;
+            InitRectGuidance(btnImg, 75, 80);
             SetRimPos(go);
-            maskObj.ShowImmediately();
+            //maskObj.ShowImmediately();
+            ShowDragPath(water1.GetStartP, btnImg.rectTransform);
         }
 
-        StartCoroutine(ShowRimTip(str));
+        //StartCoroutine(ShowRimTip(str));
     }
 
     public void Step9_1()
     {
-        RemoveButtonListener(towerBuyBtn);
         water1.gameObject.SetActive(true);
         towerPos2.enabled = true;
+        DestoryButtonListener(towerBuyBtn);
     }
 
 
@@ -326,25 +354,41 @@
     {
         if (currentIndex == 0)
         {
+            tmpMask.enabled = true;
+            tmpMask.color = new Color(1.0f, 1.0f, 1.0f, 0);
             SetGuideUI(false);
             SetRimActive(true);
             SetRimPos(skill.gameObject);
-            StartCoroutine(ShowRimTip(str));
+            image_Tip_Rect.gameObject.SetActive(false);
+            //StartCoroutine(ShowRimTip(str));
+
+            ShowDragPath(skill.GetStartP, image_SkillRim.rectTransform);
+
+            InitRectGuidance(image_SkillRim, 79, 265);
+
         }
         else if (currentIndex == 1)
         {
-            SetRimPos(image_SkillRim.gameObject);
-            StartCoroutine(ShowRimTip(str));
+            SetRimActive(false);
+            //SetRimPos(image_SkillRim.gameObject);
+            //StartCoroutine(ShowRimTip(str));
         }
     }
 
+    public void SkillRelease()
+    {
+        StopShowDragPath(true);
+        CloseMask();
+        image_SkillRim.gameObject.SetActive(false);
+        tmpMask.enabled = false;
+        SetRimActive(false);
+    }
 
     public void Step12()
     {
-        image_SkillRim.gameObject.SetActive(false);
+
 
         SetGuideUI(true);
-        SetRimActive(false);
     }
 
     #region 按钮以及提示
@@ -368,6 +412,17 @@
         RectTransform rt = target.GetComponent<RectTransform>();
         image_Rim_Rect.anchoredPosition = rt.anchoredPosition;
         image_Rim_Rect.sizeDelta = (rt.sizeDelta * rt.localScale) + rimOffset;
+        if (image_Rim_Rect.sizeDelta.x > 200)
+        {
+            particle_1.SetActive(false);
+            particle_2.SetActive(true);
+        }
+        else
+        {
+            particle_1.SetActive(true);
+            particle_2.SetActive(false);
+        }
+
         if (changeTipPos)
             image_Tip_Rect.anchoredPosition = new Vector2(image_Rim_Rect.anchoredPosition.x, image_Rim_Rect.anchoredPosition.y + 74 / 2 + image_Rim_Rect.sizeDelta.y / 2);
 
@@ -399,13 +454,16 @@
     /// 抠出来一个区域
     /// </summary>
     /// <param name="target"></param>
-    void InitRectGuidance(Image target)
+    void InitRectGuidance(Image target, float x, float y)
     {
         if (!maskObj.gameObject.activeSelf)
         {
             maskObj.gameObject.SetActive(true);
         }
-        maskObj.Init(target);
+        //maskObj.Init(target);
+        //maskObj.ShowImmediately();
+        maskObj.InitForCamera(target, x, y);
+
     }
 
     /// <summary>
@@ -439,7 +497,35 @@
         eventTriggerListener.RemoveListener(go);
     }
 
+    private void DestoryButtonListener(GameObject go)
+    {
+        EventTriggerListener eventTriggerListener = EventTriggerListener.GetListener(go);
+
+        if (eventTriggerListener != null)
+            Destroy(eventTriggerListener);
+    }
+
     #endregion
 
+    #region 拖动效果
+    private void ShowDragPath(Vector2 startP, RectTransform endP)
+    {
+        if (!dragHandImg.gameObject.activeSelf)
+        {
+            dragHandImg.gameObject.SetActive(true);
+            dragHandImg.anchoredPosition = startP;
+            dragHandImg.DOMove(endP.position, 1).SetEase(Ease.InCubic).SetLoops(-1);
+        }
+    }
+
+    public void StopShowDragPath(bool isClose)
+    {
+        dragHandImg.DOKill();
+        if (isClose)
+            dragHandImg.gameObject.SetActive(false);
+    }
+
+
+    #endregion
 
 }

--
Gitblit v1.9.1