Merge pull request #53 from dnutiu/exit-strategy

Exit strategy
This commit is contained in:
Denis-Cosmin Nutiu 2019-07-14 14:46:56 +03:00 committed by GitHub
commit 064f47d52a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
20 changed files with 244 additions and 201 deletions

View file

@ -10,6 +10,8 @@ GameObject:
m_Component: m_Component:
- component: {fileID: 3243993883904879596} - component: {fileID: 3243993883904879596}
- component: {fileID: 3212428174306319952} - component: {fileID: 3212428174306319952}
- component: {fileID: 3858379993772342456}
- component: {fileID: 1949159407646367785}
m_Layer: 0 m_Layer: 0
m_Name: exitDoorPrefab m_Name: exitDoorPrefab
m_TagString: Untagged m_TagString: Untagged
@ -79,3 +81,41 @@ SpriteRenderer:
m_WasSpriteAssigned: 1 m_WasSpriteAssigned: 1
m_MaskInteraction: 0 m_MaskInteraction: 0
m_SpriteSortPoint: 0 m_SpriteSortPoint: 0
--- !u!114 &3858379993772342456
MonoBehaviour:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 1538214466168189615}
m_Enabled: 1
m_EditorHideFlags: 0
m_Script: {fileID: 11500000, guid: d5d5847c8fef4a91bafe88cc2ccf43ec, type: 3}
m_Name:
m_EditorClassIdentifier:
--- !u!61 &1949159407646367785
BoxCollider2D:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 1538214466168189615}
m_Enabled: 1
m_Density: 1
m_Material: {fileID: 0}
m_IsTrigger: 1
m_UsedByEffector: 0
m_UsedByComposite: 0
m_Offset: {x: 0.5, y: 0.5}
m_SpriteTilingProperty:
border: {x: 0, y: 0, z: 0, w: 0}
pivot: {x: 0, y: 0}
oldSize: {x: 1, y: 1}
newSize: {x: 0.32, y: 0.32}
adaptiveTilingThreshold: 0.5
drawMode: 0
adaptiveTiling: 0
m_AutoTiling: 0
serializedVersion: 2
m_Size: {x: 0.1, y: 0.8}
m_EdgeRadius: 0

View file

