浏览代码

Merge remote-tracking branch 'remotes/origin/master' into ios_test

hexiaojie 11 月之前
父节点
当前提交
ddf3a18ec9
共有 24 个文件被更改,包括 477 次插入63 次删除
  1. 二进制
      GameClient/.idea/.idea.GameClient/.idea/copilot/chatSessions/00000000000.xd
  2. 二进制
      GameClient/.idea/.idea.GameClient/.idea/copilot/chatSessions/blobs/version
  3. 78 0
      GameClient/.idea/.idea.GameClient/.idea/copilot/chatSessions/xd.lck
  4. 2 0
      GameClient/Assets/Game/HotUpdate/Data/FieldWorkDataManager.cs
  5. 3 0
      GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/Arena/UI_ArenaDressInfoUI.cs
  6. 71 0
      GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/FieldWork/UI_Component1.cs
  7. 11 0
      GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/FieldWork/UI_Component1.cs.meta
  8. 71 0
      GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/FieldWork/UI_Component2.cs
  9. 11 0
      GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/FieldWork/UI_Component2.cs.meta
  10. 10 3
      GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/FieldWork/UI_FieldWorkLevelInfoUI.cs
  11. 4 0
      GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/FieldWork/UI_FieldWorkRoundResultUI.cs
  12. 42 15
      GameClient/Assets/Game/HotUpdate/ServerProxy/FieldWorkSproxy.cs
  13. 20 2
      GameClient/Assets/Game/HotUpdate/Views/Arena/ArenaDressInfoView.cs
  14. 1 1
      GameClient/Assets/Game/HotUpdate/Views/DressUp/ArenaDressUpFightView.cs
  15. 26 1
      GameClient/Assets/Game/HotUpdate/Views/FieldWork/FieldWorkDressFIghtView.cs
  16. 9 8
      GameClient/Assets/Game/HotUpdate/Views/FieldWork/FieldWorkLevelInfoView.cs
  17. 81 22
      GameClient/Assets/Game/HotUpdate/Views/FieldWork/FieldWorkLevelView.cs
  18. 19 2
      GameClient/Assets/Game/HotUpdate/Views/FieldWork/FieldWorkRoundResultView.cs
  19. 5 5
      GameClient/Assets/Game/HotUpdate/Views/InstanceZones/InstanceZonesView.cs
  20. 9 3
      GameClient/Assets/Game/HotUpdate/Views/MainStory/StoryCardChoose.cs
  21. 4 1
      GameClient/Assets/Game/HotUpdate/Views/MainStory/StoryFightSingleScoreView.cs
  22. 二进制
      GameClient/Assets/ResIn/UI/Arena/Arena_fui.bytes
  23. 二进制
      GameClient/Assets/ResIn/UI/FieldWork/FieldWork_fui.bytes
  24. 二进制
      GameClient/Assets/ResIn/UI/Main/Main_fui.bytes

二进制
GameClient/.idea/.idea.GameClient/.idea/copilot/chatSessions/00000000000.xd


二进制
GameClient/.idea/.idea.GameClient/.idea/copilot/chatSessions/blobs/version


+ 78 - 0
GameClient/.idea/.idea.GameClient/.idea/copilot/chatSessions/xd.lck

@@ -0,0 +1,78 @@
+Private property of Exodus: 32556@DESKTOP-8ILLQSI
+
+jetbrains.exodus.io.LockingManager.lock(LockingManager.kt:88)
+jetbrains.exodus.io.LockingManager.lock(LockingManager.kt:39)
+jetbrains.exodus.io.FileDataWriter.lock(FileDataWriter.kt:70)
+jetbrains.exodus.log.Log.tryLock(Log.kt:804)
+jetbrains.exodus.log.Log.<init>(Log.kt:117)
+jetbrains.exodus.env.Environments.newLogInstance(Environments.kt:117)
+jetbrains.exodus.env.Environments.newLogInstance(Environments.kt:81)
+jetbrains.exodus.env.Environments.newLogInstance(Environments.kt:77)
+jetbrains.exodus.env.Environments$newInstance$4.invoke(Environments.kt:46)
+jetbrains.exodus.env.Environments$newInstance$4.invoke(Environments.kt:46)
+jetbrains.exodus.env.Environments.prepare(Environments.kt:120)
+jetbrains.exodus.env.Environments.newInstance(Environments.kt:46)
+kotlinx.dnq.store.container.EntityStoreHelperKt.createTransientEntityStore(EntityStoreHelper.kt:40)
+kotlinx.dnq.store.container.EntityStoreHelperKt.createTransientEntityStore(EntityStoreHelper.kt:31)
+kotlinx.dnq.store.container.EntityStoreHelperKt.createTransientEntityStore$default(EntityStoreHelper.kt:30)
+com.github.copilot.chat.session.persistence.xodus.XdChatSessionPersistenceService.initStore(XdChatSessionPersistenceService.kt:115)
+com.github.copilot.chat.session.persistence.xodus.XdChatSessionPersistenceService.<init>(XdChatSessionPersistenceService.kt:22)
+com.github.copilot.chat.session.persistence.xodus.XdChatSessionPersistenceService.<init>(XdChatSessionPersistenceService.kt:15)
+com.github.copilot.chat.session.persistence.ChatSessionPersistenceServiceKt.ChatSessionPersistenceService(ChatSessionPersistenceService.kt:43)
+com.github.copilot.chat.session.persistence.ChatSessionPersistenceServiceKt.chatSessionsPersistenceService(ChatSessionPersistenceService.kt:53)
+com.github.copilot.chat.session.ChatSessionManager.<init>(ChatSessionManager.kt:45)
+com.github.copilot.chat.session.ChatSessionManager.<init>(ChatSessionManager.kt:25)
+com.github.copilot.chat.window.CopilotChatToolWindow.onCopilotReady(CopilotChatToolWindow.kt:133)
+com.github.copilot.chat.window.CopilotChatToolWindow.access$onCopilotReady(CopilotChatToolWindow.kt:40)
+com.github.copilot.chat.window.CopilotChatToolWindow$initCopilotStatusListener$1.invoke(CopilotChatToolWindow.kt:118)
+com.github.copilot.chat.window.CopilotChatToolWindow$initCopilotStatusListener$1.invoke(CopilotChatToolWindow.kt:115)
+com.github.copilot.status.CopilotAuthStatusKt.subscribeToCopilotAuthStatus(CopilotAuthStatus.kt:27)
+com.github.copilot.chat.window.CopilotChatToolWindow.initCopilotStatusListener(CopilotChatToolWindow.kt:115)
+com.github.copilot.chat.window.CopilotChatToolWindow.<init>(CopilotChatToolWindow.kt:59)
+com.github.copilot.chat.window.CopilotChatToolWindow.<init>(CopilotChatToolWindow.kt:40)
+com.github.copilot.chat.window.CopilotChatToolWindowFactory.init(CopilotChatToolWindowFactory.kt:18)
+com.intellij.openapi.wm.impl.ToolWindowManagerImpl.registerToolWindow$intellij_platform_ide_impl(ToolWindowManagerImpl.kt:1083)
+com.intellij.toolWindow.ToolWindowSetInitializerKt.registerToolWindows(ToolWindowSetInitializer.kt:181)
+com.intellij.toolWindow.ToolWindowSetInitializerKt.access$registerToolWindows(ToolWindowSetInitializer.kt:1)
+com.intellij.toolWindow.ToolWindowSetInitializer$createAndLayoutToolWindows$entries$1$1.invoke(ToolWindowSetInitializer.kt:129)
+com.intellij.toolWindow.ToolWindowSetInitializer$createAndLayoutToolWindows$entries$1$1.invoke(ToolWindowSetInitializer.kt:121)
+com.intellij.openapi.progress.CoroutinesKt.blockingContext(coroutines.kt:248)
+com.intellij.openapi.progress.CoroutinesKt.blockingContext(coroutines.kt:199)
+com.intellij.toolWindow.ToolWindowSetInitializer$createAndLayoutToolWindows$entries$1.invokeSuspend(ToolWindowSetInitializer.kt:121)
+kotlin.coroutines.jvm.internal.BaseContinuationImpl.resumeWith(ContinuationImpl.kt:33)
+kotlinx.coroutines.DispatchedTask.run(DispatchedTask.kt:106)
+com.intellij.openapi.application.TransactionGuardImpl$1.run(TransactionGuardImpl.java:193)
+com.intellij.openapi.application.impl.ApplicationImpl.runIntendedWriteActionOnCurrentThread(ApplicationImpl.java:861)
+com.intellij.openapi.application.impl.ApplicationImpl$4.run(ApplicationImpl.java:478)
+com.intellij.openapi.application.impl.FlushQueue.doRun(FlushQueue.java:79)
+com.intellij.openapi.application.impl.FlushQueue.runNextEvent(FlushQueue.java:121)
+com.intellij.openapi.application.impl.FlushQueue.flushNow(FlushQueue.java:41)
+java.desktop/java.awt.event.InvocationEvent.dispatch(InvocationEvent.java:318)
+java.desktop/java.awt.EventQueue.dispatchEventImpl(EventQueue.java:789)
+java.desktop/java.awt.EventQueue$3.run(EventQueue.java:740)
+java.desktop/java.awt.EventQueue$3.run(EventQueue.java:734)
+java.base/java.security.AccessController.doPrivileged(AccessController.java:399)
+java.base/java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:86)
+java.desktop/java.awt.EventQueue.dispatchEvent(EventQueue.java:759)
+com.intellij.ide.IdeEventQueue.defaultDispatchEvent(IdeEventQueue.kt:685)
+com.intellij.ide.IdeEventQueue._dispatchEvent$lambda$10(IdeEventQueue.kt:589)
+com.intellij.openapi.application.impl.ApplicationImpl.runWithoutImplicitRead(ApplicationImpl.java:1485)
+com.intellij.ide.IdeEventQueue._dispatchEvent(IdeEventQueue.kt:589)
+com.intellij.ide.IdeEventQueue.access$_dispatchEvent(IdeEventQueue.kt:67)
+com.intellij.ide.IdeEventQueue$dispatchEvent$processEventRunnable$1$1$1.compute(IdeEventQueue.kt:369)
+com.intellij.ide.IdeEventQueue$dispatchEvent$processEventRunnable$1$1$1.compute(IdeEventQueue.kt:368)
+com.intellij.openapi.progress.impl.CoreProgressManager.computePrioritized(CoreProgressManager.java:787)
+com.intellij.ide.IdeEventQueue$dispatchEvent$processEventRunnable$1$1.invoke(IdeEventQueue.kt:368)
+com.intellij.ide.IdeEventQueue$dispatchEvent$processEventRunnable$1$1.invoke(IdeEventQueue.kt:363)
+com.intellij.ide.IdeEventQueueKt.performActivity$lambda$1(IdeEventQueue.kt:992)
+com.intellij.openapi.application.TransactionGuardImpl.performActivity(TransactionGuardImpl.java:105)
+com.intellij.ide.IdeEventQueueKt.performActivity(IdeEventQueue.kt:992)
+com.intellij.ide.IdeEventQueue.dispatchEvent$lambda$7(IdeEventQueue.kt:363)
+com.intellij.openapi.application.impl.ApplicationImpl.runIntendedWriteActionOnCurrentThread(ApplicationImpl.java:861)
+com.intellij.ide.IdeEventQueue.dispatchEvent(IdeEventQueue.kt:405)
+java.desktop/java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:207)
+java.desktop/java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:128)
+java.desktop/java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:117)
+java.desktop/java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:113)
+java.desktop/java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:105)
+java.desktop/java.awt.EventDispatchThread.run(EventDispatchThread.java:92)

