From 42cd1608acf5bb9f99ee16fa6db7d7e7fff072c6 Mon Sep 17 00:00:00 2001
From: yyl <yyl>
Date: 星期一, 02 二月 2026 17:35:34 +0800
Subject: [PATCH] 125 防止重复注册事件的内容

---
 Main/Utility/Extension.cs                          |   77 +++++++++++++++++++++++++++++++++++++-
 Main/System/Battle/BattleField/StoryBattleField.cs |    5 ++
 Main/System/FuncPreset/FuncPresetManager.cs        |    2 
 3 files changed, 81 insertions(+), 3 deletions(-)

diff --git a/Main/System/Battle/BattleField/StoryBattleField.cs b/Main/System/Battle/BattleField/StoryBattleField.cs
index a29c749..c1dceef 100644
--- a/Main/System/Battle/BattleField/StoryBattleField.cs
+++ b/Main/System/Battle/BattleField/StoryBattleField.cs
@@ -62,7 +62,12 @@
 
         // LoadBattleMode();
         lastPresetID = TeamManager.Instance.GetMainTeamID();
+
+        //  闃叉閲嶅娉ㄥ唽鐨勯棶棰�
+        TeamManager.Instance.OnTeamChange.RemoveCompletely(OnTeamChange);
         TeamManager.Instance.OnTeamChange += OnTeamChange;
+
+        FuncPresetManager.Instance.OnFuncPresetUseDataEvent.RemoveCompletely(OnFuncPresetUseDataEvent);
         FuncPresetManager.Instance.OnFuncPresetUseDataEvent += OnFuncPresetUseDataEvent;
     }
 
diff --git a/Main/System/FuncPreset/FuncPresetManager.cs b/Main/System/FuncPreset/FuncPresetManager.cs
index 503e904..1652915 100644
--- a/Main/System/FuncPreset/FuncPresetManager.cs
+++ b/Main/System/FuncPreset/FuncPresetManager.cs
@@ -15,7 +15,7 @@
 
     //鎵�鏈夐璁炬柟妗堢殑淇濆瓨淇℃伅 鍏ㄥ眬鏂规ID 锛氬瓙鍔熻兘绫诲瀷锛堥厤琛級锛氬瓙鏂规ID
     Dictionary<int, Dictionary<int, int>> m_FuncPresetSaveDict = new Dictionary<int, Dictionary<int, int>>();
-    public event Action<int> OnFuncPresetUseDataEvent;  //0 鏇存崲瀛愭柟妗堬紝1 鏇存崲鍏ㄥ眬鏂规锛�2 瑙i攣/鏇存敼鍚�
+    public Action<int> OnFuncPresetUseDataEvent;  //0 鏇存崲瀛愭柟妗堬紝1 鏇存崲鍏ㄥ眬鏂规锛�2 瑙i攣/鏇存敼鍚�
 
     public const int GlobalDefaultPresetID = 1; //榛樿鍏ㄥ眬鏂规ID
     public const int FuncDefaultPresetID = 1;   //榛樿瀛愬姛鑳芥柟妗圛D
diff --git a/Main/Utility/Extension.cs b/Main/Utility/Extension.cs
index 5a2e4e8..b5d01c7 100644
--- a/Main/Utility/Extension.cs
+++ b/Main/Utility/Extension.cs
@@ -1,4 +1,77 @@
-class Extension
-{
+using System;
+using System.Collections.Generic;
 
+public static class Extension
+{
+    public static void RemoveCompletely<T>(this System.Action<T> action, Action<T> removeAction)
+    {
+        if (null == action)
+        {
+            return;
+        }
+
+        Delegate[] invocations = action.GetInvocationList();
+
+        for (int i = 0; i < invocations.Length; i++)
+        {
+            if (invocations[i].Equals(removeAction))
+            {
+                action -= removeAction;
+            }
+        }
+    }
+
+    public static void RemoveCompletely<T, U>(this System.Action<T, U> action, Action<T, U> removeAction)
+    {
+        if (null == action)
+        {
+            return;
+        }
+
+        Delegate[] invocations = action.GetInvocationList();
+
+        for (int i = 0; i < invocations.Length; i++)
+        {
+            if (invocations[i].Equals(removeAction))
+            {
+                action -= removeAction;
+            }
+        }
+    }
+
+    public static void RemoveCompletely(this System.Action action, Action removeAction)
+    {
+        if (null == action)
+        {
+            return;
+        }
+
+        Delegate[] invocations = action.GetInvocationList();
+
+        for (int i = 0; i < invocations.Length; i++)
+        {
+            if (invocations[i].Equals(removeAction))
+            {
+                action -= removeAction;
+            }
+        }
+    }
+
+    public static void RemoveCompletely<T, U, V>(this System.Action<T, U, V> action, Action<T, U, V> removeAction)
+    {
+        if (null == action)
+        {
+            return;
+        }
+
+        Delegate[] invocations = action.GetInvocationList();
+
+        for (int i = 0; i < invocations.Length; i++)
+        {
+            if (invocations[i].Equals(removeAction))
+            {
+                action -= removeAction;
+            }
+        }
+    }
 }
\ No newline at end of file

--
Gitblit v1.8.0