diff --git a/Assets/Scripts/Game/GameLogic.cs b/Assets/Scripts/Game/GameLogic.cs index c1dda20a..ef90ec6b 100644 --- a/Assets/Scripts/Game/GameLogic.cs +++ b/Assets/Scripts/Game/GameLogic.cs @@ -70,11 +70,11 @@ public class GameLogic : MonoBehaviour { PlayerData.Instance.UnlockNewLevel(); } - tUIResult.Init(PlayerData.Instance.CurrentLevelID, tEdData.EndingName, tEdData.IsGoodEnding, tHasNew, PlayerData.Instance.HasUnlockedAllLevel()); + tUIResult.Init(PlayerData.Instance.CurrentLevelID, tEdData.EndingName, tEdData.IsGoodEnding, tHasNew, PlayerData.Instance.IsNextLevelPassed()); } else { - tUIResult.Init(PlayerData.Instance.CurrentLevelID, "", false, false, PlayerData.Instance.HasUnlockedAllLevel()); + tUIResult.Init(PlayerData.Instance.CurrentLevelID, "", false, false, PlayerData.Instance.IsNextLevelPassed()); } tUIResult.DelAgain = PlayAgain; diff --git a/Assets/Scripts/Storage/PlayerData.cs b/Assets/Scripts/Storage/PlayerData.cs index 0d4e825f..e5aae501 100644 --- a/Assets/Scripts/Storage/PlayerData.cs +++ b/Assets/Scripts/Storage/PlayerData.cs @@ -51,6 +51,17 @@ public class PlayerData : StorageBase return mUnlockedLevel == GameConfig.Instance.LevelSort.Count; } + public bool IsNextLevelPassed() + { + if (mCurrentLevel == GameConfig.Instance.LevelSort.Count) + { + return true; + } + + int tNextLvID = GameConfig.Instance.LevelSort[mCurrentLevel];//+1 - 1 + return LevelReachGoodEnding(tNextLvID); + } + public bool AddEnding(int pLevelID, int pEndingID) { if (!mEndingDic.ContainsKey(pLevelID)) @@ -78,6 +89,23 @@ public class PlayerData : StorageBase return 0; } + public bool LevelReachGoodEnding(int pLevelID) + { + if (mEndingDic.ContainsKey(pLevelID)) + { + LevelData tLvData = GameConfig.Instance.GetLevelData(pLevelID); + for (int i = 0; i < tLvData.Endings.Count; i++) + { + if (tLvData.Endings[i].IsGoodEnding && mEndingDic[pLevelID].Contains(i)) + { + return true; + } + } + } + + return false; + } + public bool HasUnlockedEnding(int pLevelID, int pEndingID) { return mEndingDic.ContainsKey(pLevelID) && mEndingDic[pLevelID].Contains(pEndingID); diff --git a/Assets/Scripts/UI/PanelResult.cs b/Assets/Scripts/UI/PanelResult.cs index a6628b81..58a06bd2 100644 --- a/Assets/Scripts/UI/PanelResult.cs +++ b/Assets/Scripts/UI/PanelResult.cs @@ -45,7 +45,7 @@ public class PanelResult : BasePanel mGobFx.SetActive(pFocus); } - public void Init(int pLevelID, string pEndingName,bool pIsWin, bool pHasNew, bool pAllLevelClear) + public void Init(int pLevelID, string pEndingName,bool pIsWin, bool pHasNew, bool pNextLevelClear) { mTxtEndingName.text = pEndingName; @@ -55,8 +55,8 @@ public class PanelResult : BasePanel mGobWinFace.SetActive(pIsWin); mGobLoseFace.SetActive(!pIsWin); - mGobWinBtns.SetActive(!pAllLevelClear && pIsWin); - mGobOtherBtns.SetActive(pAllLevelClear || !pIsWin); + mGobWinBtns.SetActive(!pNextLevelClear && pIsWin); + mGobOtherBtns.SetActive(pNextLevelClear || !pIsWin); LevelData tLvData = GameConfig.Instance.GetLevelData(pLevelID); mBtnEndings.Init(pLevelID, PlayerData.Instance.EndingCountOfLevel(pLevelID), tLvData.Endings.Count);