+ 2 - 0
GameClient/Assets/Game/HotUpdate/Data/FieldWorkDataManager.cs

@@ -44,6 +44,8 @@ namespace GFGGame
         public int currentLevelID = 0;
         public int currentLevelID = 0;
         public List<string> nameList = new List<string>() 
         public List<string> nameList = new List<string>() 
         {"壹","贰","叄","肆","伍","陆","柒","捌","玖","拾","拾壹","终"};
         {"壹","贰","叄","肆","伍","陆","柒","捌","玖","拾","拾壹","终"};
+        public int guideLevelID = 100005009;
+        public int MaxLevelId = 0;
         /// <summary>
         /// <summary>
         /// 更新战斗结算总分,含胜负
         /// 更新战斗结算总分,含胜负
         /// </summary>
         /// </summary>

+ 3 - 0
GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/Arena/UI_ArenaDressInfoUI.cs

@@ -24,6 +24,7 @@ namespace UI.Arena
         public UI_BtnTab3 m_btn2;
         public UI_BtnTab3 m_btn2;
         public GButton m_btnDress;
         public GButton m_btnDress;
         public GButton m_btnRecommend;
         public GButton m_btnRecommend;
+        public GButton m_btnConfire;
         public const string URL = "ui://4lc5fhlbpsph1";
         public const string URL = "ui://4lc5fhlbpsph1";
         public const string PACKAGE_NAME = "Arena";
         public const string PACKAGE_NAME = "Arena";
         public const string RES_NAME = "ArenaDressInfoUI";
         public const string RES_NAME = "ArenaDressInfoUI";
@@ -88,6 +89,7 @@ namespace UI.Arena
             m_btn2 = (UI_BtnTab3)UI_BtnTab3.Create(comp.GetChild("btn2"));
             m_btn2 = (UI_BtnTab3)UI_BtnTab3.Create(comp.GetChild("btn2"));
             m_btnDress = (GButton)comp.GetChild("btnDress");
             m_btnDress = (GButton)comp.GetChild("btnDress");
             m_btnRecommend = (GButton)comp.GetChild("btnRecommend");
             m_btnRecommend = (GButton)comp.GetChild("btnRecommend");