@ -45,6 +45,8 @@ MonoBehaviour:
m_Script: {fileID: 11500000, guid: 697f5ae5656c74dcd8d7f5d619adb0ac, type: 3} m_Script: {fileID: 11500000, guid: 697f5ae5656c74dcd8d7f5d619adb0ac, type: 3}
m_Name: m_Name:
m_EditorClassIdentifier: m_EditorClassIdentifier:
preStageUiPrefab: {fileID: 4994633962466276707, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
--- !u!114 &158905820630581596 --- !u!114 &158905820630581596
MonoBehaviour: MonoBehaviour:
m_ObjectHideFlags: 0 m_ObjectHideFlags: 0

View file

@ -553,7 +553,7 @@ MonoBehaviour:
m_FloatArgument: 1 m_FloatArgument: 1
m_StringArgument: Jump m_StringArgument: Jump
m_BoolArgument: 0 m_BoolArgument: 0
m_CallState: 2 m_CallState: 1
m_TypeName: UnityEngine.EventSystems.EventTrigger+TriggerEvent, UnityEngine.UI, m_TypeName: UnityEngine.EventSystems.EventTrigger+TriggerEvent, UnityEngine.UI,
Version=1.0.0.0, Culture=neutral, PublicKeyToken=null Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
delegates: delegates:

View file

@ -34,8 +34,8 @@ RectTransform:
m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
m_AnchorMin: {x: 0.5, y: 0.5} m_AnchorMin: {x: 0.5, y: 0.5}
m_AnchorMax: {x: 0.5, y: 0.5} m_AnchorMax: {x: 0.5, y: 0.5}
m_AnchoredPosition: {x: 0, y: 0} m_AnchoredPosition: {x: 70.3, y: -35.5}
m_SizeDelta: {x: 160, y: 30} m_SizeDelta: {x: 300.5, y: 101.1}
m_Pivot: {x: 0.5, y: 0.5} m_Pivot: {x: 0.5, y: 0.5}
--- !u!222 &5829552964612260718 --- !u!222 &5829552964612260718
CanvasRenderer: CanvasRenderer:
@ -71,14 +71,14 @@ MonoBehaviour:
m_FontStyle: 1 m_FontStyle: 1
m_BestFit: 0 m_BestFit: 0
m_MinSize: 1 m_MinSize: 1
m_MaxSize: 40 m_MaxSize: 50
m_Alignment: 0 m_Alignment: 0
m_AlignByGeometry: 0 m_AlignByGeometry: 0
m_RichText: 0 m_RichText: 0
m_HorizontalOverflow: 0 m_HorizontalOverflow: 0
m_VerticalOverflow: 0 m_VerticalOverflow: 0
m_LineSpacing: 1 m_LineSpacing: 1
m_Text: Stage 1 m_Text:
--- !u!1 &2251350585563921972 --- !u!1 &2251350585563921972
GameObject: GameObject:
m_ObjectHideFlags: 0 m_ObjectHideFlags: 0
@ -165,7 +165,7 @@ GameObject:
- component: {fileID: 2152024136797500473} - component: {fileID: 2152024136797500473}
- component: {fileID: 936482196064115039} - component: {fileID: 936482196064115039}
- component: {fileID: 826719949318333507} - component: {fileID: 826719949318333507}
- component: {fileID: 2684488013186753063} - component: {fileID: 4764158450672019134}
m_Layer: 5 m_Layer: 5
m_Name: PreStageUI m_Name: PreStageUI
m_TagString: Untagged m_TagString: Untagged
@ -254,7 +254,7 @@ MonoBehaviour:
m_BlockingMask: m_BlockingMask:
serializedVersion: 2 serializedVersion: 2
m_Bits: 4294967295 m_Bits: 4294967295
--- !u!114 &2684488013186753063 --- !u!114 &4764158450672019134
MonoBehaviour: MonoBehaviour:
m_ObjectHideFlags: 0 m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0} m_CorrespondingSourceObject: {fileID: 0}

View file

