|
@@ -27,21 +27,74 @@ namespace GFGGame
|
|
bool isGuide = GameGlobal.skipGuide == false && !isAllGuideFinish;
|
|
bool isGuide = GameGlobal.skipGuide == false && !isAllGuideFinish;
|
|
return isGuide;
|
|
return isGuide;
|
|
}
|
|
}
|
|
|
|
+ /// <summary>
|
|
|
|
+ /// 检测当前角色等级是否有引导开启,若有则返回引导id
|
|
|
|
+ /// </summary>
|
|
|
|
+ /// <returns></returns>
|
|
|
|
+ public static string CheckHasRoleLvGuideOpen()
|
|
|
|
+ {
|
|
|
|
+ GuideCfg[] guideCfgs = GuideCfgArray.Instance.dataArray;
|
|
|
|
+
|
|
|
|
+ for (int i = 0; i < guideCfgs.Length; i++)
|
|
|
|
+ {
|
|
|
|
+ if (guideCfgs[i].roleLv <= 0) continue;
|
|
|
|
+ bool isFinishCurId = StorageDataManager.Instance.GetStorageValue(ConstStorageId.STORAGE_GUIDE + guideCfgs[i].id) > 0;
|
|
|
|
+ if (!isFinishCurId && guideCfgs[i].roleLv <= RoleDataManager.lvl)
|
|
|
|
+ {
|
|
|
|
+ return guideCfgs[i].viewName;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return "";
|
|
|
|
+ }
|
|
|
|
|
|
- public static bool TryGuide(GObject target, string guideKey, int index, string guideStr = null, int listIndex = -1, bool checkPriorIndex = true, int yTxt = 0, float devWidth = 0, float devHeight = 0, bool showAni = true)
|
|
|
|
|
|
+ /// <summary>
|
|
|
|
+ /// 是否特殊条件开启
|
|
|
|
+ /// </summary>
|
|
|
|
+ /// <returns></returns>
|
|
|
|
+ private static bool CheckSpecialGuideOpen(GuideCfg cfg)
|
|
{
|
|
{
|
|
|
|
+ if (cfg.special <= 0) return false;
|
|
|
|
+ if (cfg.key == ConstGuideId.SUIT_LIST_VIEW)
|
|
|
|
+ {
|
|
|
|
+ return FunctionOpenDataManager.Instance.CheckIsFunOpenById(typeof(SuitListView).Name, false);
|
|
|
|
+ }
|
|
|
|
+ return false;
|
|
|
|
+
|
|
|
|
+ }
|
|
|
|
|
|
|
|
+ public static bool TryGuide(GObject target, string guideKey, int index, string guideStr = null, int listIndex = -1, bool checkPriorIndex = true, int yTxt = 0, float devWidth = 0, float devHeight = 0, bool showAni = true, bool showEffect = true, bool isOptionalGuide = false)
|
|
|
|
+ {
|
|
GuideCfg cfg = GuideCfgArray.Instance.GetCfg(guideKey);
|
|
GuideCfg cfg = GuideCfgArray.Instance.GetCfg(guideKey);
|
|
|
|
+ if (GuideDataManager.currentGuideId != 0 && GuideDataManager.currentGuideId != cfg.id) return false;
|
|
|
|
|
|
bool isStoryLevelGuide = cfg.storyLevelId > 0;
|
|
bool isStoryLevelGuide = cfg.storyLevelId > 0;
|
|
bool isFinishCurId = StorageDataManager.Instance.GetStorageValue(ConstStorageId.STORAGE_GUIDE + cfg.id) > 0;//当前引导未完成
|
|
bool isFinishCurId = StorageDataManager.Instance.GetStorageValue(ConstStorageId.STORAGE_GUIDE + cfg.id) > 0;//当前引导未完成
|
|
bool isFinishPriorId = cfg.priorId <= 0 || StorageDataManager.Instance.GetStorageValue(ConstStorageId.STORAGE_GUIDE + cfg.priorId) > 0;//前置引导已完成
|
|
bool isFinishPriorId = cfg.priorId <= 0 || StorageDataManager.Instance.GetStorageValue(ConstStorageId.STORAGE_GUIDE + cfg.priorId) > 0;//前置引导已完成
|
|
bool isFinishCurIndex = GuideDataManager.IsGuideIndexFinish(cfg.id, index) == true;//当前index未完成
|
|
bool isFinishCurIndex = GuideDataManager.IsGuideIndexFinish(cfg.id, index) == true;//当前index未完成
|
|
bool isFinishPriorIndex = !checkPriorIndex || checkPriorIndex && GuideDataManager.IsGuideIndexFinish(cfg.id, index - 1) == true;//前置index已完成
|
|
bool isFinishPriorIndex = !checkPriorIndex || checkPriorIndex && GuideDataManager.IsGuideIndexFinish(cfg.id, index - 1) == true;//前置index已完成
|
|
- bool isCfgChapterOpen = MainStoryDataManager.CheckLevelUnlock(cfg.storyLevelId);//引导配置关卡已开启
|
|
|
|
|
|
+ bool isCfgChapterOpen = MainStoryDataManager.CheckLevelUnlock(cfg.storyLevelId, false);//引导配置关卡已开启
|
|
|
|
+ // if (checkChapterPass && !isCfgChapterOpen)
|
|
|
|
+ // {//cfg.storyLevelId为当前关卡,通关时 MainStoryDataManager.currentLevelCfgId为下一章的第一关,但下一章有可能因为角色等级不足未开启,会导致引导无法正常开启,所以添加是否通关检测
|
|
|
|
+ // StoryLevelCfg levelCfg = StoryLevelCfgArray.Instance.GetCfg(cfg.storyLevelId);
|
|
|
|
+ // if (levelCfg.chapterId - 1 > 0)
|
|
|
|
+ // {
|
|
|
|
+ // isCfgChapterOpen = MainStoryDataManager.CheckNeedChapterPass(levelCfg.chapterId - 1, out int needChapterId);
|
|
|
|
+ // }
|
|
|
|
+ // }
|
|
bool isCfgChapter = MainStoryDataManager.currentLevelCfgId == 0 || MainStoryDataManager.currentLevelCfgId == cfg.storyLevelId;//无选择(进入游戏时无选择)或当前所选择为配置关卡
|
|
bool isCfgChapter = MainStoryDataManager.currentLevelCfgId == 0 || MainStoryDataManager.currentLevelCfgId == cfg.storyLevelId;//无选择(进入游戏时无选择)或当前所选择为配置关卡
|
|
|
|
|
|
- if (isStoryLevelGuide && !isFinishCurId && isFinishPriorId && !isFinishCurIndex && isFinishPriorIndex && isCfgChapterOpen && isCfgChapter || !isStoryLevelGuide && !isFinishCurId)
|
|
|
|
|
|
+ bool isRoleLvGuide = cfg.roleLv > 0;
|
|
|
|
+ bool iscurRoleLv = RoleDataManager.lvl >= cfg.roleLv;
|
|
|
|
+
|
|
|
|
+ bool isSpecial = cfg.special > 0; //特殊条件开启的引导
|
|
|
|
+ bool specialOpen = CheckSpecialGuideOpen(cfg);
|
|
|
|
+
|
|
|
|
+ bool noneType = !isStoryLevelGuide && !isFinishCurId && isFinishPriorId && !isFinishCurIndex && isFinishPriorIndex && !isRoleLvGuide && !isSpecial;
|
|
|
|
+ bool storyType = isStoryLevelGuide && !isFinishCurId && isFinishPriorId && !isFinishCurIndex && isFinishPriorIndex && isCfgChapterOpen && isCfgChapter;
|
|
|
|
+ bool roleLvType = isRoleLvGuide && !isFinishCurId && isFinishPriorId && !isFinishCurIndex && isFinishPriorIndex && iscurRoleLv;
|
|
|
|
+ bool specialType = isSpecial && !isFinishCurId && isFinishPriorId && !isFinishCurIndex && isFinishPriorIndex && specialOpen;
|
|
|
|
+ if (storyType || roleLvType || specialType || noneType)
|
|
{
|
|
{
|
|
GuideDataManager.currentGuideId = cfg.id;
|
|
GuideDataManager.currentGuideId = cfg.id;
|
|
GuideDataManager.currentGuideIdIndex = index;
|
|
GuideDataManager.currentGuideIdIndex = index;
|
|
@@ -64,7 +117,8 @@ namespace GFGGame
|
|
return false;
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
- ShowGuideByIndex(target, guideStr, yTxt, cfg.optionalGuide == 1, devWidth, devHeight, GuideDataManager.currentGuideId, GuideDataManager.currentGuideIdIndex, showAni);
|
|
|
|
|
|
+ bool _isOptionalGuide = isOptionalGuide ? isOptionalGuide : cfg.optionalGuide == 1;
|
|
|
|
+ ShowGuideByIndex(target, guideStr, yTxt, _isOptionalGuide, devWidth, devHeight, GuideDataManager.currentGuideId, GuideDataManager.currentGuideIdIndex, showAni, showEffect);
|
|
if (!checkPriorIndex)
|
|
if (!checkPriorIndex)
|
|
{
|
|
{
|
|
for (int i = 1; i < index; i++)
|
|
for (int i = 1; i < index; i++)
|
|
@@ -76,7 +130,7 @@ namespace GFGGame
|
|
}
|
|
}
|
|
return false;
|
|
return false;
|
|
}
|
|
}
|
|
- private static void ShowGuideByIndex(GObject target, string guideStr = null, int yTxt = 0, bool isOptionalGuide = false, float devWidth = 0, float devHeight = 0, int guideId = 0, int index = 0, bool showAni = true)
|
|
|
|
|
|
+ private static void ShowGuideByIndex(GObject target, string guideStr = null, int yTxt = 0, bool isOptionalGuide = false, float devWidth = 0, float devHeight = 0, int guideId = 0, int index = 0, bool showAni = true, bool showEffect = true)
|
|
{
|
|
{
|
|
HideGuide();
|
|
HideGuide();
|
|
if (GameGlobal.skipGuide)
|
|
if (GameGlobal.skipGuide)
|
|
@@ -84,7 +138,7 @@ namespace GFGGame
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
|
|
|
|
- ViewManager.Show(ViewName.GUIDE_VIEW, new List<object> { target, guideStr, yTxt, isOptionalGuide, devWidth, devHeight, guideId, index, showAni });
|
|
|
|
|
|
+ ViewManager.Show(ViewName.GUIDE_VIEW, new List<object> { target, guideStr, yTxt, isOptionalGuide, devWidth, devHeight, guideId, index, showAni, showEffect });
|
|
}
|
|
}
|
|
public static bool TryCompleteGuideIndex(int guideId, int index)
|
|
public static bool TryCompleteGuideIndex(int guideId, int index)
|
|
{
|
|
{
|