+            m_btnConfire = (GButton)comp.GetChild("btnConfire");
         }
         }
         public void Dispose(bool disposeTarget = false)
         public void Dispose(bool disposeTarget = false)
         {
         {
@@ -114,6 +116,7 @@ namespace UI.Arena
             m_btn2 = null;
             m_btn2 = null;
             m_btnDress = null;
             m_btnDress = null;
             m_btnRecommend = null;
             m_btnRecommend = null;
+            m_btnConfire = null;
             if(disposeTarget && target != null)
             if(disposeTarget && target != null)
             {
             {
                 target.RemoveFromParent();
                 target.RemoveFromParent();

+ 71 - 0
GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/FieldWork/UI_Component1.cs

@@ -0,0 +1,71 @@
+/** This is an automatically generated class by FairyGUI. Please do not modify it. **/
+
+using FairyGUI;
+
+namespace UI.FieldWork
+{
+    public partial class UI_Component1
+    {
+        public GComponent target;
+        public GLoader m_guideTarget;
+        public const string URL = "ui://efym480mbc2226";
+        public const string PACKAGE_NAME = "FieldWork";
+        public const string RES_NAME = "Component1";
+        private static UI_Component1 _proxy;
+
+        public static UI_Component1 Create(GObject gObject = null)
+        {
+            var ui = new UI_Component1();
+            if(gObject == null)
+            	ui.target =  (GComponent)UIPackage.CreateObject(PACKAGE_NAME, RES_NAME);
+            else
+            	ui.target =  (GComponent)gObject;
+            ui.Init(ui.target);
+            return ui;
+        }
+
+        public static UI_Component1 Proxy(GObject gObject = null)
+        {
+            if(_proxy == null)
+            {
+                _proxy = new UI_Component1();
+            }
+            var ui = _proxy;
+            if(gObject == null)
+            	ui.target =  (GComponent)UIPackage.CreateObject(PACKAGE_NAME, RES_NAME);
+            else
+            	ui.target =  (GComponent)gObject;
+            ui.Init(ui.target);
+            return ui;
+        }
+
+        public static void ProxyEnd()
+        {
+            if (_proxy != null)
+            {
+                _proxy.Dispose();
+            }
+        }
+
+        public static void ClearProxy()
+        {
+            ProxyEnd();
+            _proxy = null;
+        }
+
+        private void Init(GComponent comp)
+        {
+            m_guideTarget = (GLoader)comp.GetChild("guideTarget");
+        }
+        public void Dispose(bool disposeTarget = false)
+        {
+            m_guideTarget = null;
+            if(disposeTarget && target != null)
+            {
+                target.RemoveFromParent();
+                target.Dispose();
+            }
+            target = null;
+        }
+    }
+}

+ 11 - 0
GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/FieldWork/UI_Component1.cs.meta

@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: 16c7add426c3a4c4da0e6244b4556f3e
+MonoImporter:
+  externalObjects: {}
+  serializedVersion: 2
+  defaultReferences: []
+  executionOrder: 0
+  icon: {instanceID: 0}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 

+ 71 - 0
GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/FieldWork/UI_Component2.cs

@@ -0,0 +1,71 @@
+/** This is an automatically generated class by FairyGUI. Please do not modify it. **/
+
+using FairyGUI;
+
+namespace UI.FieldWork
+{
+    public partial class UI_Component2
+    {
+        public GComponent target;
+        public GLoader m_guide;
+        public const string URL = "ui://efym480mbc2227";
+        public const string PACKAGE_NAME = "FieldWork";
+        public const string RES_NAME = "Component2";
+        private static UI_Component2 _proxy;
+
+        public static UI_Component2 Create(GObject gObject = null)
+        {
+            var ui = new UI_Component2();
+            if(gObject == null)
+            	ui.target =  (GComponent)UIPackage.CreateObject(PACKAGE_NAME, RES_NAME);
+            else
+            	ui.target =  (GComponent)gObject;
+            ui.Init(ui.target);
+            return ui;
+        }
+
+        public static UI_Component2 Proxy(GObject gObject = null)
+        {
+            if(_proxy == null)
+            {
+                _proxy = new UI_Component2();
+            }
+            var ui = _proxy;
+            if(gObject == null)
+            	ui.target =  (GComponent)UIPackage.CreateObject(PACKAGE_NAME, RES_NAME);
+            else
+            	ui.target =  (GComponent)gObject;
+            ui.Init(ui.target);
+            return ui;
+        }
+
+        public static void ProxyEnd()
+        {
+            if (_proxy != null)
+            {
+                _proxy.Dispose();
+            }
+        }
+
+        public static void ClearProxy()
+        {
+            ProxyEnd();
+            _proxy = null;
+        }
+
+        private void Init(GComponent comp)
+        {
+            m_guide = (GLoader)comp.GetChild("guide");
+        }
+        public void Dispose(bool disposeTarget = false)
+        {
+            m_guide = null;
+            if(disposeTarget && target != null)
+            {
+                target.RemoveFromParent();
+                target.Dispose();
+            }
+            target = null;
+        }
+    }
+}

+ 11 - 0
GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/FieldWork/UI_Component2.cs.meta

@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: d335c03b09d6c994e8519abf23c671af
+MonoImporter:
+  externalObjects: {}
+  serializedVersion: 2
+  defaultReferences: []
+  executionOrder: 0
+  icon: {instanceID: 0}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 

+ 10 - 3
GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/FieldWork/UI_FieldWorkLevelInfoUI.cs

@@ -11,8 +11,10 @@ namespace UI.FieldWork
         public GLoader m_loaderHead;
         public GLoader m_loaderHead;
         public GTextField m_txtTargetName;
         public GTextField m_txtTargetName;
         public GTextField m_txtTitle;
         public GTextField m_txtTitle;
-        public GTextField m_txtHighestScore;
+        public GTextField m_targetScore;
         public GLoader m_scoreType;
         public GLoader m_scoreType;
+        public GTextField m_txtHighestScore;
+        public UI_Component1 m_guideTarget;
         public GList m_listBonus;
         public GList m_listBonus;
         public GButton m_btnStart;
         public GButton m_btnStart;
         public UI_Button1 m_btnSkip;
         public UI_Button1 m_btnSkip;
@@ -68,8 +70,10 @@ namespace UI.FieldWork
             m_loaderHead = (GLoader)comp.GetChild("loaderHead");
             m_loaderHead = (GLoader)comp.GetChild("loaderHead");
             m_txtTargetName = (GTextField)comp.GetChild("txtTargetName");
             m_txtTargetName = (GTextField)comp.GetChild("txtTargetName");
             m_txtTitle = (GTextField)comp.GetChild("txtTitle");
             m_txtTitle = (GTextField)comp.GetChild("txtTitle");
-            m_txtHighestScore = (GTextField)comp.GetChild("txtHighestScore");
+            m_targetScore = (GTextField)comp.GetChild("targetScore");
             m_scoreType = (GLoader)comp.GetChild("scoreType");
             m_scoreType = (GLoader)comp.GetChild("scoreType");
+            m_txtHighestScore = (GTextField)comp.GetChild("txtHighestScore");
+            m_guideTarget = (UI_Component1)UI_Component1.Create(comp.GetChild("guideTarget"));
             m_listBonus = (GList)comp.GetChild("listBonus");
             m_listBonus = (GList)comp.GetChild("listBonus");
             m_btnStart = (GButton)comp.GetChild("btnStart");
             m_btnStart = (GButton)comp.GetChild("btnStart");
             m_btnSkip = (UI_Button1)UI_Button1.Create(comp.GetChild("btnSkip"));
             m_btnSkip = (UI_Button1)UI_Button1.Create(comp.GetChild("btnSkip"));
@@ -81,8 +85,11 @@ namespace UI.FieldWork
             m_loaderHead = null;
             m_loaderHead = null;
             m_txtTargetName = null;
             m_txtTargetName = null;
             m_txtTitle = null;
             m_txtTitle = null;
-            m_txtHighestScore = null;
+            m_targetScore = null;
             m_scoreType = null;
             m_scoreType = null;
+            m_txtHighestScore = null;
+            m_guideTarget.Dispose();
+            m_guideTarget = null;
             m_listBonus = null;
             m_listBonus = null;
             m_btnStart = null;
             m_btnStart = null;
             m_btnSkip.Dispose();
             m_btnSkip.Dispose();

+ 4 - 0
GameClient/Assets/Game/HotUpdate/FairyGUI/GenCode/FieldWork/UI_FieldWorkRoundResultUI.cs

@@ -10,6 +10,7 @@ namespace UI.FieldWork
         public UI_ComAllScoreResult m_ComResult;
         public UI_ComAllScoreResult m_ComResult;
         public GList m_list;
         public GList m_list;
         public GLoader m_loaResule;
         public GLoader m_loaResule;
+        public UI_Component2 m_guide;
         public const string URL = "ui://efym480mo8tww";
         public const string URL = "ui://efym480mo8tww";
         public const string PACKAGE_NAME = "FieldWork";
         public const string PACKAGE_NAME = "FieldWork";
         public const string RES_NAME = "FieldWorkRoundResultUI";
         public const string RES_NAME = "FieldWorkRoundResultUI";
@@ -60,6 +61,7 @@ namespace UI.FieldWork
             m_ComResult = (UI_ComAllScoreResult)UI_ComAllScoreResult.Create(comp.GetChild("ComResult"));
             m_ComResult = (UI_ComAllScoreResult)UI_ComAllScoreResult.Create(comp.GetChild("ComResult"));
             m_list = (GList)comp.GetChild("list");
             m_list = (GList)comp.GetChild("list");
             m_loaResule = (GLoader)comp.GetChild("loaResule");
             m_loaResule = (GLoader)comp.GetChild("loaResule");
+            m_guide = (UI_Component2)UI_Component2.Create(comp.GetChild("guide"));
         }
         }
         public void Dispose(bool disposeTarget = false)
         public void Dispose(bool disposeTarget = false)
         {
         {
@@ -67,6 +69,8 @@ namespace UI.FieldWork
             m_ComResult = null;
             m_ComResult = null;
             m_list = null;
             m_list = null;
             m_loaResule = null;
             m_loaResule = null;
+            m_guide.Dispose();
+            m_guide = null;
             if(disposeTarget && target != null)
             if(disposeTarget && target != null)
             {
             {
                 target.RemoveFromParent();
                 target.RemoveFromParent();

+ 42 - 15
GameClient/Assets/Game/HotUpdate/ServerProxy/FieldWorkSproxy.cs

@@ -22,6 +22,7 @@ namespace GFGGame
             {
             {
                 if (response.Error == ErrorCode.ERR_Success)
                 if (response.Error == ErrorCode.ERR_Success)
                 {
                 {
+                    FieldWorkDataManager.Instance.MaxLevelId = response.MaxLevelId;
                     FieldWorkDataManager.Instance.Tag = response.WeekTags ;
                     FieldWorkDataManager.Instance.Tag = response.WeekTags ;
                     FieldWorkDataManager.Instance.DressupList.Clear();
                     FieldWorkDataManager.Instance.DressupList.Clear();
                     FieldWorkDataManager.Instance.HistoryDressupList = response.WeekUserItems;
                     FieldWorkDataManager.Instance.HistoryDressupList = response.WeekUserItems;
@@ -110,6 +111,7 @@ namespace GFGGame
             {
             {
                 if (response.Error == ErrorCode.ERR_Success)
                 if (response.Error == ErrorCode.ERR_Success)
                 {
                 {
+                    FieldWorkDataManager.Instance.MaxLevelId = response.MaxLevelId;
                     FieldWorkDataManager.Instance.HistoryDressupList = response.WeekUserItems;
                     FieldWorkDataManager.Instance.HistoryDressupList = response.WeekUserItems;
                     FieldWorkDataManager.Instance.CardAbrasionInfoList = response.CardAbrasionInfoList;
                     FieldWorkDataManager.Instance.CardAbrasionInfoList = response.CardAbrasionInfoList;
                     if(response.CimbingTowerLevelInfo.IsPass)
                     if(response.CimbingTowerLevelInfo.IsPass)
@@ -120,7 +122,7 @@ namespace GFGGame
                         }
                         }
                         else
                         else
                         {
                         {
-                            PromptController.Instance.ShowFloatTextPrompt("已通过,自动清除服装,保留卡牌!");
+                            PromptController.Instance.ShowFloatTextPrompt("已通过,自动清除搭配!");
                             FieldWorkDataManager.Instance.CimbingTowerLevelInfoList.Add(response.CimbingTowerLevelInfo.LevelId, response.CimbingTowerLevelInfo);
                             FieldWorkDataManager.Instance.CimbingTowerLevelInfoList.Add(response.CimbingTowerLevelInfo.LevelId, response.CimbingTowerLevelInfo);
                         }
                         }
 
 
@@ -129,28 +131,47 @@ namespace GFGGame
                        for(int i=0;i<FieldWorkDataManager.Instance.DressupList.Count;i++)
                        for(int i=0;i<FieldWorkDataManager.Instance.DressupList.Count;i++)
                        {
                        {
                             FieldWorkDataManager.Instance.DressupList[i].itemList.Clear();
                             FieldWorkDataManager.Instance.DressupList[i].itemList.Clear();
-                            foreach(var item in FieldWorkDataManager.Instance.CardAbrasionInfoList)
+                            FieldWorkDataManager.Instance.DressupList[i].cardId = 0;
+                            isDelete = true;                        
+                       }
+                        FieldWorkDataManager.Instance.BonusList = response.BonusList;
+                        EventAgent.DispatchEvent(ConstMessage.FieldWork_StateCHANGE);
+                        return true;
+                    }
+                    else
+                    {
+                        if(response.CimbingTowerLevelInfo != null)
+                        {
+                            if (FieldWorkDataManager.Instance.CimbingTowerLevelInfoList.ContainsKey(response.CimbingTowerLevelInfo.LevelId))
+                            {
+                                FieldWorkDataManager.Instance.CimbingTowerLevelInfoList[response.CimbingTowerLevelInfo.LevelId] = response.CimbingTowerLevelInfo;
+                            }
+                            else
+                            {
+                                FieldWorkDataManager.Instance.CimbingTowerLevelInfoList.Add(response.CimbingTowerLevelInfo.LevelId, response.CimbingTowerLevelInfo);
+                            }
+                        }
+                        int limit = CimbingTowerCfgArray.Instance.dataArray[0].UseLimit;
+                        bool isDelete = false;
+                        for (int i = 0; i < FieldWorkDataManager.Instance.DressupList.Count; i++)
+                        {
+                            foreach (var item in FieldWorkDataManager.Instance.CardAbrasionInfoList)
                             {
                             {
-                                if(item.Card == FieldWorkDataManager.Instance.DressupList[i].cardId)
+                                if (item.Card == FieldWorkDataManager.Instance.DressupList[i].cardId)
                                 {
                                 {
-                                    if(item.UseNum >= limit)
+                                    if (item.UseNum >= limit)
                                     {
                                     {
                                         FieldWorkDataManager.Instance.DressupList[i].cardId = 0;
                                         FieldWorkDataManager.Instance.DressupList[i].cardId = 0;
                                         isDelete = true;
                                         isDelete = true;
                                     }
                                     }
                                 }
                                 }
-                            }                          
-                       }
-                       if(isDelete)
-                       {
+                            }
+                        }
+                        if (isDelete)
+                        {
                             PromptController.Instance.ShowFloatTextPrompt("词牌磨损率过高已自动解除佩戴!");
                             PromptController.Instance.ShowFloatTextPrompt("词牌磨损率过高已自动解除佩戴!");
-                       }
-                        FieldWorkDataManager.Instance.BonusList = response.BonusList;
-                        EventAgent.DispatchEvent(ConstMessage.FieldWork_StateCHANGE);
-                        return true;
-                    }
-                    else
-                    {
+                            EventAgent.DispatchEvent(ConstMessage.FieldWork_StateCHANGE);
+                        }
                         return false;
                         return false;
                     }
                     }
                 }
                 }
@@ -166,6 +187,7 @@ namespace GFGGame
             {
             {
                 if (response.Error == ErrorCode.ERR_Success)
                 if (response.Error == ErrorCode.ERR_Success)
                 {
                 {
+                    FieldWorkDataManager.Instance.MaxLevelId = response.MaxLevelId;
                     FieldWorkDataManager.Instance.CimbingTowerLevelInfoList.Clear();
                     FieldWorkDataManager.Instance.CimbingTowerLevelInfoList.Clear();
                     foreach (var item in response.CimbingTowerLevelInfoList)
                     foreach (var item in response.CimbingTowerLevelInfoList)
                     {
                     {
@@ -207,6 +229,11 @@ namespace GFGGame
                             FieldWorkDataManager.Instance.CimbingTowerLevelInfoList.Add(item.LevelId, item);
                             FieldWorkDataManager.Instance.CimbingTowerLevelInfoList.Add(item.LevelId, item);
                         }
                         }
                     }
                     }
+                    for (int i = 0; i < FieldWorkDataManager.Instance.DressupList.Count; i++)
+                    {
+                        FieldWorkDataManager.Instance.DressupList[i].itemList.Clear();
+                        FieldWorkDataManager.Instance.DressupList[i].cardId = 0;
+                    }
                     EventAgent.DispatchEvent(ConstMessage.FieldWork_StateCHANGE);
                     EventAgent.DispatchEvent(ConstMessage.FieldWork_StateCHANGE);
                     return true;
                     return true;
                 }
                 }

+ 20 - 2
GameClient/Assets/Game/HotUpdate/Views/Arena/ArenaDressInfoView.cs

@@ -55,6 +55,7 @@ namespace GFGGame
 
 
             _ui.m_c2.onChanged.Add(OnThemeChange);
             _ui.m_c2.onChanged.Add(OnThemeChange);
             _ui.m_btnBack.onClick.Add(OnClickBtnBack);
             _ui.m_btnBack.onClick.Add(OnClickBtnBack);
+            _ui.m_btnConfire.onClick.Add(OnClickConfire);
             _ui.m_btnDress.onClick.Add(OnBtnDressClick);
             _ui.m_btnDress.onClick.Add(OnBtnDressClick);
             _ui.m_btnRecommend.onClick.Add(OnBtnRecommendClick);
             _ui.m_btnRecommend.onClick.Add(OnBtnRecommendClick);
             _ui.m_comValueInfo.m_btnFightScoreRule.onClick.Add(OnBtnFightScoreRule);
             _ui.m_comValueInfo.m_btnFightScoreRule.onClick.Add(OnBtnFightScoreRule);
@@ -113,6 +114,10 @@ namespace GFGGame
         {
         {
             //ViewManager.GoBackFrom(typeof(ArenaDressInfoView).FullName); //返回竞技场主界面
             //ViewManager.GoBackFrom(typeof(ArenaDressInfoView).FullName); //返回竞技场主界面
             this.Hide();
             this.Hide();
+            if (_roleType == FightRoleType.FieldWork)
+            {
+                ViewManager.Show<FieldWorkLevelInfoView>(new object[] { FieldWorkDataManager.Instance.currentLevelID });
+            }           
             //this.OnHide();
             //this.OnHide();
             //ViewManager.Show<ArenaView>(null, new object[] { typeof(MainUIView).FullName, this.viewData });
             //ViewManager.Show<ArenaView>(null, new object[] { typeof(MainUIView).FullName, this.viewData });
             //if (!string.IsNullOrEmpty(_openViewName))
             //if (!string.IsNullOrEmpty(_openViewName))
@@ -120,7 +125,14 @@ namespace GFGGame
             //    ViewManager.Show(_openViewName); //打开来源界面:如历史记录、排行榜
             //    ViewManager.Show(_openViewName); //打开来源界面:如历史记录、排行榜
             //}
             //}
         }
         }
-
+        private void OnClickConfire()
+        {
+            ViewManager.GoBackFrom(typeof(ArenaDressInfoView).FullName);
+            if (_roleType == FightRoleType.FieldWork)
+            {
+                ViewManager.Show<FieldWorkLevelInfoView>(new object[] { FieldWorkDataManager.Instance.currentLevelID });
+            }
+        }
         private void OnThemeChange()
         private void OnThemeChange()
         {
         {
             _themeIndex = _ui.m_c2.selectedIndex;
             _themeIndex = _ui.m_c2.selectedIndex;
@@ -315,7 +327,8 @@ namespace GFGGame
 
 
         private void CheckGuide(object param)
         private void CheckGuide(object param)
         {
         {
-            if (GuideDataManager.IsGuideFinish(ConstGuideId.ARENA_OPEN) <= 0)
+            if (GuideDataManager.IsGuideFinish(ConstGuideId.ARENA_OPEN) <= 0
+                ||(GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0 && InstanceZonesDataManager.FightScene == ConstInstanceZonesType.FieldWork && InstanceZonesDataManager.CheckLevelPass(FieldWorkDataManager.Instance.guideLevelID)))
             {
             {
                 UpdateToCheckGuide(null);
                 UpdateToCheckGuide(null);
             }
             }
@@ -331,6 +344,11 @@ namespace GFGGame
 
 
             GuideController.TryGuide(_ui.m_btnRecommend, ConstGuideId.ARENA_OPEN, 6, "");
             GuideController.TryGuide(_ui.m_btnRecommend, ConstGuideId.ARENA_OPEN, 6, "");
             GuideController.TryGuide(_ui.m_btnBack, ConstGuideId.ARENA_OPEN, 7, "搭配好啦,挑个对手比拼吧~");
             GuideController.TryGuide(_ui.m_btnBack, ConstGuideId.ARENA_OPEN, 7, "搭配好啦,挑个对手比拼吧~");
+            if((GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0 && InstanceZonesDataManager.FightScene == ConstInstanceZonesType.FieldWork))
+            {
+                GuideController.TryGuide(_ui.m_btnDress, ConstGuideId.FIELD, 6, "三套战斗方案可自由搭配且在同一关卡中服装可重复使用,让我们前往搭配吧!");
+                GuideController.TryGuide(_ui.m_btnBack, ConstGuideId.FIELD, 12, "返回!");
+            }
         }
         }
 
 
         protected override void TryCompleteGuide()
         protected override void TryCompleteGuide()

+ 1 - 1
GameClient/Assets/Game/HotUpdate/Views/DressUp/ArenaDressUpFightView.cs

@@ -160,6 +160,7 @@ namespace GFGGame
             SendLog();
             SendLog();
 
 
             cardId = _roleData.cardId;
             cardId = _roleData.cardId;
+
         }
         }
 
 
         protected override void OnHide()
         protected override void OnHide()
@@ -1000,6 +1001,5 @@ namespace GFGGame
         {
         {
 
 
         }
         }
-
     }
     }
 }
 }

+ 26 - 1
GameClient/Assets/Game/HotUpdate/Views/FieldWork/FieldWorkDressFIghtView.cs

@@ -160,6 +160,8 @@ namespace GFGGame
             SendLog();
             SendLog();
 
 
             cardId = _roleData.cardId;
             cardId = _roleData.cardId;
+
+            Timers.inst.AddUpdate(CheckGuide);
         }
         }
 
 
         protected override void OnHide()
         protected override void OnHide()
@@ -520,7 +522,7 @@ namespace GFGGame
             else
             else
             {
             {
                 List<long> fightScoreDatas = ArenaDataManager.Instance.GetFightScoreList(ArenaDataManager.Instance.DressupList);
                 List<long> fightScoreDatas = ArenaDataManager.Instance.GetFightScoreList(ArenaDataManager.Instance.DressupList);
-                bool result = await ArenaSproxy.ReqChangeArenaDressup(_dataManager.SelectThemeIndex, 0, MyDressUpHelper.dressUpObj.itemList, fightScoreDatas);
+                bool result = await FieldWorkSproxy.ReqChangeFieldWorkDressupOne(_dataManager.SelectThemeIndex, 0, MyDressUpHelper.dressUpObj.itemList);
                 if (result)
                 if (result)
                 {
                 {
                     _itemList = new List<int>(MyDressUpHelper.dressUpObj.itemList);
                     _itemList = new List<int>(MyDressUpHelper.dressUpObj.itemList);
@@ -1069,6 +1071,29 @@ namespace GFGGame
         {
         {
 
 
         }
         }
+        private void CheckGuide(object param)
+        {
+            if ((GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0
+                && InstanceZonesDataManager.FightScene == ConstInstanceZonesType.FieldWork
+                && InstanceZonesDataManager.CheckLevelPass(FieldWorkDataManager.Instance.guideLevelID)))
+            {
+                UpdateToCheckGuide(null);
+            }
+            else
+            {
+                Timers.inst.Remove(CheckGuide);
+            }
+        }
 
 
+        protected override void UpdateToCheckGuide(object param)
+        {
+            if (!ViewManager.CheckIsTopView(this.viewCom)) return;
+            if ((GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0 && InstanceZonesDataManager.FightScene == ConstInstanceZonesType.FieldWork))
+            {
+                GuideController.TryGuide(_ui.m_comListType1.m_listType, ConstGuideId.FIELD, 7, "选择服装进行战斗吧!", 1);
+                GuideController.TryGuide(_ui.m_partsList.m_list, ConstGuideId.FIELD, 8, "选择服装进行战斗吧!", 0);
+                GuideController.TryGuide(_ui.m_btnNext, ConstGuideId.FIELD, 9, "下一步!");
+            }
+        }
     }
     }
 }
 }

+ 9 - 8
GameClient/Assets/Game/HotUpdate/Views/FieldWork/FieldWorkLevelInfoView.cs

@@ -49,6 +49,7 @@ namespace GFGGame
             FieldWorkDataManager.Instance.SetDataScoreType();
             FieldWorkDataManager.Instance.SetDataScoreType();
             InstanceZonesDataManager.FightScene = ConstInstanceZonesType.FieldWork;
             InstanceZonesDataManager.FightScene = ConstInstanceZonesType.FieldWork;
             FieldWorkDataManager.Instance.CurFightIndex = 0;
             FieldWorkDataManager.Instance.CurFightIndex = 0;
+            FieldWorkDataManager.Instance.currentLevelID = _levelID;
             UpDressdate();
             UpDressdate();
             UpdateView();
             UpdateView();
             Timers.inst.AddUpdate(CheckGuide);
             Timers.inst.AddUpdate(CheckGuide);
@@ -75,6 +76,8 @@ namespace GFGGame
             _ui.m_loaderHead.url = ResPathUtil.GetNpcHeadPath("self");
             _ui.m_loaderHead.url = ResPathUtil.GetNpcHeadPath("self");
             _ui.m_txtHighestScore.text = FieldWorkDataManager.Instance.GetHeihtScore(_levelID);
             _ui.m_txtHighestScore.text = FieldWorkDataManager.Instance.GetHeihtScore(_levelID);
             _ui.m_txtTitle.text = levelCfg.name;
             _ui.m_txtTitle.text = levelCfg.name;
+            _ui.m_scoreType.url = "ui://CommonGame/kp_sx_" + levelCfg.scoreType;
+            _ui.m_targetScore.text = levelCfg.ClearanceScore.ToString();
             _ui.m_cardList.numItems = 3;
             _ui.m_cardList.numItems = 3;
             //只有首通奖励
             //只有首通奖励
             bool once = true;
             bool once = true;
@@ -144,7 +147,7 @@ namespace GFGGame
             {
             {
                 item.m_c1.selectedIndex = 1;
                 item.m_c1.selectedIndex = 1;
                 ItemCfg itemCfg = ItemCfgArray.Instance.GetCfg(cardId);
                 ItemCfg itemCfg = ItemCfgArray.Instance.GetCfg(cardId);
-                item.m_txtCardName.text = itemCfg.name;
+                item.m_txtCardName.text = "我的搭配";
                 item.m_comCard.m_loaCard.url = ResPathUtil.GetCardIconPath(itemCfg.res);
                 item.m_comCard.m_loaCard.url = ResPathUtil.GetCardIconPath(itemCfg.res);
                 item.m_loaScore.url = ResPathUtil.GetScorePath(itemCfg.mainScore);
                 item.m_loaScore.url = ResPathUtil.GetScorePath(itemCfg.mainScore);
                 RarityIconController.UpdateRarityIcon(item.m_loaRarity, cardId, false);
                 RarityIconController.UpdateRarityIcon(item.m_loaRarity, cardId, false);
@@ -160,10 +163,6 @@ namespace GFGGame
         }
         }
         private void OnClickCardList(EventContext context)
         private void OnClickCardList(EventContext context)
         {
         {
-            if (GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0)
-            {
-                return;
-            }
             GObject obj = context.sender as GObject;
             GObject obj = context.sender as GObject;
             int index = (int)obj.data;
             int index = (int)obj.data;
             FieldWorkDataManager.Instance.SelectThemeIndex = index;
             FieldWorkDataManager.Instance.SelectThemeIndex = index;
@@ -172,8 +171,8 @@ namespace GFGGame
         }
         }
         private void OnClickBtnStart()
         private void OnClickBtnStart()
         {
         {
-            //判断是否搭配了三套衣服和词牌
             FieldWorkDataManager.Instance.currentLevelID = _levelID;
             FieldWorkDataManager.Instance.currentLevelID = _levelID;
+            //判断是否搭配了三套衣服和词牌
             if (FieldWorkDataManager.Instance.SetCanStart())
             if (FieldWorkDataManager.Instance.SetCanStart())
             {
             {
                 UpDressdate();
                 UpDressdate();
@@ -197,6 +196,7 @@ namespace GFGGame
             {
             {
                 FieldWorkDataManager.Instance.myScore.Clear();
                 FieldWorkDataManager.Instance.myScore.Clear();
                 FieldWorkDataManager.Instance.GetFightResult();
                 FieldWorkDataManager.Instance.GetFightResult();
+                this.Hide();
                 ViewManager.Show<FieldWorkRoundResultView>();
                 ViewManager.Show<FieldWorkRoundResultView>();
             }
             }
             else
             else
@@ -218,8 +218,9 @@ namespace GFGGame
         protected override void UpdateToCheckGuide(object param)
         protected override void UpdateToCheckGuide(object param)
         {
         {
             if (!ViewManager.CheckIsTopView(this.viewCom)) return;
             if (!ViewManager.CheckIsTopView(this.viewCom)) return;
-            GuideController.TryGuide(_ui.m_cardList, ConstGuideId.FIELD, 4, "点击选择搭配!挑战成功的衣服本周不可使用!",0);
-            GuideController.TryCompleteGuide(ConstGuideId.FIELD, 4);
+            GuideController.TryGuide(_ui.m_guideTarget.target, ConstGuideId.FIELD, 4, "在这里可以看见过关要求!");
+            GuideController.TryGuide(_ui.m_cardList, ConstGuideId.FIELD, 5, "搭配多套服装和词牌可以得到更高的分数!", 0);
+            GuideController.TryGuide(_ui.m_btnStart, ConstGuideId.FIELD, 13, "开始挑战!");
         }
         }
     }
     }
 }
 }

+ 81 - 22
GameClient/Assets/Game/HotUpdate/Views/FieldWork/FieldWorkLevelView.cs

@@ -79,10 +79,7 @@ namespace GFGGame
             yield return new WaitForSeconds(0.1f);
             yield return new WaitForSeconds(0.1f);
             if (gamey != null)
             if (gamey != null)
             {
             {
-                int levelCount = CimbingTowerLevelCfgArray.Instance.dataArray.Length - FieldWorkDataManager.Instance.CimbingTowerLevelInfoList.Count;
-                indexY = 212.0f * Mathf.Max(0, (float)levelCount);
-                _ui.m_chapter.m_compChapterScroll.target.y = 0;
-                gamey.transform.position = new Vector3(0, indexY, 0);
+                //gamey.transform.position = new Vector3(0, indexY, 0);
             }
             }
         }
         }
 
 