@ -271,7 +271,7 @@ Transform:
m_Children: m_Children:
- {fileID: 97386695} - {fileID: 97386695}
m_Father: {fileID: 0} m_Father: {fileID: 0}
m_RootOrder: 3 m_RootOrder: 4
m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
--- !u!114 &266944717 --- !u!114 &266944717
MonoBehaviour: MonoBehaviour:
@ -404,7 +404,7 @@ Transform:
m_PrefabAsset: {fileID: 0} m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 519420028} m_GameObject: {fileID: 519420028}
m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
m_LocalPosition: {x: 11.456655, y: -4.0430503, z: -10} m_LocalPosition: {x: 13.828903, y: -4.0430503, z: -10}
m_LocalScale: {x: 1, y: 1, z: 1} m_LocalScale: {x: 1, y: 1, z: 1}
m_Children: [] m_Children: []
m_Father: {fileID: 0} m_Father: {fileID: 0}
@ -478,137 +478,8 @@ Transform:
m_LocalScale: {x: 1, y: 1, z: 1} m_LocalScale: {x: 1, y: 1, z: 1}
m_Children: [] m_Children: []
m_Father: {fileID: 0} m_Father: {fileID: 0}
m_RootOrder: 5 m_RootOrder: 6
m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
--- !u!1001 &1152312890
PrefabInstance:
m_ObjectHideFlags: 0
serializedVersion: 2
m_Modification:
m_TransformParent: {fileID: 0}
m_Modifications:
- target: {fileID: 4994633962466276707, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_Name
value: PreStageUI
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_LocalPosition.x
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_LocalPosition.y
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_LocalPosition.z
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_LocalRotation.x
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_LocalRotation.y
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_LocalRotation.z
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_LocalRotation.w
value: 1
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_RootOrder
value: 9
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_LocalEulerAnglesHint.x
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_LocalEulerAnglesHint.y
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_LocalEulerAnglesHint.z
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_AnchoredPosition.x
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_AnchoredPosition.y
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_SizeDelta.x
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_SizeDelta.y
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_AnchorMin.x
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_AnchorMin.y
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_AnchorMax.x
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_AnchorMax.y
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_Pivot.x
value: 0
objectReference: {fileID: 0}
- target: {fileID: 7935883257743492533, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_Pivot.y
value: 0
objectReference: {fileID: 0}
- target: {fileID: 2152024136797500473, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_Enabled
value: 1
objectReference: {fileID: 0}
- target: {fileID: 4935993846136593301, guid: 1f5ebc13237e070449ea8bc9e8b07ac8,
type: 3}
propertyPath: m_Text
value:
objectReference: {fileID: 0}
m_RemovedComponents: []
m_SourcePrefab: {fileID: 100100000, guid: 1f5ebc13237e070449ea8bc9e8b07ac8, type: 3}
--- !u!4 &1352658977 stripped --- !u!4 &1352658977 stripped
Transform: Transform:
m_CorrespondingSourceObject: {fileID: 6843575828445418654, guid: d3055091a17dc4aa1accf2e33ccef144, m_CorrespondingSourceObject: {fileID: 6843575828445418654, guid: d3055091a17dc4aa1accf2e33ccef144,
@ -734,7 +605,7 @@ PrefabInstance:
- target: {fileID: 158905820630581587, guid: fdaa7451ab31b477b930076bbc888bab, - target: {fileID: 158905820630581587, guid: fdaa7451ab31b477b930076bbc888bab,
type: 3} type: 3}
propertyPath: m_RootOrder propertyPath: m_RootOrder
value: 6 value: 5
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 158905820630581587, guid: fdaa7451ab31b477b930076bbc888bab, - target: {fileID: 158905820630581587, guid: fdaa7451ab31b477b930076bbc888bab,
type: 3} type: 3}
@ -882,27 +753,27 @@ PrefabInstance:
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 311312839, guid: 4ca131020414f4b1597dac2e1d292d7f, type: 3} - target: {fileID: 311312839, guid: 4ca131020414f4b1597dac2e1d292d7f, type: 3}
propertyPath: m_IsActive propertyPath: m_IsActive
value: 1 value: 0
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 8007755715420797612, guid: 4ca131020414f4b1597dac2e1d292d7f, - target: {fileID: 8007755715420797612, guid: 4ca131020414f4b1597dac2e1d292d7f,
type: 3} type: 3}
propertyPath: m_IsActive propertyPath: m_IsActive
value: 1 value: 0
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 2219516564249810540, guid: 4ca131020414f4b1597dac2e1d292d7f, - target: {fileID: 2219516564249810540, guid: 4ca131020414f4b1597dac2e1d292d7f,
type: 3} type: 3}
propertyPath: m_IsActive propertyPath: m_IsActive
value: 1 value: 0
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 1533625511004221075, guid: 4ca131020414f4b1597dac2e1d292d7f, - target: {fileID: 1533625511004221075, guid: 4ca131020414f4b1597dac2e1d292d7f,
type: 3} type: 3}
propertyPath: m_IsActive propertyPath: m_IsActive
value: 1 value: 0
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 7551096532728223647, guid: 4ca131020414f4b1597dac2e1d292d7f, - target: {fileID: 7551096532728223647, guid: 4ca131020414f4b1597dac2e1d292d7f,
type: 3} type: 3}
propertyPath: m_IsActive propertyPath: m_IsActive
value: 1 value: 0
objectReference: {fileID: 0} objectReference: {fileID: 0}
m_RemovedComponents: [] m_RemovedComponents: []
m_SourcePrefab: {fileID: 100100000, guid: 4ca131020414f4b1597dac2e1d292d7f, type: 3} m_SourcePrefab: {fileID: 100100000, guid: 4ca131020414f4b1597dac2e1d292d7f, type: 3}
@ -1099,7 +970,7 @@ PrefabInstance:
- target: {fileID: 9082059503774285365, guid: fd1ddd924c55b4f9694b98102c91a0a6, - target: {fileID: 9082059503774285365, guid: fd1ddd924c55b4f9694b98102c91a0a6,
type: 3} type: 3}
propertyPath: m_RootOrder propertyPath: m_RootOrder
value: 4 value: 3
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 9082059503774285365, guid: fd1ddd924c55b4f9694b98102c91a0a6, - target: {fileID: 9082059503774285365, guid: fd1ddd924c55b4f9694b98102c91a0a6,
type: 3} type: 3}

