From 74f26f60deac8fc1bb1f93ad26412f9a7e4a281d Mon Sep 17 00:00:00 2001
From: hch <305670599@qq.com>
Date: 星期日, 31 八月 2025 11:33:33 +0800
Subject: [PATCH] 50 【主界面】核心主体 - 战斗按钮逻辑

---
 Main/System/Main/MainWin.cs |  123 +++++++++++++++++++++++++++++++++++++++-
 1 files changed, 119 insertions(+), 4 deletions(-)

diff --git a/Main/System/Main/MainWin.cs b/Main/System/Main/MainWin.cs
index f88f5cd..1423613 100644
--- a/Main/System/Main/MainWin.cs
+++ b/Main/System/Main/MainWin.cs
@@ -15,12 +15,23 @@
     [SerializeField] Text powerText;
     [SerializeField] OfficialTitleCell officialRankText;
 
+    //鎴樻枟鎸夐挳
+    [SerializeField] Image fightOtherWinBG; //鍒囨崲鍏朵粬鐣岄潰鐨勬樉绀�
+    [SerializeField] Image fightOtherWinWarnImg; //鍒囨崲鍏朵粬鐣岄潰 濡傛灉鏄垬鏂椾腑娉涚孩鎻愮ず
+    [SerializeField] GameObject fightBG; //鎴樻枟鐣岄潰鏄剧ず
+    [SerializeField] Image restImg; //浼戞伅鐘舵��
+    [SerializeField] GameObject fightGo; //鎴樻枟鐘舵��
+    [SerializeField] Image fightHeroImg; //鎴樻枟鏄剧ず鑻遍泟
+    [SerializeField] UIEffectPlayer fightEffect;
+    [SerializeField] FillTween cdTween;
+
+
     public Text hammerText;
 
     protected override void InitComponent()
     {
         base.InitComponent();
-        
+
         avatarCell.button.AddListener(() => { });
 
     }
@@ -29,11 +40,13 @@
     {
         UpdateCurrency();
         UpdatePlayerInfo();
+        RefreshFightBtn();
     }
 
     protected override void OnPreOpen()
     {
         PlayerDatas.Instance.playerDataRefreshEvent += PlayerDataRefresh;
+        AutoFightModel.Instance.OnFightEvent += OnSkillCast;
         base.OnPreOpen();
 
         // 鍒锋柊UI
@@ -43,6 +56,7 @@
     protected override void OnPreClose()
     {
         PlayerDatas.Instance.playerDataRefreshEvent -= PlayerDataRefresh;
+        AutoFightModel.Instance.OnFightEvent -= OnSkillCast;
         base.OnPreClose();
     }
 
@@ -109,7 +123,7 @@
             case PlayerDataType.default26:
                 hammerText.text = UIHelper.GetMoneyCnt(41).ToString();
                 break;
-                
+
         }
 
     }
@@ -122,7 +136,7 @@
     {
         hammerText.text = UIHelper.GetMoneyCnt(41).ToString();
     }
-    
+
     /// <summary>
     /// 搴曢儴鏍囩鎸夐挳鐐瑰嚮
     /// </summary>
@@ -138,7 +152,7 @@
         }
         SelectBottomTab(index);
     }
-    
+
 
     /// <summary>
     /// 鏍规嵁鏍囩绱㈠紩鎵撳紑瀵瑰簲鐨勫瓙鐣岄潰
@@ -185,5 +199,106 @@
                 Debug.LogWarning("鏈煡鐨勬爣绛剧储寮�: " + functionOrder);
                 break;
         }