@@ -113,8 +110,20 @@ namespace GFGGame
                 levelItem.target.onClick.Add(OnClickLevelItem);
                 levelItem.target.onClick.Add(OnClickLevelItem);
                 UI_CompStoryLevelItem.ProxyEnd();
                 UI_CompStoryLevelItem.ProxyEnd();
             }
             }
-            Timers.inst.StartCoroutine(InitChapter());
-            _ui.m_chapter.m_compChapterScroll.target.y = 1;
+            //Timers.inst.StartCoroutine(InitChapter());
+            int isPassCount = 0;
+            foreach(var item in FieldWorkDataManager.Instance.CimbingTowerLevelInfoList)
+            {
+                if(item.Value.IsPass)
+                {
+                    isPassCount++;
+                }
+            }
+            int levelCount = CimbingTowerLevelCfgArray.Instance.dataArray.Length - isPassCount;
+            float height = _ui.m_chapter.target.height;
+            float value = 300 / (_ui.m_chapter.target.height / 1080.0f);
+            indexY = value * Mathf.Max(0, (float)levelCount);
+            _ui.m_chapter.target.scrollPane.posY = indexY;
         }
         }
         private void OnClickLevelItem(EventContext context)
         private void OnClickLevelItem(EventContext context)
         {
         {
@@ -125,6 +134,17 @@ namespace GFGGame
                 PromptController.Instance.ShowFloatTextPrompt("请通过前置关卡");
                 PromptController.Instance.ShowFloatTextPrompt("请通过前置关卡");
                 return;
                 return;
             }
             }
