| Main/System/HeroUI/HeroBestWin.cs | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
| Main/System/HeroUI/HeroTrainWin.cs | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
| Main/System/HeroUI/HeroUIManager.Collect.cs | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 |
Main/System/HeroUI/HeroBestWin.cs
@@ -193,8 +193,17 @@ { if (heroConfig.FetterIDList.Length > 0) { int fetterID = heroConfig.FetterIDList[0]; HeroFetterConfig fetterConfig = HeroFetterConfig.Get(fetterID); if (fetterConfig != null && HeroUIManager.IsFetterAllHeroOpen(fetterConfig)) { connetionForm.SetActive(true); connetionForm.Display(heroConfig.FetterIDList[0], Language.Get("herocard38") + "\n", true); connetionForm.Display(fetterID, Language.Get("herocard38") + "\n", true); } else { connetionForm.SetActive(false); } } else { @@ -394,11 +403,21 @@ //羁绊 void RefreshFetter() { if (heroConfig.FetterIDList.Length == 0) if (heroConfig.FetterIDList.IsNullOrEmpty()) { fetterGo.SetActive(false); return; } // 检查第一个羁绊组合是否满足开服天条件,不满足则隐藏整个羁绊区域 int firstFetterID = heroConfig.FetterIDList[0]; HeroFetterConfig firstFetterConfig = HeroFetterConfig.Get(firstFetterID); if (firstFetterConfig == null || !HeroUIManager.IsFetterAllHeroOpen(firstFetterConfig)) { fetterGo.SetActive(false); return; } fetterGo.SetActive(true); for (int i = 0; i < fetterText.Length; i++) @@ -526,6 +545,5 @@ } } } } Main/System/HeroUI/HeroTrainWin.cs
@@ -371,8 +371,17 @@ { if (hero.heroConfig.FetterIDList.Length > 0) { int fetterID = hero.heroConfig.FetterIDList[0]; HeroFetterConfig fetterConfig = HeroFetterConfig.Get(fetterID); if (fetterConfig != null && HeroUIManager.IsFetterAllHeroOpen(fetterConfig)) { connetionForm.SetActive(true); connetionForm.Display(hero.heroConfig.FetterIDList[0], Language.Get("herocard38") + "\n", true, guid); connetionForm.Display(fetterID, Language.Get("herocard38") + "\n", true, guid); } else { connetionForm.SetActive(false); } } else { @@ -694,6 +703,16 @@ fetterGo.SetActive(false); return; } // 检查第一个羁绊组合是否满足开服天条件,不满足则隐藏整个羁绊区域 int firstFetterID = hero.heroConfig.FetterIDList[0]; HeroFetterConfig firstFetterConfig = HeroFetterConfig.Get(firstFetterID); if (firstFetterConfig == null || !HeroUIManager.IsFetterAllHeroOpen(firstFetterConfig)) { fetterGo.SetActive(false); return; } fetterGo.SetActive(true); for (int i = 0; i < fetterText.Length; i++) Main/System/HeroUI/HeroUIManager.Collect.cs
@@ -162,8 +162,8 @@ HeroConfig heroConfig = HeroConfig.Get(heroID); if (heroConfig.PlayerCanUse == 0) continue; // 新增:开服第x天显示图鉴,0表示不限制开服天 if (heroConfig.OpenCollectionDay > 0 && TimeUtility.OpenDay + 1 < heroConfig.OpenCollectionDay) // 开服第x天显示图鉴,0表示不限制开服天 if (HasOpenCollectionDayLimit(heroID) && !IsOpenCollectionDayMet(heroID)) continue; if (!heroCollectDict.ContainsKey(heroConfig.Quality)) { @@ -414,6 +414,57 @@ } #region 开服天数相关方法 /// <summary> /// 检查武将是否配置了开服展示天数限制 /// </summary> /// <param name="heroID">武将ID</param> /// <returns>true: 有开服天限制; false: 无限制(OpenCollectionDay==0 或配置不存在)</returns> public static bool HasOpenCollectionDayLimit(int heroID) { HeroConfig heroConfig = HeroConfig.Get(heroID); if (heroConfig == null) return false; return heroConfig.OpenCollectionDay > 0; } /// <summary> /// 检查武将是否已满足开服展示天数要求(仅在有限制时调用有意义) /// </summary> /// <param name="heroID">武将ID</param> /// <returns>true: 已满足展示天数; false: 尚未满足</returns> public static bool IsOpenCollectionDayMet(int heroID) { HeroConfig heroConfig = HeroConfig.Get(heroID); if (heroConfig == null) return false; // OpenCollectionDay==0 无限制,视为已满足 if (heroConfig.OpenCollectionDay <= 0) return true; return TimeUtility.OpenDay + 1 >= heroConfig.OpenCollectionDay; } /// <summary> /// 检查羁绊组合中所有武将是否都满足开服展示天数 /// 只有配置了开服天限制的武将才需要检查,未配置限制的武将视为满足 /// </summary> /// <param name="fetterConfig">羁绊配置</param> /// <returns>true: 所有武将都满足; false: 有武将不满足</returns> public static bool IsFetterAllHeroOpen(HeroFetterConfig fetterConfig) { for (int i = 0; i < fetterConfig.HeroIDList.Length; i++) { int heroID = fetterConfig.HeroIDList[i]; // 有限制但未满足 -> 该羁绊不可显示 if (HasOpenCollectionDayLimit(heroID) && !IsOpenCollectionDayMet(heroID)) return false; } return true; } #endregion #endregion }