View file

@ -1,17 +1,18 @@
using src.Base;
using src.Interfaces; using src.Interfaces;
using src.Managers; using src.Managers;
using UnityEngine; using UnityEngine;
namespace src.Upgrade namespace src.Base
{ {
public class UpgradeBase : GameplayComponent, IUpgrade public class UpgradeBase : GameplayComponent, IUpgrade
{ {
protected GameManager gameManager; protected GameManager GameManager;
private UpgradeManager _upgradeManager;
public void Start() public void Start()
{ {
gameManager = GameManager.Instance; GameManager = GameManager.Instance;
_upgradeManager = UpgradeManager.Instance;
} }
public virtual void PerformUpgrade() public virtual void PerformUpgrade()
@ -23,6 +24,7 @@ namespace src.Upgrade
{ {
if (!other.CompareTag("Player")) return; if (!other.CompareTag("Player")) return;
PerformUpgrade(); PerformUpgrade();
_upgradeManager.ClaimUpgrade(gameObject);
Destroy(gameObject); Destroy(gameObject);
} }
} }

View file

@ -8,6 +8,16 @@ namespace src.Helpers
{ {
public static class DebugHelper public static class DebugHelper
{ {
public static void LogVerbose(string message)
{
#if LOG_VERBOSE
if (Debug.isDebugBuild)
{
Debug.Log(message);
}
#endif
}
public static void LogInfo(string message) public static void LogInfo(string message)
{ {
if (Debug.isDebugBuild) if (Debug.isDebugBuild)

View file

@ -1,5 +1,6 @@
using System.Collections; using System.Collections;
using src.Helpers; using src.Helpers;
using src.Player;
using UnityEngine; using UnityEngine;
namespace src.Managers namespace src.Managers
@ -10,7 +11,11 @@ namespace src.Managers
private LevelManager _levelManager; private LevelManager _levelManager;
private UpgradeManager _upgradeManager; private UpgradeManager _upgradeManager;
private BombsUtilManager _bombsUtilManager; private BombsUtilManager _bombsUtilManager;
private GameObject _preStageUi;
// External Components
public GameObject preStageUiPrefab;
private PlayerController _playerController;
private readonly GameStateManager _gameStateManager = GameStateManager.Instance;
public void Awake() public void Awake()
{ {
@ -26,16 +31,26 @@ namespace src.Managers
/* Don't destroy when reloading the scene */ /* Don't destroy when reloading the scene */
DontDestroyOnLoad(gameObject); DontDestroyOnLoad(gameObject);
// Load inner components
_levelManager = GetComponent<LevelManager>(); _levelManager = GetComponent<LevelManager>();
_upgradeManager = GetComponent<UpgradeManager>(); _upgradeManager = GetComponent<UpgradeManager>();
_bombsUtilManager = BombsUtilManager.Instance; _bombsUtilManager = BombsUtilManager.Instance;
_preStageUi = GameObject.Find("PreStageUI");
// Load external components
_playerController = GameObject.Find("Player").GetComponent<PlayerController>();
} }
public void Start() public void Start()
{ {
_levelManager.InitBoard();
StartLevel();
}
private void StartLevel()
{
_playerController.Respawn();
StartCoroutine(PreInitGame()); StartCoroutine(PreInitGame());
InitGame(); _levelManager.InitLevel();
} }
public UpgradeManager GetUpgradeManager() public UpgradeManager GetUpgradeManager()
@ -47,16 +62,13 @@ namespace src.Managers
{ {
return _bombsUtilManager; return _bombsUtilManager;
} }
private void InitGame()
{
_levelManager.InitLevel();
}
private IEnumerator PreInitGame() private IEnumerator PreInitGame()
{ {
_preStageUi.SetActive(true); var preStageUi = Instantiate(preStageUiPrefab); // Will destroy itself.
preStageUi.SetActive(true);
yield return new WaitForSeconds(1f); yield return new WaitForSeconds(1f);
_preStageUi.SetActive(false); Destroy(preStageUi);
} }
private void Update() private void Update()
@ -75,5 +87,13 @@ namespace src.Managers
ApplicationActions.HandlePauseKey(); ApplicationActions.HandlePauseKey();
} }
} }
public void StartNextLevel()
{
_levelManager.DestroyLevel();
_upgradeManager.DestroyUnclaimedUpgrades();
_gameStateManager.IncreaseLevel();
StartLevel();
}
} }
} }