+            else
+            {
+                if(FieldWorkDataManager.Instance.CimbingTowerLevelInfoList.ContainsKey(levelCfgId))
+                {
+                    if(FieldWorkDataManager.Instance.CimbingTowerLevelInfoList[levelCfgId].IsPass)
+                    {
+                        PromptController.Instance.ShowFloatTextPrompt("关卡已通过!");
+                        return;
+                    }
+                }
+            }
             UI_CompStoryLevelItem.ProxyEnd();
             UI_CompStoryLevelItem.ProxyEnd();
             ViewManager.Show<FieldWorkLevelInfoView>(new object[] { levelCfgId });
             ViewManager.Show<FieldWorkLevelInfoView>(new object[] { levelCfgId });
         }
         }
@@ -156,34 +176,71 @@ namespace GFGGame
         {
         {
             ViewManager.Show<StoreView>(new object[] { ConstStoreTabId.STORE_EXCHANGE, 3 });
             ViewManager.Show<StoreView>(new object[] { ConstStoreTabId.STORE_EXCHANGE, 3 });
         }
         }
-        private async void OnClickBtnReSet()
+        private void OnClickBtnReSet()
         {
         {
             if (GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0)
             if (GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0)
             {
             {
                 return;
                 return;
             }
             }
-            bool result = await FieldWorkSproxy.ReqFieldWorkReset();
-            if (result)
-            {
-                UpdateLevel();
-                PromptController.Instance.ShowFloatTextPrompt("重置成功!");
-            }
-            else
+            if (FieldWorkDataManager.Instance.CimbingTowerLevelInfoList.Count == 0)
             {
             {
-                PromptController.Instance.ShowFloatTextPrompt("没有重置次数!");
+                PromptController.Instance.ShowFloatTextPrompt("本周暂未参与该玩法,无法使用此功能!");
+                return;
             }
             }
+                AlertUI.Show("重置后当前关卡进度将被清空,每周可使用一次,是否重置?")
+                .SetLeftButton(true, "否").SetRightButton(true, "是", async (object data) =>
+                {
+                    bool result = await FieldWorkSproxy.ReqFieldWorkReset();
+                    if (result)
+                    {
+                        UpdateLevel();
+                        PromptController.Instance.ShowFloatTextPrompt("重置成功!");
+                    }
+                    else
+                    {
+                        //PromptController.Instance.ShowFloatTextPrompt("没有重置次数!");
+                    }
+                });
         }
         }
