From 391af7efb2ba8d8a3575fa96972b0e9217be5fc8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Denis=20Nu=C8=9Biu?= Date: Sun, 28 Jul 2019 19:31:01 +0300 Subject: [PATCH 1/2] Extract Count into Helper class --- Assets/Scripts/src/Helpers/Count.cs | 21 +++++++++++++++++++++ Assets/Scripts/src/Helpers/Count.cs.meta | 3 +++ Assets/Scripts/src/Managers/LevelManager.cs | 17 ----------------- 3 files changed, 24 insertions(+), 17 deletions(-) create mode 100644 Assets/Scripts/src/Helpers/Count.cs create mode 100644 Assets/Scripts/src/Helpers/Count.cs.meta diff --git a/Assets/Scripts/src/Helpers/Count.cs b/Assets/Scripts/src/Helpers/Count.cs new file mode 100644 index 0000000..d044c06 --- /dev/null +++ b/Assets/Scripts/src/Helpers/Count.cs @@ -0,0 +1,21 @@ +using UnityEngine; + +namespace src.Helpers +{ + public class Count + { + private readonly int _min; + private readonly int _max; + + public Count(int min, int max) + { + _min = min; + _max = max; + } + + public int RandomIntRange() + { + return Mathf.FloorToInt(Random.Range(_min, _max)); + } + } +} \ No newline at end of file diff --git a/Assets/Scripts/src/Helpers/Count.cs.meta b/Assets/Scripts/src/Helpers/Count.cs.meta new file mode 100644 index 0000000..a17b6b6 --- /dev/null +++ b/Assets/Scripts/src/Helpers/Count.cs.meta @@ -0,0 +1,3 @@ +fileFormatVersion: 2 +guid: a2787d1c344641e3a5509f691156eab7 +timeCreated: 1564331210 \ No newline at end of file diff --git a/Assets/Scripts/src/Managers/LevelManager.cs b/Assets/Scripts/src/Managers/LevelManager.cs index ab9e24e..5976480 100644 --- a/Assets/Scripts/src/Managers/LevelManager.cs +++ b/Assets/Scripts/src/Managers/LevelManager.cs @@ -10,23 +10,6 @@ namespace src.Managers { public class LevelManager : GameplayComponent { - public class Count - { - private readonly int _min; - private readonly int _max; - - public Count(int min, int max) - { - _min = min; - _max = max; - } - - public int RandomIntRange() - { - return Mathf.FloorToInt(Random.Range(_min, _max)); - } - } - public Count DestructibleWallCount { get => _destructibleWallCount; From de3ea0e2947726df459e132ec981b271694c5b5b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Denis=20Nu=C8=9Biu?= Date: Sun, 28 Jul 2019 21:40:48 +0300 Subject: [PATCH 2/2] Implement LevelData progression --- ...all_overlap.prefab.meta => Resources.meta} | 5 +- Assets/DevMocks/Resources/DevMocks.meta | 8 + .../DevMocks}/BombsUpgrade.prefab | 0 .../DevMocks}/BombsUpgrade.prefab.meta | 0 .../{ => Resources/DevMocks}/Dumb.prefab | 0 .../{ => Resources/DevMocks}/Dumb.prefab.meta | 0 .../{ => Resources/DevMocks}/Dumber.prefab | 0 .../DevMocks}/Dumber.prefab.meta | 0 .../DevMocks}/FlameUpgrade.prefab | 0 .../DevMocks}/FlameUpgrade.prefab.meta | 0 .../DevMocks}/SpeedUpgrade.prefab | 0 .../DevMocks}/SpeedUpgrade.prefab.meta | 0 .../DevMocks}/TestUpgrade.prefab | 0 .../DevMocks}/TestUpgrade.prefab.meta | 0 .../DevMocks}/exitDoorPrefab.prefab | 0 .../DevMocks}/exitDoorPrefab.prefab.meta | 0 .../bman_destructible_wall_overlap.prefab | 174 ------------------ Assets/DevMocks/bomb1.png | Bin 373 -> 0 bytes Assets/DevMocks/bomb1.png.meta | 99 ---------- Assets/{Prefabs.meta => Resources.meta} | 0 Assets/{Prefabs => Resources}/.gitkeep | 0 Assets/{Prefabs => Resources}/Ammo.meta | 0 .../{Prefabs => Resources}/Ammo/Bomb.prefab | 0 .../Ammo/Bomb.prefab.meta | 0 .../Ammo/BombSpawner.prefab | 0 .../Ammo/BombSpawner.prefab.meta | 0 .../Ammo/Explosion.prefab | 0 .../Ammo/Explosion.prefab.meta | 0 Assets/{Prefabs => Resources}/Camera.meta | 0 .../Camera/CameraConfiner.prefab | 0 .../Camera/CameraConfiner.prefab.meta | 0 .../Camera/Main Camera.prefab | 0 .../Camera/Main Camera.prefab.meta | 0 .../Camera/VCAM1.prefab | 0 .../Camera/VCAM1.prefab.meta | 0 Assets/{Prefabs => Resources}/Grid.prefab | 0 .../{Prefabs => Resources}/Grid.prefab.meta | 0 Assets/{Prefabs => Resources}/Managers.meta | 0 .../Managers/GameManager.prefab | 10 - .../Managers/GameManager.prefab.meta | 0 Assets/{Prefabs => Resources}/Player.prefab | 0 .../{Prefabs => Resources}/Player.prefab.meta | 0 .../RespawnPosition.prefab | 0 .../RespawnPosition.prefab.meta | 0 Assets/{Prefabs => Resources}/UI.meta | 0 .../UI/MobileInputControls.prefab | 0 .../UI/MobileInputControls.prefab.meta | 0 .../UI/PreStageUI.prefab | 0 .../UI/PreStageUI.prefab.meta | 0 Assets/{Prefabs => Resources}/Walls.meta | 0 .../Walls/destructible_high_snow.prefab | 0 .../Walls/destructible_high_snow.prefab.meta | 0 .../Walls/destructible_snow.prefab | 0 .../Walls/destructible_snow.prefab.meta | 0 .../Walls/indestructible_crate.prefab | 0 .../Walls/indestructible_crate.prefab.meta | 0 Assets/Scripts/src/Helpers/PrefabAtlas.cs | 27 +++ .../Scripts/src/Helpers/PrefabAtlas.cs.meta | 3 + Assets/Scripts/src/Level.meta | 3 + Assets/Scripts/src/Level/LevelData.cs | 55 ++++++ Assets/Scripts/src/Level/LevelData.cs.meta | 3 + .../src/{Managers => Level}/LevelManager.cs | 26 ++- .../{Managers => Level}/LevelManager.cs.meta | 0 Assets/Scripts/src/Managers/GameManager.cs | 7 + Assets/Scripts/src/Managers/UpgradeManager.cs | 10 +- 65 files changed, 135 insertions(+), 295 deletions(-) rename Assets/DevMocks/{bman_destructible_wall_overlap.prefab.meta => Resources.meta} (57%) create mode 100644 Assets/DevMocks/Resources/DevMocks.meta rename Assets/DevMocks/{ => Resources/DevMocks}/BombsUpgrade.prefab (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/BombsUpgrade.prefab.meta (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/Dumb.prefab (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/Dumb.prefab.meta (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/Dumber.prefab (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/Dumber.prefab.meta (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/FlameUpgrade.prefab (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/FlameUpgrade.prefab.meta (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/SpeedUpgrade.prefab (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/SpeedUpgrade.prefab.meta (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/TestUpgrade.prefab (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/TestUpgrade.prefab.meta (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/exitDoorPrefab.prefab (100%) rename Assets/DevMocks/{ => Resources/DevMocks}/exitDoorPrefab.prefab.meta (100%) delete mode 100644 Assets/DevMocks/bman_destructible_wall_overlap.prefab delete mode 100644 Assets/DevMocks/bomb1.png delete mode 100644 Assets/DevMocks/bomb1.png.meta rename Assets/{Prefabs.meta => Resources.meta} (100%) rename Assets/{Prefabs => Resources}/.gitkeep (100%) rename Assets/{Prefabs => Resources}/Ammo.meta (100%) rename Assets/{Prefabs => Resources}/Ammo/Bomb.prefab (100%) rename Assets/{Prefabs => Resources}/Ammo/Bomb.prefab.meta (100%) rename Assets/{Prefabs => Resources}/Ammo/BombSpawner.prefab (100%) rename Assets/{Prefabs => Resources}/Ammo/BombSpawner.prefab.meta (100%) rename Assets/{Prefabs => Resources}/Ammo/Explosion.prefab (100%) rename Assets/{Prefabs => Resources}/Ammo/Explosion.prefab.meta (100%) rename Assets/{Prefabs => Resources}/Camera.meta (100%) rename Assets/{Prefabs => Resources}/Camera/CameraConfiner.prefab (100%) rename Assets/{Prefabs => Resources}/Camera/CameraConfiner.prefab.meta (100%) rename Assets/{Prefabs => Resources}/Camera/Main Camera.prefab (100%) rename Assets/{Prefabs => Resources}/Camera/Main Camera.prefab.meta (100%) rename Assets/{Prefabs => Resources}/Camera/VCAM1.prefab (100%) rename Assets/{Prefabs => Resources}/Camera/VCAM1.prefab.meta (100%) rename Assets/{Prefabs => Resources}/Grid.prefab (100%) rename Assets/{Prefabs => Resources}/Grid.prefab.meta (100%) rename Assets/{Prefabs => Resources}/Managers.meta (100%) rename Assets/{Prefabs => Resources}/Managers/GameManager.prefab (79%) rename Assets/{Prefabs => Resources}/Managers/GameManager.prefab.meta (100%) rename Assets/{Prefabs => Resources}/Player.prefab (100%) rename Assets/{Prefabs => Resources}/Player.prefab.meta (100%) rename Assets/{Prefabs => Resources}/RespawnPosition.prefab (100%) rename Assets/{Prefabs => Resources}/RespawnPosition.prefab.meta (100%) rename Assets/{Prefabs => Resources}/UI.meta (100%) rename Assets/{Prefabs => Resources}/UI/MobileInputControls.prefab (100%) rename Assets/{Prefabs => Resources}/UI/MobileInputControls.prefab.meta (100%) rename Assets/{Prefabs => Resources}/UI/PreStageUI.prefab (100%) rename Assets/{Prefabs => Resources}/UI/PreStageUI.prefab.meta (100%) rename Assets/{Prefabs => Resources}/Walls.meta (100%) rename Assets/{Prefabs => Resources}/Walls/destructible_high_snow.prefab (100%) rename Assets/{Prefabs => Resources}/Walls/destructible_high_snow.prefab.meta (100%) rename Assets/{Prefabs => Resources}/Walls/destructible_snow.prefab (100%) rename Assets/{Prefabs => Resources}/Walls/destructible_snow.prefab.meta (100%) rename Assets/{Prefabs => Resources}/Walls/indestructible_crate.prefab (100%) rename Assets/{Prefabs => Resources}/Walls/indestructible_crate.prefab.meta (100%) create mode 100644 Assets/Scripts/src/Helpers/PrefabAtlas.cs create mode 100644 Assets/Scripts/src/Helpers/PrefabAtlas.cs.meta create mode 100644 Assets/Scripts/src/Level.meta create mode 100644 Assets/Scripts/src/Level/LevelData.cs create mode 100644 Assets/Scripts/src/Level/LevelData.cs.meta rename Assets/Scripts/src/{Managers => Level}/LevelManager.cs (88%) rename Assets/Scripts/src/{Managers => Level}/LevelManager.cs.meta (100%) diff --git a/Assets/DevMocks/bman_destructible_wall_overlap.prefab.meta b/Assets/DevMocks/Resources.meta similarity index 57% rename from Assets/DevMocks/bman_destructible_wall_overlap.prefab.meta rename to Assets/DevMocks/Resources.meta index 457104a..851c072 100644 --- a/Assets/DevMocks/bman_destructible_wall_overlap.prefab.meta +++ b/Assets/DevMocks/Resources.meta @@ -1,6 +1,7 @@ fileFormatVersion: 2 -guid: b7e3d2e65cd1840089ccdb548a440e87 -PrefabImporter: +guid: 9707b5b706df4460bbc6cda55152ee98 +folderAsset: yes +DefaultImporter: externalObjects: {} userData: assetBundleName: diff --git a/Assets/DevMocks/Resources/DevMocks.meta b/Assets/DevMocks/Resources/DevMocks.meta new file mode 100644 index 0000000..f951bb3 --- /dev/null +++ b/Assets/DevMocks/Resources/DevMocks.meta @@ -0,0 +1,8 @@ +fileFormatVersion: 2 +guid: f1b9b3e206dfd47df84c2567ac76022b +folderAsset: yes +DefaultImporter: + externalObjects: {} + userData: + assetBundleName: + assetBundleVariant: diff --git a/Assets/DevMocks/BombsUpgrade.prefab b/Assets/DevMocks/Resources/DevMocks/BombsUpgrade.prefab similarity index 100% rename from Assets/DevMocks/BombsUpgrade.prefab rename to Assets/DevMocks/Resources/DevMocks/BombsUpgrade.prefab diff --git a/Assets/DevMocks/BombsUpgrade.prefab.meta b/Assets/DevMocks/Resources/DevMocks/BombsUpgrade.prefab.meta similarity index 100% rename from Assets/DevMocks/BombsUpgrade.prefab.meta rename to Assets/DevMocks/Resources/DevMocks/BombsUpgrade.prefab.meta diff --git a/Assets/DevMocks/Dumb.prefab b/Assets/DevMocks/Resources/DevMocks/Dumb.prefab similarity index 100% rename from Assets/DevMocks/Dumb.prefab rename to Assets/DevMocks/Resources/DevMocks/Dumb.prefab diff --git a/Assets/DevMocks/Dumb.prefab.meta b/Assets/DevMocks/Resources/DevMocks/Dumb.prefab.meta similarity index 100% rename from Assets/DevMocks/Dumb.prefab.meta rename to Assets/DevMocks/Resources/DevMocks/Dumb.prefab.meta diff --git a/Assets/DevMocks/Dumber.prefab b/Assets/DevMocks/Resources/DevMocks/Dumber.prefab similarity index 100% rename from Assets/DevMocks/Dumber.prefab rename to Assets/DevMocks/Resources/DevMocks/Dumber.prefab diff --git a/Assets/DevMocks/Dumber.prefab.meta b/Assets/DevMocks/Resources/DevMocks/Dumber.prefab.meta similarity index 100% rename from Assets/DevMocks/Dumber.prefab.meta rename to Assets/DevMocks/Resources/DevMocks/Dumber.prefab.meta diff --git a/Assets/DevMocks/FlameUpgrade.prefab b/Assets/DevMocks/Resources/DevMocks/FlameUpgrade.prefab similarity index 100% rename from Assets/DevMocks/FlameUpgrade.prefab rename to Assets/DevMocks/Resources/DevMocks/FlameUpgrade.prefab diff --git a/Assets/DevMocks/FlameUpgrade.prefab.meta b/Assets/DevMocks/Resources/DevMocks/FlameUpgrade.prefab.meta similarity index 100% rename from Assets/DevMocks/FlameUpgrade.prefab.meta rename to Assets/DevMocks/Resources/DevMocks/FlameUpgrade.prefab.meta diff --git a/Assets/DevMocks/SpeedUpgrade.prefab b/Assets/DevMocks/Resources/DevMocks/SpeedUpgrade.prefab similarity index 100% rename from Assets/DevMocks/SpeedUpgrade.prefab rename to Assets/DevMocks/Resources/DevMocks/SpeedUpgrade.prefab diff --git a/Assets/DevMocks/SpeedUpgrade.prefab.meta b/Assets/DevMocks/Resources/DevMocks/SpeedUpgrade.prefab.meta similarity index 100% rename from Assets/DevMocks/SpeedUpgrade.prefab.meta rename to Assets/DevMocks/Resources/DevMocks/SpeedUpgrade.prefab.meta diff --git a/Assets/DevMocks/TestUpgrade.prefab b/Assets/DevMocks/Resources/DevMocks/TestUpgrade.prefab similarity index 100% rename from Assets/DevMocks/TestUpgrade.prefab rename to Assets/DevMocks/Resources/DevMocks/TestUpgrade.prefab diff --git a/Assets/DevMocks/TestUpgrade.prefab.meta b/Assets/DevMocks/Resources/DevMocks/TestUpgrade.prefab.meta similarity index 100% rename from Assets/DevMocks/TestUpgrade.prefab.meta rename to Assets/DevMocks/Resources/DevMocks/TestUpgrade.prefab.meta diff --git a/Assets/DevMocks/exitDoorPrefab.prefab b/Assets/DevMocks/Resources/DevMocks/exitDoorPrefab.prefab similarity index 100% rename from Assets/DevMocks/exitDoorPrefab.prefab rename to Assets/DevMocks/Resources/DevMocks/exitDoorPrefab.prefab diff --git a/Assets/DevMocks/exitDoorPrefab.prefab.meta b/Assets/DevMocks/Resources/DevMocks/exitDoorPrefab.prefab.meta similarity index 100% rename from Assets/DevMocks/exitDoorPrefab.prefab.meta rename to Assets/DevMocks/Resources/DevMocks/exitDoorPrefab.prefab.meta diff --git a/Assets/DevMocks/bman_destructible_wall_overlap.prefab b/Assets/DevMocks/bman_destructible_wall_overlap.prefab deleted file mode 100644 index 2384564..0000000 --- a/Assets/DevMocks/bman_destructible_wall_overlap.prefab +++ /dev/null @@ -1,174 +0,0 @@ -%YAML 1.1 -%TAG !u! tag:unity3d.com,2011: ---- !u!1 &2899889047683555164 -GameObject: - m_ObjectHideFlags: 0 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - serializedVersion: 6 - m_Component: - - component: {fileID: 6637306046394798484} - - component: {fileID: 2675033481556760561} - - component: {fileID: 5245497846486186022} - - component: {fileID: 7475857772367562264} - m_Layer: 8 - m_Name: bman_destructible_wall2exp - m_TagString: Untagged - m_Icon: {fileID: 0} - m_NavMeshLayer: 0 - m_StaticEditorFlags: 0 - m_IsActive: 1 ---- !u!4 &6637306046394798484 -Transform: - m_ObjectHideFlags: 0 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 2899889047683555164} - m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} - m_LocalPosition: {x: 3.96, y: -1.07, z: 0} - m_LocalScale: {x: 1, y: 1, z: 0} - m_Children: - - {fileID: 1878121175747991472} - m_Father: {fileID: 0} - m_RootOrder: 0 - m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} ---- !u!50 &2675033481556760561 -Rigidbody2D: - serializedVersion: 4 - m_ObjectHideFlags: 0 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 2899889047683555164} - m_BodyType: 2 - m_Simulated: 1 - m_UseFullKinematicContacts: 0 - m_UseAutoMass: 0 - m_Mass: 1 - m_LinearDrag: 0 - m_AngularDrag: 0.05 - m_GravityScale: 1 - m_Material: {fileID: 0} - m_Interpolate: 0 - m_SleepingMode: 1 - m_CollisionDetection: 0 - m_Constraints: 0 ---- !u!61 &5245497846486186022 -BoxCollider2D: - m_ObjectHideFlags: 0 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 2899889047683555164} - m_Enabled: 1 - m_Density: 1 - m_Material: {fileID: 6200000, guid: dc8eb6133faaf45f6820487d0d28b47f, type: 2} - m_IsTrigger: 0 - m_UsedByEffector: 0 - m_UsedByComposite: 0 - m_Offset: {x: 0.51631534, y: 0.55982304} - m_SpriteTilingProperty: - border: {x: 0, y: 0, z: 0, w: 0} - pivot: {x: 0, y: 0} - oldSize: {x: 0, y: 0} - newSize: {x: 0, y: 0} - adaptiveTilingThreshold: 0 - drawMode: 0 - adaptiveTiling: 0 - m_AutoTiling: 0 - serializedVersion: 2 - m_Size: {x: 0.9673693, y: 0.98912334} - m_EdgeRadius: 0 ---- !u!114 &7475857772367562264 -MonoBehaviour: - m_ObjectHideFlags: 0 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 2899889047683555164} - m_Enabled: 1 - m_EditorHideFlags: 0 - m_Script: {fileID: 11500000, guid: b30e7124fcdf4e1f92fc7dd42d8c7298, type: 3} - m_Name: - m_EditorClassIdentifier: ---- !u!1 &5530905156088972342 -GameObject: - m_ObjectHideFlags: 0 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - serializedVersion: 6 - m_Component: - - component: {fileID: 1878121175747991472} - - component: {fileID: 2525467942923604880} - m_Layer: 0 - m_Name: Sprite - m_TagString: Untagged - m_Icon: {fileID: 0} - m_NavMeshLayer: 0 - m_StaticEditorFlags: 0 - m_IsActive: 1 ---- !u!4 &1878121175747991472 -Transform: - m_ObjectHideFlags: 0 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 5530905156088972342} - m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} - m_LocalPosition: {x: -0.34, y: -0.15, z: 0} - m_LocalScale: {x: 1.724866, y: 1.7598268, z: 1} - m_Children: [] - m_Father: {fileID: 6637306046394798484} - m_RootOrder: 0 - m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} ---- !u!212 &2525467942923604880 -SpriteRenderer: - m_ObjectHideFlags: 0 - m_CorrespondingSourceObject: {fileID: 0} - m_PrefabInstance: {fileID: 0} - m_PrefabAsset: {fileID: 0} - m_GameObject: {fileID: 5530905156088972342} - m_Enabled: 1 - m_CastShadows: 0 - m_ReceiveShadows: 0 - m_DynamicOccludee: 1 - m_MotionVectors: 1 - m_LightProbeUsage: 1 - m_ReflectionProbeUsage: 1 - m_RenderingLayerMask: 1 - m_RendererPriority: 0 - m_Materials: - - {fileID: 10754, guid: 0000000000000000f000000000000000, type: 0} - m_StaticBatchInfo: - firstSubMesh: 0 - subMeshCount: 0 - m_StaticBatchRoot: {fileID: 0} - m_ProbeAnchor: {fileID: 0} - m_LightProbeVolumeOverride: {fileID: 0} - m_ScaleInLightmap: 1 - m_PreserveUVs: 0 - m_IgnoreNormalsForChartDetection: 0 - m_ImportantGI: 0 - m_StitchLightmapSeams: 0 - m_SelectedEditorRenderState: 0 - m_MinimumChartSize: 4 - m_AutoUVMaxDistance: 0.5 - m_AutoUVMaxAngle: 89 - m_LightmapParameters: {fileID: 0} - m_SortingLayerID: 0 - m_SortingLayer: 0 - m_SortingOrder: 0 - m_Sprite: {fileID: 21300000, guid: 2c89c5592e07249fd8d1f49c0e5a125e, type: 3} - m_Color: {r: 1, g: 1, b: 1, a: 1} - m_FlipX: 0 - m_FlipY: 0 - m_DrawMode: 0 - m_Size: {x: 1, y: 1} - m_AdaptiveModeThreshold: 0.5 - m_SpriteTileMode: 0 - m_WasSpriteAssigned: 1 - m_MaskInteraction: 0 - m_SpriteSortPoint: 0 diff --git a/Assets/DevMocks/bomb1.png b/Assets/DevMocks/bomb1.png deleted file mode 100644 index e5ab1594d25505f5cf9c44cc37ef41b0762873d1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 373 zcmeAS@N?(olHy`uVBq!ia0vp^3LwnE1|*BCs=fdz#^NA%Cx&(BWL^T<`kpS1ArY;~ z2@b+Te1P?LL)5&4#jYEl_B_eTS()7)9d|jzbDO0~ zwu$Md_Gldqg+8V2+4prOomGx%p44=*o(%{R6*G58>|#Dq$l=&((4EL|lkta);~M7~ z9vfw(EB-%JJ^Y(rf8(j0mP-Y%^j~iMq2tcaDxsk6^`VVnB}2H!1LlZWH=hfSxqyOZ z?HdF(b;LO2WF+k9lDL1EVPSv+`||U-M>g~?GWqcBZgAW7_w$01Se7x@{rTZE&3VN$ z1}_=MKIZ~AM$0~h_Ass+oP$vknudHjEqf4;f1~I=^JjjZWd4wd!Vy;r6kvm zn)3$?W;i!AHd-xgIRBkR)?uYGN2K2r<_WS+YnVGW&PZWDz_9OBmk7`&3|lNq_dXJS R90CkS22WQ%mvv4FO#ovLlY0OF diff --git a/Assets/DevMocks/bomb1.png.meta b/Assets/DevMocks/bomb1.png.meta deleted file mode 100644 index 3a79d29..0000000 --- a/Assets/DevMocks/bomb1.png.meta +++ /dev/null @@ -1,99 +0,0 @@ -fileFormatVersion: 2 -guid: 98d73a0d91287d34ea2ede695d239f4f -TextureImporter: - fileIDToRecycleName: {} - externalObjects: {} - serializedVersion: 9 - mipmaps: - mipMapMode: 0 - enableMipMap: 0 - sRGBTexture: 1 - linearTexture: 0 - fadeOut: 0 - borderMipMap: 0 - mipMapsPreserveCoverage: 0 - alphaTestReferenceValue: 0.5 - mipMapFadeDistanceStart: 1 - mipMapFadeDistanceEnd: 3 - bumpmap: - convertToNormalMap: 0 - externalNormalMap: 0 - heightScale: 0.25 - normalMapFilter: 0 - isReadable: 0 - streamingMipmaps: 0 - streamingMipmapsPriority: 0 - grayScaleToAlpha: 0 - generateCubemap: 6 - cubemapConvolution: 0 - seamlessCubemap: 0 - textureFormat: 1 - maxTextureSize: 2048 - textureSettings: - serializedVersion: 2 - filterMode: -1 - aniso: -1 - mipBias: -100 - wrapU: 1 - wrapV: 1 - wrapW: 1 - nPOTScale: 0 - lightmap: 0 - compressionQuality: 50 - spriteMode: 1 - spriteExtrude: 1 - spriteMeshType: 1 - alignment: 6 - spritePivot: {x: 0.5, y: 0.5} - spritePixelsToUnits: 32 - spriteBorder: {x: 0, y: 0, z: 0, w: 0} - spriteGenerateFallbackPhysicsShape: 1 - alphaUsage: 1 - alphaIsTransparency: 1 - spriteTessellationDetail: -1 - textureType: 8 - textureShape: 1 - singleChannelComponent: 0 - maxTextureSizeSet: 0 - compressionQualitySet: 0 - textureFormatSet: 0 - platformSettings: - - serializedVersion: 2 - buildTarget: DefaultTexturePlatform - maxTextureSize: 2048 - resizeAlgorithm: 0 - textureFormat: -1 - textureCompression: 1 - compressionQuality: 50 - crunchedCompression: 0 - allowsAlphaSplitting: 0 - overridden: 0 - androidETC2FallbackOverride: 0 - - serializedVersion: 2 - buildTarget: Standalone - maxTextureSize: 2048 - resizeAlgorithm: 0 - textureFormat: -1 - textureCompression: 1 - compressionQuality: 50 - crunchedCompression: 0 - allowsAlphaSplitting: 0 - overridden: 0 - androidETC2FallbackOverride: 0 - spriteSheet: - serializedVersion: 2 - sprites: [] - outline: [] - physicsShape: [] - bones: [] - spriteID: 62b1ac1cb6a320140ac9bd5e9b091023 - vertices: [] - indices: - edges: [] - weights: [] - spritePackingTag: - pSDRemoveMatte: 0 - pSDShowRemoveMatteOption: 0 - userData: - assetBundleName: - assetBundleVariant: diff --git a/Assets/Prefabs.meta b/Assets/Resources.meta similarity index 100% rename from Assets/Prefabs.meta rename to Assets/Resources.meta diff --git a/Assets/Prefabs/.gitkeep b/Assets/Resources/.gitkeep similarity index 100% rename from Assets/Prefabs/.gitkeep rename to Assets/Resources/.gitkeep diff --git a/Assets/Prefabs/Ammo.meta b/Assets/Resources/Ammo.meta similarity index 100% rename from Assets/Prefabs/Ammo.meta rename to Assets/Resources/Ammo.meta diff --git a/Assets/Prefabs/Ammo/Bomb.prefab b/Assets/Resources/Ammo/Bomb.prefab similarity index 100% rename from Assets/Prefabs/Ammo/Bomb.prefab rename to Assets/Resources/Ammo/Bomb.prefab diff --git a/Assets/Prefabs/Ammo/Bomb.prefab.meta b/Assets/Resources/Ammo/Bomb.prefab.meta similarity index 100% rename from Assets/Prefabs/Ammo/Bomb.prefab.meta rename to Assets/Resources/Ammo/Bomb.prefab.meta diff --git a/Assets/Prefabs/Ammo/BombSpawner.prefab b/Assets/Resources/Ammo/BombSpawner.prefab similarity index 100% rename from Assets/Prefabs/Ammo/BombSpawner.prefab rename to Assets/Resources/Ammo/BombSpawner.prefab diff --git a/Assets/Prefabs/Ammo/BombSpawner.prefab.meta b/Assets/Resources/Ammo/BombSpawner.prefab.meta similarity index 100% rename from Assets/Prefabs/Ammo/BombSpawner.prefab.meta rename to Assets/Resources/Ammo/BombSpawner.prefab.meta diff --git a/Assets/Prefabs/Ammo/Explosion.prefab b/Assets/Resources/Ammo/Explosion.prefab similarity index 100% rename from Assets/Prefabs/Ammo/Explosion.prefab rename to Assets/Resources/Ammo/Explosion.prefab diff --git a/Assets/Prefabs/Ammo/Explosion.prefab.meta b/Assets/Resources/Ammo/Explosion.prefab.meta similarity index 100% rename from Assets/Prefabs/Ammo/Explosion.prefab.meta rename to Assets/Resources/Ammo/Explosion.prefab.meta diff --git a/Assets/Prefabs/Camera.meta b/Assets/Resources/Camera.meta similarity index 100% rename from Assets/Prefabs/Camera.meta rename to Assets/Resources/Camera.meta diff --git a/Assets/Prefabs/Camera/CameraConfiner.prefab b/Assets/Resources/Camera/CameraConfiner.prefab similarity index 100% rename from Assets/Prefabs/Camera/CameraConfiner.prefab rename to Assets/Resources/Camera/CameraConfiner.prefab diff --git a/Assets/Prefabs/Camera/CameraConfiner.prefab.meta b/Assets/Resources/Camera/CameraConfiner.prefab.meta similarity index 100% rename from Assets/Prefabs/Camera/CameraConfiner.prefab.meta rename to Assets/Resources/Camera/CameraConfiner.prefab.meta diff --git a/Assets/Prefabs/Camera/Main Camera.prefab b/Assets/Resources/Camera/Main Camera.prefab similarity index 100% rename from Assets/Prefabs/Camera/Main Camera.prefab rename to Assets/Resources/Camera/Main Camera.prefab diff --git a/Assets/Prefabs/Camera/Main Camera.prefab.meta b/Assets/Resources/Camera/Main Camera.prefab.meta similarity index 100% rename from Assets/Prefabs/Camera/Main Camera.prefab.meta rename to Assets/Resources/Camera/Main Camera.prefab.meta diff --git a/Assets/Prefabs/Camera/VCAM1.prefab b/Assets/Resources/Camera/VCAM1.prefab similarity index 100% rename from Assets/Prefabs/Camera/VCAM1.prefab rename to Assets/Resources/Camera/VCAM1.prefab diff --git a/Assets/Prefabs/Camera/VCAM1.prefab.meta b/Assets/Resources/Camera/VCAM1.prefab.meta similarity index 100% rename from Assets/Prefabs/Camera/VCAM1.prefab.meta rename to Assets/Resources/Camera/VCAM1.prefab.meta diff --git a/Assets/Prefabs/Grid.prefab b/Assets/Resources/Grid.prefab similarity index 100% rename from Assets/Prefabs/Grid.prefab rename to Assets/Resources/Grid.prefab diff --git a/Assets/Prefabs/Grid.prefab.meta b/Assets/Resources/Grid.prefab.meta similarity index 100% rename from Assets/Prefabs/Grid.prefab.meta rename to Assets/Resources/Grid.prefab.meta diff --git a/Assets/Prefabs/Managers.meta b/Assets/Resources/Managers.meta similarity index 100% rename from Assets/Prefabs/Managers.meta rename to Assets/Resources/Managers.meta diff --git a/Assets/Prefabs/Managers/GameManager.prefab b/Assets/Resources/Managers/GameManager.prefab similarity index 79% rename from Assets/Prefabs/Managers/GameManager.prefab rename to Assets/Resources/Managers/GameManager.prefab index c1c56c7..5223a31 100644 --- a/Assets/Prefabs/Managers/GameManager.prefab +++ b/Assets/Resources/Managers/GameManager.prefab @@ -63,12 +63,6 @@ MonoBehaviour: startPosition: {fileID: 0} indestructibleWallPrefab: {fileID: 5996206011854593075, guid: 84b92ac1e96d940bda97d1b1125887d7, type: 3} - destructibleWallPrefabs: - - {fileID: 4177940729222266681, guid: da559e681f8d34d58bb5f3457045664a, type: 3} - - {fileID: 8729402555587492036, guid: 7e54504f1e1de4334be2e6a115b838c2, type: 3} - enemiesPrefab: - - {fileID: 4346602752014574748, guid: e719de70e335f4e49ae40cc6731309d4, type: 3} - - {fileID: 7795087027144463245, guid: fe8fb4e4a7e127648b306469b723d81e, type: 3} --- !u!114 &6316647355651322741 MonoBehaviour: m_ObjectHideFlags: 0 @@ -81,7 +75,3 @@ MonoBehaviour: m_Script: {fileID: 11500000, guid: e64481d2e18e4b6ca4f22926a5061450, type: 3} m_Name: m_EditorClassIdentifier: - upgradePrefabs: - - {fileID: 4242909486338491383, guid: c0bd5085d71f847b19df326a2fbcf069, type: 3} - - {fileID: 7385886653159515755, guid: ba0e1f9d79914426ba805d871bcad311, type: 3} - - {fileID: 2377911311221568072, guid: 6d6a8eb6810cd4483a761f7b02fff67f, type: 3} diff --git a/Assets/Prefabs/Managers/GameManager.prefab.meta b/Assets/Resources/Managers/GameManager.prefab.meta similarity index 100% rename from Assets/Prefabs/Managers/GameManager.prefab.meta rename to Assets/Resources/Managers/GameManager.prefab.meta diff --git a/Assets/Prefabs/Player.prefab b/Assets/Resources/Player.prefab similarity index 100% rename from Assets/Prefabs/Player.prefab rename to Assets/Resources/Player.prefab diff --git a/Assets/Prefabs/Player.prefab.meta b/Assets/Resources/Player.prefab.meta similarity index 100% rename from Assets/Prefabs/Player.prefab.meta rename to Assets/Resources/Player.prefab.meta diff --git a/Assets/Prefabs/RespawnPosition.prefab b/Assets/Resources/RespawnPosition.prefab similarity index 100% rename from Assets/Prefabs/RespawnPosition.prefab rename to Assets/Resources/RespawnPosition.prefab diff --git a/Assets/Prefabs/RespawnPosition.prefab.meta b/Assets/Resources/RespawnPosition.prefab.meta similarity index 100% rename from Assets/Prefabs/RespawnPosition.prefab.meta rename to Assets/Resources/RespawnPosition.prefab.meta diff --git a/Assets/Prefabs/UI.meta b/Assets/Resources/UI.meta similarity index 100% rename from Assets/Prefabs/UI.meta rename to Assets/Resources/UI.meta diff --git a/Assets/Prefabs/UI/MobileInputControls.prefab b/Assets/Resources/UI/MobileInputControls.prefab similarity index 100% rename from Assets/Prefabs/UI/MobileInputControls.prefab rename to Assets/Resources/UI/MobileInputControls.prefab diff --git a/Assets/Prefabs/UI/MobileInputControls.prefab.meta b/Assets/Resources/UI/MobileInputControls.prefab.meta similarity index 100% rename from Assets/Prefabs/UI/MobileInputControls.prefab.meta rename to Assets/Resources/UI/MobileInputControls.prefab.meta diff --git a/Assets/Prefabs/UI/PreStageUI.prefab b/Assets/Resources/UI/PreStageUI.prefab similarity index 100% rename from Assets/Prefabs/UI/PreStageUI.prefab rename to Assets/Resources/UI/PreStageUI.prefab diff --git a/Assets/Prefabs/UI/PreStageUI.prefab.meta b/Assets/Resources/UI/PreStageUI.prefab.meta similarity index 100% rename from Assets/Prefabs/UI/PreStageUI.prefab.meta rename to Assets/Resources/UI/PreStageUI.prefab.meta diff --git a/Assets/Prefabs/Walls.meta b/Assets/Resources/Walls.meta similarity index 100% rename from Assets/Prefabs/Walls.meta rename to Assets/Resources/Walls.meta diff --git a/Assets/Prefabs/Walls/destructible_high_snow.prefab b/Assets/Resources/Walls/destructible_high_snow.prefab similarity index 100% rename from Assets/Prefabs/Walls/destructible_high_snow.prefab rename to Assets/Resources/Walls/destructible_high_snow.prefab diff --git a/Assets/Prefabs/Walls/destructible_high_snow.prefab.meta b/Assets/Resources/Walls/destructible_high_snow.prefab.meta similarity index 100% rename from Assets/Prefabs/Walls/destructible_high_snow.prefab.meta rename to Assets/Resources/Walls/destructible_high_snow.prefab.meta diff --git a/Assets/Prefabs/Walls/destructible_snow.prefab b/Assets/Resources/Walls/destructible_snow.prefab similarity index 100% rename from Assets/Prefabs/Walls/destructible_snow.prefab rename to Assets/Resources/Walls/destructible_snow.prefab diff --git a/Assets/Prefabs/Walls/destructible_snow.prefab.meta b/Assets/Resources/Walls/destructible_snow.prefab.meta similarity index 100% rename from Assets/Prefabs/Walls/destructible_snow.prefab.meta rename to Assets/Resources/Walls/destructible_snow.prefab.meta diff --git a/Assets/Prefabs/Walls/indestructible_crate.prefab b/Assets/Resources/Walls/indestructible_crate.prefab similarity index 100% rename from Assets/Prefabs/Walls/indestructible_crate.prefab rename to Assets/Resources/Walls/indestructible_crate.prefab diff --git a/Assets/Prefabs/Walls/indestructible_crate.prefab.meta b/Assets/Resources/Walls/indestructible_crate.prefab.meta similarity index 100% rename from Assets/Prefabs/Walls/indestructible_crate.prefab.meta rename to Assets/Resources/Walls/indestructible_crate.prefab.meta diff --git a/Assets/Scripts/src/Helpers/PrefabAtlas.cs b/Assets/Scripts/src/Helpers/PrefabAtlas.cs new file mode 100644 index 0000000..2ad035c --- /dev/null +++ b/Assets/Scripts/src/Helpers/PrefabAtlas.cs @@ -0,0 +1,27 @@ +using UnityEngine; + +namespace src.Helpers +{ + public static class PrefabAtlas + { + /* Snow Walls */ + public static readonly GameObject DestructibleHighSnow = + Resources.Load("Walls/destructible_high_snow"); + public static readonly GameObject DestructibleSnow = + Resources.Load("Walls/destructible_snow"); + public static readonly GameObject IndestructibleWoodCrate = + Resources.Load("Walls/indestructible_crate"); + + /* Upgrades */ + public static readonly GameObject SpeedIncreaseUpgrade = + Resources.Load("DevMocks/SpeedUpgrade"); + public static readonly GameObject BombsIncreaseUpgrade = + Resources.Load("DevMocks/BombsUpgrade"); + public static readonly GameObject FlamesIncreaseUpgrade = + Resources.Load("DevMocks/FlameUpgrade"); + + /* Enemies */ + public static readonly GameObject GreenEnemy = Resources.Load("DevMocks/Dumber"); + public static readonly GameObject RedEnemy = Resources.Load("DevMocks/Dumb"); + } +} \ No newline at end of file diff --git a/Assets/Scripts/src/Helpers/PrefabAtlas.cs.meta b/Assets/Scripts/src/Helpers/PrefabAtlas.cs.meta new file mode 100644 index 0000000..3126413 --- /dev/null +++ b/Assets/Scripts/src/Helpers/PrefabAtlas.cs.meta @@ -0,0 +1,3 @@ +fileFormatVersion: 2 +guid: 7b381249f5dc4f8f972d66f5d6296478 +timeCreated: 1564336008 \ No newline at end of file diff --git a/Assets/Scripts/src/Level.meta b/Assets/Scripts/src/Level.meta new file mode 100644 index 0000000..119e4d3 --- /dev/null +++ b/Assets/Scripts/src/Level.meta @@ -0,0 +1,3 @@ +fileFormatVersion: 2 +guid: daae435e61b34b42a62a266cf7d71824 +timeCreated: 1564331113 \ No newline at end of file diff --git a/Assets/Scripts/src/Level/LevelData.cs b/Assets/Scripts/src/Level/LevelData.cs new file mode 100644 index 0000000..d105df2 --- /dev/null +++ b/Assets/Scripts/src/Level/LevelData.cs @@ -0,0 +1,55 @@ +using src.Helpers; + +namespace src.Level +{ + using System; + using UnityEngine; + + namespace src.Level + { + public struct LevelData + { + public int levelNumber; + public Count destructibleWallCount; + public Count upgradeCount; + public Count enemyCount; + public GameObject[] enemiesPrefab; + public GameObject[] upgradesPrefab; + public GameObject[] destructibleWallsPrefab; + public GameObject[] indestructibleWallsPrefab; + } + + public static class LevelResource + { + private static readonly GameObject[] AllUpgrades = + {PrefabAtlas.FlamesIncreaseUpgrade, PrefabAtlas.BombsIncreaseUpgrade, PrefabAtlas.SpeedIncreaseUpgrade}; + private static readonly GameObject[] SnowWallsDestructible = + {PrefabAtlas.DestructibleSnow, PrefabAtlas.DestructibleHighSnow}; + private static readonly GameObject[] SnowWallsIndestructible = {PrefabAtlas.IndestructibleWoodCrate}; + + /* Used to store information about the level. */ + private static readonly LevelData[] LevelData = + { + new LevelData + { + levelNumber = 1, + destructibleWallCount = new Count(150, 250), + upgradeCount = new Count(0, 5), + enemyCount = new Count(20, 50), + enemiesPrefab = new[] {PrefabAtlas.GreenEnemy, PrefabAtlas.RedEnemy}, + upgradesPrefab = AllUpgrades, + destructibleWallsPrefab = SnowWallsDestructible, + indestructibleWallsPrefab = SnowWallsIndestructible + } + }; + + /* + * Return data from level data, if it overflows, reset index. + */ + public static LevelData GetLevelData(int level) + { + return LevelData[level % LevelData.Length]; + } + } + } +} \ No newline at end of file diff --git a/Assets/Scripts/src/Level/LevelData.cs.meta b/Assets/Scripts/src/Level/LevelData.cs.meta new file mode 100644 index 0000000..159632a --- /dev/null +++ b/Assets/Scripts/src/Level/LevelData.cs.meta @@ -0,0 +1,3 @@ +fileFormatVersion: 2 +guid: c1fa3937b5264f67b7151b31ab8a70ec +timeCreated: 1564331120 \ No newline at end of file diff --git a/Assets/Scripts/src/Managers/LevelManager.cs b/Assets/Scripts/src/Level/LevelManager.cs similarity index 88% rename from Assets/Scripts/src/Managers/LevelManager.cs rename to Assets/Scripts/src/Level/LevelManager.cs index 5976480..d231fe9 100644 --- a/Assets/Scripts/src/Managers/LevelManager.cs +++ b/Assets/Scripts/src/Level/LevelManager.cs @@ -1,12 +1,13 @@ -using System; -using System.Collections.Generic; +using System.Collections.Generic; using src.Base; using src.Helpers; +using src.Level.src.Level; +using src.Managers; using src.Wall; using UnityEngine; using Random = UnityEngine.Random; -namespace src.Managers +namespace src.Level { public class LevelManager : GameplayComponent { @@ -30,12 +31,12 @@ namespace src.Managers /* Used to group spawned objects */ public Transform boardHolder; - /* Holds the starting position of the player */ public Transform startPosition; + /* Holds references to prefabs for the specified level. */ public GameObject indestructibleWallPrefab; - public GameObject[] destructibleWallPrefabs; - public GameObject[] enemiesPrefab; + private GameObject[] _destructibleWallPrefabs; + private GameObject[] _enemiesPrefab; /* Specifies how many objects we want per level. */ private Count _destructibleWallCount = new Count(150, 350); @@ -55,6 +56,15 @@ namespace src.Managers /* Singletons */ private GameStateManager _gameStateManager = GameStateManager.Instance; + public void SetLevelData(LevelData levelData) + { + _destructibleWallCount = levelData.destructibleWallCount; + _upgradesCount = levelData.upgradeCount; + _enemyCount = levelData.enemyCount; + _enemiesPrefab = levelData.enemiesPrefab; + _destructibleWallPrefabs = levelData.destructibleWallsPrefab; + } + /* Modifies walls from _destructibleWalls in order to setup upgrades*/ private void SetupSpawnables() { @@ -151,7 +161,7 @@ namespace src.Managers private void PlaceDestructibleTile(Vector3 position) { DebugHelper.LogVerbose($"PlaceDestructibleTile: x:{position.x} y:{position.y}"); - var randomWall = destructibleWallPrefabs.ChoseRandom(); + var randomWall = _destructibleWallPrefabs.ChoseRandom(); var instance = Instantiate(randomWall, position, Quaternion.identity); _destructibleWalls.Add(instance); instance.transform.SetParent(boardHolder); @@ -194,7 +204,7 @@ namespace src.Managers private bool PlaceEnemy(Vector3 position) { DebugHelper.LogVerbose($"PlaceEnemy: x:{position.x} y:{position.y}"); - var randomEnemy = enemiesPrefab.ChoseRandom(); + var randomEnemy = _enemiesPrefab.ChoseRandom(); var instance = Instantiate(randomEnemy, position, Quaternion.identity); _enemies.Add(instance); instance.transform.SetParent(boardHolder); diff --git a/Assets/Scripts/src/Managers/LevelManager.cs.meta b/Assets/Scripts/src/Level/LevelManager.cs.meta similarity index 100% rename from Assets/Scripts/src/Managers/LevelManager.cs.meta rename to Assets/Scripts/src/Level/LevelManager.cs.meta diff --git a/Assets/Scripts/src/Managers/GameManager.cs b/Assets/Scripts/src/Managers/GameManager.cs index 937e163..fceee49 100644 --- a/Assets/Scripts/src/Managers/GameManager.cs +++ b/Assets/Scripts/src/Managers/GameManager.cs @@ -1,5 +1,8 @@ using System.Collections; +using src.Ammo; using src.Helpers; +using src.Level; +using src.Level.src.Level; using src.Player; using UnityEngine; @@ -48,7 +51,11 @@ namespace src.Managers private void StartLevel() { + var levelData = LevelResource.GetLevelData(_gameStateManager.Level); StartCoroutine(PreInitGame()); + _levelManager.SetLevelData(levelData); + _upgradeManager.SetLevelData(levelData); + _levelManager.InitLevel(); _playerController.Respawn(); } diff --git a/Assets/Scripts/src/Managers/UpgradeManager.cs b/Assets/Scripts/src/Managers/UpgradeManager.cs index 0337d83..bd3ec2f 100644 --- a/Assets/Scripts/src/Managers/UpgradeManager.cs +++ b/Assets/Scripts/src/Managers/UpgradeManager.cs @@ -2,6 +2,7 @@ using System; using System.Collections.Generic; using src.Base; using src.Helpers; +using src.Level.src.Level; using UnityEngine; namespace src.Managers @@ -10,7 +11,7 @@ namespace src.Managers { public static UpgradeManager Instance; private List _unclaimedUpgrades = new List(); - public GameObject[] upgradePrefabs; + private GameObject[] _upgradePrefabs; private void Awake() { @@ -23,10 +24,15 @@ namespace src.Managers Destroy(gameObject); } } + + public void SetLevelData(LevelData levelData) + { + _upgradePrefabs = levelData.upgradesPrefab; + } public GameObject GetUpgradePrefab() { - return upgradePrefabs.ChoseRandom(); + return _upgradePrefabs.ChoseRandom(); } /* Register unclaimed upgrades so then can be destroyed on level changed or other events. */