View file

@ -1,4 +1,5 @@
using System.Collections.Generic; using System;
using System.Collections.Generic;
using src.Base; using src.Base;
using src.Helpers; using src.Helpers;
using src.Wall; using src.Wall;
@ -63,47 +64,49 @@ namespace src.Managers
private const int Rows = 20; private const int Rows = 20;
/* Holds the available positions */ /* Holds the available positions */
private readonly List<Vector3> _freeGridPositions = new List<Vector3>(); private readonly List<Vector3> _freeGridPositionsBoard = new List<Vector3>();
private readonly List<GameObject> _destructibleWalls = new List<GameObject>(); private List<Vector3> _freeGridPositions;
private readonly List<GameObject> _enemies = new List<GameObject>(); private List<GameObject> _destructibleWalls;
private List<GameObject> _enemies;
/* Singletons */
private GameStateManager _gameStateManager = GameStateManager.Instance;
private void SetupUpgrades() /* Modifies walls from _destructibleWalls in order to setup upgrades*/
private void SetupSpawnables()
{ {
var count = _upgradesCount.RandomIntRange(); var count = _upgradesCount.RandomIntRange();
var wallsSize = _destructibleWalls.Count;
_destructibleWalls.ShuffleList();
for (var i = 0; i < count; i++) for (var i = 0; i < count; i++)
{ {
if (_destructibleWalls.Count == 0) if (i > wallsSize - 1)
{ {
DebugHelper.LogWarning("No destructible walls left, cannot spawn upgrade."); DebugHelper.LogWarning("No destructible walls left, cannot spawn upgrade.");
continue; continue;
} }
/* Get the destructible wall script and make it to spawn the upgrade */ /* Get the destructible wall script and make it to spawn the upgrade */
var wall = _destructibleWalls.PopRandom().GetComponent<DestructibleWall>(); var wall = _destructibleWalls[i].GetComponent<DestructibleWall>();
DebugHelper.LogInfo($"Spawned upgrade at: x:{wall.XCoordinate} y:{wall.YCoordinate}"); DebugHelper.LogInfo($"Spawned upgrade at: x:{wall.XCoordinate} y:{wall.YCoordinate}");
wall.SpawnsUpgrade(); wall.SpawnsUpgrade();
} }
}
if (count > wallsSize - 2)
private void SetupExit()
{
if (_destructibleWalls.Count == 0)
{ {
Debug.LogWarning("No destructible walls found, cannot spawn exit!"); Debug.LogWarning("No destructible walls found, cannot spawn exit!");
return; return;
} }
/* Get the destructible wall script and make it to spawn the exit */ var exitWall = _destructibleWalls[count + 1].GetComponent<DestructibleWall>();
var wall = _destructibleWalls.PopRandom().GetComponent<DestructibleWall>(); DebugHelper.LogInfo($"Spawned exit at: x:{exitWall.XCoordinate} y:{exitWall.YCoordinate}");
DebugHelper.LogInfo($"Spawned exit at: x:{wall.XCoordinate} y:{wall.YCoordinate}"); exitWall.SpawnsExit();
wall.SpawnsExit();
} }
/* Place the indestructible tiles on the board and saves the /* Place the indestructible tiles on the board and saves the
* unused positions in a list. */ * unused positions in a list. */
private void InitBoard() public void InitBoard()
{ {
_freeGridPositions.Clear();
/* We want to iterate over the X axis taking into consideration the startPosition's offset */ /* We want to iterate over the X axis taking into consideration the startPosition's offset */
for (var x = startPosition.position.x; x < Columns; x++) for (var x = startPosition.position.x; x < Columns; x++)
{ {
@ -135,7 +138,7 @@ namespace src.Managers
} }
/* Add position to _gridPositions */ /* Add position to _gridPositions */
_freeGridPositions.Add(new Vector3(x, y, 0f)); _freeGridPositionsBoard.Add(new Vector3(x, y, 0f));
} }
} }
} }
@ -143,18 +146,18 @@ namespace src.Managers
/* Randomly places destructible tiles on the level. */ /* Randomly places destructible tiles on the level. */
private void SetupLevelDestructibleWalls() private void SetupLevelDestructibleWalls()
{ {
var numberOfDestructilbeWallsToPlace = _destructibleWallCount.RandomIntRange(); var numberOfWallsRemaining = _destructibleWallCount.RandomIntRange();
List<Vector3> usedPositions = new List<Vector3>(); List<Vector3> usedPositions = new List<Vector3>();
_freeGridPositions.ShuffleList(); _freeGridPositions.ShuffleList();
foreach (var nextPosition in _freeGridPositions) foreach (var nextPosition in _freeGridPositions)
{ {
if (numberOfDestructilbeWallsToPlace == 0) if (numberOfWallsRemaining == 0)
{ {
break; break;
} }
usedPositions.Add(nextPosition); usedPositions.Add(nextPosition);
PlaceDestructibleTile(nextPosition); PlaceDestructibleTile(nextPosition);
numberOfDestructilbeWallsToPlace -= 1; numberOfWallsRemaining -= 1;
} }
foreach (var usedPosition in usedPositions) foreach (var usedPosition in usedPositions)
{ {
@ -164,7 +167,7 @@ namespace src.Managers
private void PlaceDestructibleTile(Vector3 position) private void PlaceDestructibleTile(Vector3 position)
{ {
DebugHelper.LogInfo($"PlaceDestructibleTile: x:{position.x} y:{position.y}"); DebugHelper.LogVerbose($"PlaceDestructibleTile: x:{position.x} y:{position.y}");
var randomWall = destructibleWallPrefabs.ChoseRandom(); var randomWall = destructibleWallPrefabs.ChoseRandom();
var instance = Instantiate(randomWall, position, Quaternion.identity); var instance = Instantiate(randomWall, position, Quaternion.identity);
_destructibleWalls.Add(instance); _destructibleWalls.Add(instance);
@ -173,7 +176,7 @@ namespace src.Managers
private bool PlaceIndestructibleTile(float x, float y) private bool PlaceIndestructibleTile(float x, float y)
{ {
DebugHelper.LogInfo($"PlaceIndestructibleTile: x:{x} y:{y}"); DebugHelper.LogVerbose($"PlaceIndestructibleTile: x:{x} y:{y}");
var absX = Mathf.RoundToInt(x); var absX = Mathf.RoundToInt(x);
var absY = Mathf.RoundToInt(y); var absY = Mathf.RoundToInt(y);
@ -207,7 +210,7 @@ namespace src.Managers
private bool PlaceEnemy(Vector3 position) private bool PlaceEnemy(Vector3 position)
{ {
DebugHelper.LogInfo($"PlaceEnemy: x:{position.x} y:{position.y}"); DebugHelper.LogVerbose($"PlaceEnemy: x:{position.x} y:{position.y}");
var randomEnemy = enemiesPrefab.ChoseRandom(); var randomEnemy = enemiesPrefab.ChoseRandom();
var instance = Instantiate(randomEnemy, position, Quaternion.identity); var instance = Instantiate(randomEnemy, position, Quaternion.identity);
_enemies.Add(instance); _enemies.Add(instance);
@ -218,11 +221,27 @@ namespace src.Managers
/* Initializes the level. */ /* Initializes the level. */
public void InitLevel() public void InitLevel()
{ {
InitBoard(); DebugHelper.LogInfo($"Initializing level: #{_gameStateManager.Level}");
_freeGridPositions = new List<Vector3>(_freeGridPositionsBoard);
_destructibleWalls = new List<GameObject>();
_enemies = new List<GameObject>();
SetupLevelDestructibleWalls(); SetupLevelDestructibleWalls();
SetupLevelEnemies(); SetupLevelEnemies();
SetupExit(); SetupSpawnables();
SetupUpgrades(); }
public void DestroyLevel()
{
foreach (var enemy in _enemies)
{
Destroy(enemy);
}
foreach (var wall in _destructibleWalls)
{
Destroy(wall);
}
DebugHelper.LogInfo("LevelManager: Cleared level!");
} }
} }
} }

View file

@ -1,3 +1,5 @@
using System;
using System.Collections.Generic;
using src.Base; using src.Base;
using src.Helpers; using src.Helpers;
using UnityEngine; using UnityEngine;
@ -6,11 +8,45 @@ namespace src.Managers
{ {
public class UpgradeManager : GameplayComponent public class UpgradeManager : GameplayComponent
{ {
public static UpgradeManager Instance;
private List<GameObject> _unclaimedUpgrades = new List<GameObject>();
public GameObject[] upgradePrefabs; public GameObject[] upgradePrefabs;
private void Awake()
{
if (Instance == null)
{
Instance = this;
}
else if (Instance != null)
{
Destroy(gameObject);
}
}
public GameObject GetUpgradePrefab() public GameObject GetUpgradePrefab()
{ {
return upgradePrefabs.ChoseRandom(); return upgradePrefabs.ChoseRandom();
} }
/* Register unclaimed upgrades so then can be destroyed on level changed or other events. */
public void RegisterUpgradeAsUnclaimed(GameObject instance)
{
_unclaimedUpgrades.Add(instance);
}
public void ClaimUpgrade(GameObject instance)
{
_unclaimedUpgrades.Remove(instance);
}
public void DestroyUnclaimedUpgrades()
{
foreach (var upgrade in _unclaimedUpgrades)
{
Destroy(upgrade);
}
_unclaimedUpgrades = new List<GameObject>();
}
} }
} }

View file

@ -29,9 +29,7 @@ namespace src.Player
movementSpeed = _playerUpgrade.GetMovementSpeed(); movementSpeed = _playerUpgrade.GetMovementSpeed();
_playerUpgrade.PlayerSpeed += IncreaseSpeed; _playerUpgrade.PlayerSpeed += IncreaseSpeed;
/* Always start at the starting point. */
Respawn(); Respawn();
} }
@ -106,9 +104,11 @@ namespace src.Player
#endif #endif
} }
private void Respawn() public void Respawn()
{ {
DebugHelper.LogInfo("Player is respawning!");
transform.SetPositionAndRotation(_respawnPosition.position, Quaternion.identity); transform.SetPositionAndRotation(_respawnPosition.position, Quaternion.identity);
_animator.Play("IdleDown");
} }
public void OnTriggerExit2D(Collider2D other) public void OnTriggerExit2D(Collider2D other)

View file

@ -1,10 +1,11 @@
using src.Base;
using src.Managers; using src.Managers;
using UnityEngine; using UnityEngine;
using UnityEngine.UI; using UnityEngine.UI;
namespace src.UI namespace src.UI
{ {
public class PreLevelLoad : MonoBehaviour public class PreStageUiScript : GameplayComponent
{ {
private readonly GameStateManager _gameStateManager = GameStateManager.Instance; private readonly GameStateManager _gameStateManager = GameStateManager.Instance;
private Text _stageText; private Text _stageText;
@ -12,6 +13,9 @@ namespace src.UI
public void Start() public void Start()
{ {
_stageText = GetComponentInChildren<Text>(); _stageText = GetComponentInChildren<Text>();
#if UNITY_ANDROID || UNITY_IOS
_stageText.fontSize = 50;
#endif
_stageText.text = $"Stage {_gameStateManager.Level}"; _stageText.text = $"Stage {_gameStateManager.Level}";
} }
} }

View file

@ -1,10 +1,12 @@
using src.Base;
namespace src.Upgrade namespace src.Upgrade
{ {
public class BombFlamesUpgrade : UpgradeBase public class BombFlamesUpgrade : UpgradeBase
{ {
public override void PerformUpgrade() public override void PerformUpgrade()
{ {
var bombManager = gameManager.GetBombsUtilManager(); var bombManager = GameManager.GetBombsUtilManager();
bombManager.IncreasePower(); bombManager.IncreasePower();
} }
} }

View file

@ -1,10 +1,12 @@
using src.Base;
namespace src.Upgrade namespace src.Upgrade
{ {
public class BombPlacementUpgrade : UpgradeBase public class BombPlacementUpgrade : UpgradeBase
{ {
public override void PerformUpgrade() public override void PerformUpgrade()
{ {
var bombManager = gameManager.GetBombsUtilManager(); var bombManager = GameManager.GetBombsUtilManager();
bombManager.IncreaseAllowedBombs(); bombManager.IncreaseAllowedBombs();
} }
} }

View file

@ -1,3 +1,4 @@
using src.Base;
using src.Player; using src.Player;
namespace src.Upgrade namespace src.Upgrade

View file

@ -36,7 +36,7 @@ namespace src.Wall
public float XCoordinate => transform.position.x; public float XCoordinate => transform.position.x;
public float YCoordinate => transform.position.y; public float YCoordinate => transform.position.y;
private void BeforeDestroy() private void SpawnSomething()
{ {
var currentPosition = transform.position; var currentPosition = transform.position;
Destroy(GetComponent<SpriteRenderer>()); Destroy(GetComponent<SpriteRenderer>());
@ -50,12 +50,12 @@ namespace src.Wall
{ {
DebugHelper.LogInfo($"Destructible spawned upgrade {transform.position}"); DebugHelper.LogInfo($"Destructible spawned upgrade {transform.position}");
var upgrade = _upgradeManager.GetUpgradePrefab(); var upgrade = _upgradeManager.GetUpgradePrefab();
Instantiate(upgrade, currentPosition, Quaternion.identity); var instance = Instantiate(upgrade, currentPosition, Quaternion.identity);
_upgradeManager.RegisterUpgradeAsUnclaimed(instance);
} }
SwapToPulverise();
} }
private void SwapToPulverise() private void PlayDestroyAnimation()
{ {
// _animator.speed = 10; // _animator.speed = 10;
} }
@ -63,7 +63,8 @@ namespace src.Wall
public void onExplosion() public void onExplosion()
{ {
DebugHelper.LogInfo($"Destructible wall hit by explosion {transform.position}"); DebugHelper.LogInfo($"Destructible wall hit by explosion {transform.position}");
BeforeDestroy(); PlayDestroyAnimation();
SpawnSomething();
Destroy(gameObject); Destroy(gameObject);
} }
} }

View file

@ -0,0 +1,30 @@
using System;
using src.Base;
using src.Managers;
using UnityEngine;
namespace src.Wall
{
public class ExitDoor : GameplayComponent
{
private GameManager _gameManager;
private Collider2D _collider2D;
private void Start()
{
_gameManager = GameManager.Instance;
_collider2D = GetComponent<Collider2D>();
}
/* Trigger the next level and destroy itself. */
private void OnTriggerStay2D(Collider2D other)
{
if (!other.CompareTag("Player"))
{
return;
}
Destroy(gameObject, 1f);
_gameManager.StartNextLevel();
}
}
}

View file

@ -0,0 +1,3 @@
fileFormatVersion: 2
guid: d5d5847c8fef4a91bafe88cc2ccf43ec
timeCreated: 1563024607

Binary file not shown.

Before

Width:  |  Height:  |  Size: 496 B

After

Width:  |  Height:  |  Size: 442 B