-        private async void OnClickBtnSkip()
+        private void OnClickBtnSkip()
         {
         {
-            bool result = await FieldWorkSproxy.ReqFieldWorkOneClickPass();
-            if (result)
+            int normal = CimbingTowerCfgArray.Instance.dataArray[0].ClearanceLimit;
+            int vip = CimbingTowerCfgArray.Instance.dataArray[0].VipClearanceLimit;
+            if (RoleDataManager.CheckIsMonthCardOpenByType(1) || RoleDataManager.CheckIsMonthCardOpenByType(1))
             {
             {
-                UpdateLevel();
-                PromptController.Instance.ShowFloatTextPrompt("跳过成功!");
+                int isPassCount = 0;
+                foreach (var item in FieldWorkDataManager.Instance.CimbingTowerLevelInfoList)
+                {
+                    if (item.Value.IsPass)
+                    {
+                        isPassCount++;
+                    }
+                }
+                if (isPassCount >= FieldWorkDataManager.Instance.MaxLevelId)
+                {
+                    PromptController.Instance.ShowFloatTextPrompt("通关数量已超过最大可通关数量!");
+                    return;
+                }
             }
             }
             else
             else
             {
             {
-                PromptController.Instance.ShowFloatTextPrompt("每周仅一次!");
+                if(FieldWorkDataManager.Instance.MaxLevelId != 0)
+                {
+                    AlertUI.Show("一键通关不消耗服装和词牌的使用次数,每周可使用一次,是否快速通关?")
+                    .SetLeftButton(true, "否").SetRightButton(true, "是", async (object data) =>
+                    {
+                        bool result = await FieldWorkSproxy.ReqFieldWorkOneClickPass();
+                        if (result)
+                        {
+                            UpdateLevel();
+                            PromptController.Instance.ShowFloatTextPrompt("跳过成功!");
+                        }
+                    });
+                }
+                else
+                {
+                    PromptController.Instance.ShowFloatTextPrompt("暂未满足通关要求,无法使用此功能!");
+                }
             }
             }
         }
         }
         private void CheckGuide(object param)
         private void CheckGuide(object param)