+
+        RefreshFightBtn();
+    }
+
+
+    ///鎴樻枟鎸夐挳鏄剧ず瑙勫垯
+    /// 1.鍦ㄤ富绾挎垬鏂楃晫闈笅锛�
+    ///     1.1.浼戞伅鐘舵�佺殑鎸夐挳
+    ///     1.2.鎴樻枟鐘舵�佺殑鎸夐挳 锛氭樉绀轰笅涓�涓鏀诲嚮鐨勬灏嗗ご鍍忥紝鎸変綅缃『搴忔帹绠楁樉绀哄ご鍍忥紱涓ヨ皑鎯呭喌涓嬮渶鍒ゆ柇涓嬩竴涓灏嗘槸鍚﹀彲鏀诲嚮濡傝鐪╂檿绛�
+    ///         鏈夎挋鐗堬細榛樿鏄剧ず鎾斁鍏朵粬鎴樻枟鐨勭姸鎬侊紝鐪╂檿鐨勭姸鎬佺瓑姣旇緝澶氾紙澶у鏄挋鐗堟樉绀虹殑鎯呭喌锛屾牴鎹疄闄呯湅鏄惁闇�瑕侊級
+    ///         鏃犺挋鐗堬細缁撴潫涓�涓皬閫氱煡鐨勬椂鍊欙紙B425锛夊彲浠ラ噴鏀剧殑鍘绘帀钂欑増锛涙湁鎬掓皵鐨勬椂鍊欐槸鍚︾壒娈婅〃鐜帮紙寰幆鐏壒鏁堬紵锛�
+    ///         杞湀锛氱偣鍑婚噴鏀� 鎾斁鐗规晥涓旇挋鐗堣浆鍦堬紝杞湀缁撴潫鍚庢樉绀鸿挋鐗� -- 鍚屾椂涓婃柟鍗$墝鎾斁鐗规晥鍜岃浆鍦堬紵
+    /// 2.鍦ㄩ潪涓荤嚎鎴樻枟鐣岄潰涓嬶細
+    ///     1. 浼戞伅鏄剧ず鍏抽棴鐘舵�� 鏃犵壒鏁�
+    ///     2. 鎴樻枟涓紝鏄剧ず娉涚孩鐗规晥
+    /// 涓婃柟鍗$墝 鏀诲嚮鏃舵挱鏀剧壒鏁堝拰杞湀锛屾湁鎬掓皵鐨勬椂鍊欐樉绀烘�掓皵鐗规晥锛�
+
+
+    void RefreshFightBtn()
+    {
+        if (functionOrder == 0)
+        {
+            //涓诲煄鐣岄潰
+            fightOtherWinBG.SetActive(false);
+            fightBG.SetActive(true);
+
+
+            if (BattleManager.Instance.storyBattleField != null &&
+            BattleManager.Instance.storyBattleField.GetBattleMode() == BattleMode.Stop)
+            {
+                fightGo.SetActive(false);
+                restImg.SetActive(true);
+            }
+            else
+            {
+                fightGo.SetActive(true);
+                restImg.SetActive(false);
+                RefreshFightIng();
+            }
+
+        }
+        else
+        {
+            //闈炰富鍩庣晫闈�
+            fightOtherWinBG.SetActive(true);
+            fightBG.SetActive(false);
+            if (BattleManager.Instance.storyBattleField != null &&
+            BattleManager.Instance.storyBattleField.GetBattleMode() == BattleMode.Stop)
+            {
+                fightOtherWinWarnImg.SetActive(false);
+            }
+            else
+            {
+                fightOtherWinWarnImg.SetActive(true);
+            }
+        }
+    }
+
+
+    void RefreshFightIng(bool isfighting = false)
+    {
+        if (isfighting)
+        {
+            // fightEffect.playDelayTime = 50;
+            fightEffect.Play();
+            cdTween.SetStartState();
+            cdTween.Play(()=>
+            { 
+                AutoFightModel.Instance.fightingHeroSkinID = TeamManager.Instance.GetTeam(TeamType.Story).GetNextServerHero(AutoFightModel.Instance.heroGuid).SkinID;
+                fightHeroImg.SetSprite(HeroSkinConfig.Get(AutoFightModel.Instance.fightingHeroSkinID).SquareIcon);
+            });
+        }
+        else
+        {
+            fightEffect.Stop();
+            cdTween.Stop();
+            cdTween.SetEndState();
+        }
+
+        if (AutoFightModel.Instance.fightingHeroSkinID == 0)
+        {
+            AutoFightModel.Instance.fightingHeroSkinID = TeamManager.Instance.GetTeam(TeamType.Story).GetNextServerHero(AutoFightModel.Instance.heroGuid).SkinID;
+        }
+
+        fightHeroImg.SetSprite(HeroSkinConfig.Get(AutoFightModel.Instance.fightingHeroSkinID).SquareIcon);
+    }
+
+    void OnSkillCast(bool isfighting)
+    {
+
+        if (functionOrder != 0)
+            return;
+
+        if (isfighting)
+        {
+            RefreshFightIng(isfighting);
+        }
+        else
+        {
+            RefreshFightBtn();
+        }
     }
 }
\ No newline at end of file

--
Gitblit v1.8.0