@@ -200,8 +257,10 @@ namespace GFGGame
         protected override void UpdateToCheckGuide(object param)
         protected override void UpdateToCheckGuide(object param)
         {
         {
             if (!ViewManager.CheckIsTopView(this.viewCom)) return;
             if (!ViewManager.CheckIsTopView(this.viewCom)) return;
-            GuideController.TryGuide(_ui.m_resetBtn.target, ConstGuideId.FIELD, 2, "可重置关卡数据,每周一次!");            
+            GuideController.TryGuide(_ui.m_listTag, ConstGuideId.FIELD, 2, "每周主题标签将会获得额外的属性加成!");          
             GuideController.TryGuide(objGuide, ConstGuideId.FIELD, 3, "点击开始挑战!");
             GuideController.TryGuide(objGuide, ConstGuideId.FIELD, 3, "点击开始挑战!");
+            GuideController.TryGuide(_ui.m_resetBtn.target, ConstGuideId.FIELD, 15, "每周一5:00可以获得一次重置的机会,若遇到困难时可以考虑重置后再试试哦!", -1, true, _ui.target.height - 600);
+            GuideController.TryCompleteGuide(ConstGuideId.FIELD, 15);
         }
         }
     }
     }
 }
 }

+ 19 - 2
GameClient/Assets/Game/HotUpdate/Views/FieldWork/FieldWorkRoundResultView.cs

@@ -84,14 +84,14 @@ namespace GFGGame
                 }
                 }
                 else
                 else
                 {
                 {
-                    PromptController.Instance.ShowFloatTextPrompt("未通过!");
+                    //PromptController.Instance.ShowFloatTextPrompt("未通过!");
                 }
                 }
             }
             }
             else
             else
             {
             {
                 Timers.inst.Add(1, 1, StartNextRound);
                 Timers.inst.Add(1, 1, StartNextRound);
             }
             }
-
+            Timers.inst.AddUpdate(CheckGuide);
         }
         }
 
 
         protected override void OnHide()
         protected override void OnHide()
@@ -146,5 +146,22 @@ namespace GFGGame
                 dataManager.BonusList.Clear();
                 dataManager.BonusList.Clear();
             }
             }
         }
         }
+
+        private void CheckGuide(object param)
+        {
+            if (GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0 && isFinallyFight)
+            {
+                UpdateToCheckGuide(null);
+            }
+            else
+            {
+                Timers.inst.Remove(CheckGuide);
+            }
+        }
+        protected override void UpdateToCheckGuide(object param)
+        {
+            if (!ViewManager.CheckIsTopView(this.viewCom)) return;
+           GuideController.TryGuide(_ui.m_guide.target, ConstGuideId.FIELD, 14, "三轮累计的分数将决定关卡的通关与否!");
+        }
     }
     }
 }
 }

+ 5 - 5
GameClient/Assets/Game/HotUpdate/Views/InstanceZones/InstanceZonesView.cs

@@ -14,7 +14,7 @@ namespace GFGGame
         private EffectUI _effectUI1;
         private EffectUI _effectUI1;
         private EffectUI _effectUI2;
         private EffectUI _effectUI2;
         private EffectUI _effectUI3;
         private EffectUI _effectUI3;
-        private int fieldWorkLockLevel = 100005009;
+        private int fieldWorkLockLevel = FieldWorkDataManager.Instance.guideLevelID;
 
 
         public override void Dispose()
         public override void Dispose()
         {
         {
@@ -109,9 +109,9 @@ namespace GFGGame
                 || GuideDataManager.IsGuideFinish(ConstGuideId.STUDIO_FILING) <= 0
                 || GuideDataManager.IsGuideFinish(ConstGuideId.STUDIO_FILING) <= 0
                 || GuideDataManager.IsGuideFinish("TimeTracingShowView") <= 0
                 || GuideDataManager.IsGuideFinish("TimeTracingShowView") <= 0
                 || GuideDataManager.IsGuideFinish("ClothingSelectView") <= 0
                 || GuideDataManager.IsGuideFinish("ClothingSelectView") <= 0
-                //|| (GuideDataManager.IsGuideFinish("DAPEISAI_1") <=0 && MatchingCompetitionDataManager.Instance.MatchingState == 1 && MatchingCompetitionDataManager.Instance.MatchingCompetitionSeason != 0 && InstanceZonesDataManager.CheckLevelPass(100003004))
-                //|| (GuideDataManager.IsGuideFinish("DAPEISAI_2") <= 0 && MatchingCompetitionDataManager.Instance.MatchingState == 2 && MatchingCompetitionDataManager.Instance.MatchingCompetitionSeason != 0 && InstanceZonesDataManager.CheckLevelPass(100003004))
-                || (GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0 && InstanceZonesDataManager.CheckLevelPass(100005009)))
+                || (GuideDataManager.IsGuideFinish("DAPEISAI_1") <=0 && MatchingCompetitionDataManager.Instance.MatchingState == 1 && MatchingCompetitionDataManager.Instance.MatchingCompetitionSeason != 0 && InstanceZonesDataManager.CheckLevelPass(100003004))
+                || (GuideDataManager.IsGuideFinish("DAPEISAI_2") <= 0 && MatchingCompetitionDataManager.Instance.MatchingState == 2 && MatchingCompetitionDataManager.Instance.MatchingCompetitionSeason != 0 && InstanceZonesDataManager.CheckLevelPass(100003004))
+                || (GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0 && InstanceZonesDataManager.CheckLevelPass(FieldWorkDataManager.Instance.guideLevelID)))
             {
             {
                 UpdateToCheckGuide(null);
                 UpdateToCheckGuide(null);
             }
             }
@@ -218,7 +218,7 @@ namespace GFGGame
             //_ui.m_loaGuidestudio.visible = false;
             //_ui.m_loaGuidestudio.visible = false;
             GuideController.TryGuide(_ui.m_instance.m_btnStudio.target, ConstGuideId.STUDIO_PORCELAIN, 3, "工作室开门啦,进去看看~");
             GuideController.TryGuide(_ui.m_instance.m_btnStudio.target, ConstGuideId.STUDIO_PORCELAIN, 3, "工作室开门啦,进去看看~");
             GuideController.TryGuide(_ui.m_instance.m_btnStudio.target, ConstGuideId.STUDIO_FILING, 3, "工作室有新的任务啦。");
             GuideController.TryGuide(_ui.m_instance.m_btnStudio.target, ConstGuideId.STUDIO_FILING, 3, "工作室有新的任务啦。");
-            if (GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0 && InstanceZonesDataManager.CheckLevelPass(100005009))
+            if (GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0 && InstanceZonesDataManager.CheckLevelPass(FieldWorkDataManager.Instance.guideLevelID))
             {
             {
                 GuideController.TryGuide(_ui.m_instance.m_btnFieldWork.target, ConstGuideId.FIELD, 1, "外出进行考察,会有意想不到的收获哦。");
                 GuideController.TryGuide(_ui.m_instance.m_btnFieldWork.target, ConstGuideId.FIELD, 1, "外出进行考察,会有意想不到的收获哦。");
             }
             }

+ 9 - 3
GameClient/Assets/Game/HotUpdate/Views/MainStory/StoryCardChoose.cs

@@ -376,8 +376,7 @@ namespace GFGGame
                 FieldWorkSproxy.ReqChangeFieldWorkDressupOne(dataManager.SelectThemeIndex, cardId, MyDressUpHelper.dressUpObj.itemList).Coroutine();
                 FieldWorkSproxy.ReqChangeFieldWorkDressupOne(dataManager.SelectThemeIndex, cardId, MyDressUpHelper.dressUpObj.itemList).Coroutine();
                 if (InstanceZonesDataManager.FightScene == ConstInstanceZonesType.FieldWork)
                 if (InstanceZonesDataManager.FightScene == ConstInstanceZonesType.FieldWork)
                 {
                 {
-                    //ViewManager.GoBackFrom(typeof(ArenaDressUpFightView).FullName);
-                    ViewManager.Show<ArenaDressInfoView>(new object[] { FightRoleType.FieldWork, 0, dataManager.DressupList, "" }, true);
+                    ViewManager.GoBackFrom(typeof(FieldWorkDressFightView).FullName);                  
                     PromptController.Instance.ShowFloatTextPrompt("保存成功");
                     PromptController.Instance.ShowFloatTextPrompt("保存成功");
                 }
                 }
             }
             }
@@ -408,7 +407,8 @@ namespace GFGGame
 
 
         private void CheckGuide(object param)
         private void CheckGuide(object param)
         {
         {
-            if (GuideDataManager.IsGuideFinish(ConstGuideId.SKILL_CARD_FIGHT) <= 0)
+            if (GuideDataManager.IsGuideFinish(ConstGuideId.SKILL_CARD_FIGHT) <= 0
+                || (GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0 && InstanceZonesDataManager.FightScene == ConstInstanceZonesType.FieldWork && InstanceZonesDataManager.CheckLevelPass(FieldWorkDataManager.Instance.guideLevelID)))
             {
             {
                 UpdateToCheckGuide(null);
                 UpdateToCheckGuide(null);
             }
             }
@@ -426,6 +426,12 @@ namespace GFGGame
                 _ui.m_btnCancel.y + _ui.m_btnCancel.height);
                 _ui.m_btnCancel.y + _ui.m_btnCancel.height);
             GuideController.TryGuide(_ui.m_listCard, ConstGuideId.SKILL_CARD_FIGHT, 2, "选择一张合适的词牌,增加过关战斗力。", 0);
             GuideController.TryGuide(_ui.m_listCard, ConstGuideId.SKILL_CARD_FIGHT, 2, "选择一张合适的词牌,增加过关战斗力。", 0);
             GuideController.TryCompleteGuide(ConstGuideId.SKILL_CARD_FIGHT, 2);
             GuideController.TryCompleteGuide(ConstGuideId.SKILL_CARD_FIGHT, 2);
+
+            if ((GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0 && InstanceZonesDataManager.FightScene == ConstInstanceZonesType.FieldWork))
+            {
+                GuideController.TryGuide(_ui.m_listCard, ConstGuideId.FIELD, 10, "战斗结束时使用过的词牌会根据对应的关卡难度形成不同程度损耗关卡的难度合理搭配阵容!", 0);
+                GuideController.TryGuide(_ui.m_btnConfirm, ConstGuideId.FIELD, 11, "确认!");
+            }
         }
         }
         private void AddEffect()
         private void AddEffect()
         {
         {

+ 4 - 1
GameClient/Assets/Game/HotUpdate/Views/MainStory/StoryFightSingleScoreView.cs

@@ -197,7 +197,6 @@ namespace GFGGame
             _ui.m_loaBg.url = ResPathUtil.GetBgImgPath("zd_g_bg");
             _ui.m_loaBg.url = ResPathUtil.GetBgImgPath("zd_g_bg");
             if (InstanceZonesDataManager.FightScene == ConstInstanceZonesType.FieldWork)
             if (InstanceZonesDataManager.FightScene == ConstInstanceZonesType.FieldWork)
             {
             {
-                _ui.m_btnBack.visible = false;
                 FightDataManager.Instance.autoPlay = true;
                 FightDataManager.Instance.autoPlay = true;
             }
             }
             if (!FightDataManager.Instance.autoPlay)
             if (!FightDataManager.Instance.autoPlay)
@@ -252,6 +251,10 @@ namespace GFGGame
                 _ui.m_btnBack.visible = true;
                 _ui.m_btnBack.visible = true;
                 Timers.inst.Add(0.5f, 1, TryShowCardSkill);
                 Timers.inst.Add(0.5f, 1, TryShowCardSkill);
             }
             }
+            if (GuideDataManager.IsGuideFinish(ConstGuideId.FIELD) <= 0 && InstanceZonesDataManager.FightScene == ConstInstanceZonesType.FieldWork)
+            {
+                _ui.m_btnBack.visible = false;
+            }
             tryGuide = false;
             tryGuide = false;
             Timers.inst.AddUpdate(CheckGuide);
             Timers.inst.AddUpdate(CheckGuide);
         }
         }

二进制
GameClient/Assets/ResIn/UI/Arena/Arena_fui.bytes


二进制
GameClient/Assets/ResIn/UI/FieldWork/FieldWork_fui.bytes


二进制
GameClient/Assets/ResIn/UI/Main/Main_fui.bytes