From 7612251f7e591333f8c534a9a64ca164c8de6bad Mon Sep 17 00:00:00 2001 From: kimrdd Date: Sun, 4 Feb 2024 10:24:51 +0100 Subject: [PATCH] pause in progress --- Assets/Scenes/GameScene.unity | 112 +++++++++++++++++++++++++++- Assets/Scripts/UI/PauseMenu.cs | 65 ++++++++++++++++ Assets/Scripts/UI/PauseMenu.cs.meta | 11 +++ 3 files changed, 186 insertions(+), 2 deletions(-) create mode 100644 Assets/Scripts/UI/PauseMenu.cs create mode 100644 Assets/Scripts/UI/PauseMenu.cs.meta diff --git a/Assets/Scenes/GameScene.unity b/Assets/Scenes/GameScene.unity index e5ec1d3..a5e5be8 100644 --- a/Assets/Scenes/GameScene.unity +++ b/Assets/Scenes/GameScene.unity @@ -1153,6 +1153,81 @@ SpriteRenderer: m_WasSpriteAssigned: 1 m_MaskInteraction: 0 m_SpriteSortPoint: 0 +--- !u!1 &1230350817 +GameObject: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + serializedVersion: 6 + m_Component: + - component: {fileID: 1230350818} + - component: {fileID: 1230350820} + - component: {fileID: 1230350819} + m_Layer: 5 + m_Name: Panel + m_TagString: Untagged + m_Icon: {fileID: 0} + m_NavMeshLayer: 0 + m_StaticEditorFlags: 0 + m_IsActive: 1 +--- !u!224 &1230350818 +RectTransform: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 1230350817} + m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} + m_LocalPosition: {x: 0, y: 0, z: 0} + m_LocalScale: {x: 0.5, y: 0.7, z: 1} + m_ConstrainProportionsScale: 0 + m_Children: [] + m_Father: {fileID: 4158834148864819268} + m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} + m_AnchorMin: {x: 0, y: 0} + m_AnchorMax: {x: 1, y: 1} + m_AnchoredPosition: {x: 0, y: 0} + m_SizeDelta: {x: 0, y: 0} + m_Pivot: {x: 0.5, y: 0.5} +--- !u!114 &1230350819 +MonoBehaviour: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 1230350817} + m_Enabled: 1 + m_EditorHideFlags: 0 + m_Script: {fileID: 11500000, guid: fe87c0e1cc204ed48ad3b37840f39efc, type: 3} + m_Name: + m_EditorClassIdentifier: + m_Material: {fileID: 0} + m_Color: {r: 1, g: 1, b: 1, a: 0.392} + m_RaycastTarget: 1 + m_RaycastPadding: {x: 0, y: 0, z: 0, w: 0} + m_Maskable: 1 + m_OnCullStateChanged: + m_PersistentCalls: + m_Calls: [] + m_Sprite: {fileID: 10907, guid: 0000000000000000f000000000000000, type: 0} + m_Type: 1 + m_PreserveAspect: 0 + m_FillCenter: 1 + m_FillMethod: 4 + m_FillAmount: 1 + m_FillClockwise: 1 + m_FillOrigin: 0 + m_UseSpriteMesh: 0 + m_PixelsPerUnitMultiplier: 1 +--- !u!222 &1230350820 +CanvasRenderer: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 1230350817} + m_CullTransparentMesh: 1 --- !u!1001 &1232208432 PrefabInstance: m_ObjectHideFlags: 0 @@ -3422,15 +3497,48 @@ PrefabInstance: propertyPath: m_LocalEulerAnglesHint.z value: 0 objectReference: {fileID: 0} + - target: {fileID: 6216580377014392011, guid: 48e0e53445d42474895d37a321c39d1c, type: 3} + propertyPath: m_IsActive + value: 0 + objectReference: {fileID: 0} - target: {fileID: 7301411897347746173, guid: 48e0e53445d42474895d37a321c39d1c, type: 3} propertyPath: m_Name value: UI objectReference: {fileID: 0} m_RemovedComponents: [] m_RemovedGameObjects: [] - m_AddedGameObjects: [] - m_AddedComponents: [] + m_AddedGameObjects: + - targetCorrespondingSourceObject: {fileID: 2603779566095873902, guid: 48e0e53445d42474895d37a321c39d1c, type: 3} + insertIndex: -1 + addedObject: {fileID: 1230350818} + m_AddedComponents: + - targetCorrespondingSourceObject: {fileID: 7301411897347746173, guid: 48e0e53445d42474895d37a321c39d1c, type: 3} + insertIndex: -1 + addedObject: {fileID: 4158834148864819269} m_SourcePrefab: {fileID: 100100000, guid: 48e0e53445d42474895d37a321c39d1c, type: 3} +--- !u!1 &4158834148864819267 stripped +GameObject: + m_CorrespondingSourceObject: {fileID: 7301411897347746173, guid: 48e0e53445d42474895d37a321c39d1c, type: 3} + m_PrefabInstance: {fileID: 4158834148864819266} + m_PrefabAsset: {fileID: 0} +--- !u!224 &4158834148864819268 stripped +RectTransform: + m_CorrespondingSourceObject: {fileID: 2603779566095873902, guid: 48e0e53445d42474895d37a321c39d1c, type: 3} + m_PrefabInstance: {fileID: 4158834148864819266} + m_PrefabAsset: {fileID: 0} +--- !u!114 &4158834148864819269 +MonoBehaviour: + m_ObjectHideFlags: 0 + m_CorrespondingSourceObject: {fileID: 0} + m_PrefabInstance: {fileID: 0} + m_PrefabAsset: {fileID: 0} + m_GameObject: {fileID: 4158834148864819267} + m_Enabled: 1 + m_EditorHideFlags: 0 + m_Script: {fileID: 11500000, guid: 3c20bad5f6ef76d429d398dfba893d40, type: 3} + m_Name: + m_EditorClassIdentifier: + pauseMenuUI: {fileID: 1230350817} --- !u!1001 &4910321061857220295 PrefabInstance: m_ObjectHideFlags: 0 diff --git a/Assets/Scripts/UI/PauseMenu.cs b/Assets/Scripts/UI/PauseMenu.cs new file mode 100644 index 0000000..68cae2e --- /dev/null +++ b/Assets/Scripts/UI/PauseMenu.cs @@ -0,0 +1,65 @@ +using System.Collections; +using System.Collections.Generic; +using System.Linq; +using UnityEngine; +using UnityEngine.InputSystem; +public class PauseMenu : MonoBehaviour +{ + public GameObject pauseMenuUI; + + Gamepad pad; + + // Variable to keep track of the game's pause state + private bool isPaused = false; + private void Start() + { + if (pauseMenuUI.activeSelf) + pauseMenuUI.SetActive(false); + + } + void Update() + { + for (int i = 0; i < Gamepad.all.Count; i++) + Gamepad.all.ElementAtOrDefault(i); + + + // Check if the Escape key is pressed + if (Input.GetKeyDown(KeyCode.Escape) || PlayerInput.c) + { + if (isPaused) + { + ResumeGame(); + } + else + { + PauseGame(); + } + } + } + + // Method to resume the game + public void ResumeGame() + { + // Hide the pause menu + pauseMenuUI.SetActive(false); + + // Set the time scale to 1 to resume normal gameplay + Time.timeScale = 1f; + + // Update the pause state + isPaused = false; + } + + // Method to pause the game + public void PauseGame() + { + // Show the pause menu + pauseMenuUI.SetActive(true); + + // Set the time scale to 0 to pause the game + Time.timeScale = 0f; + + // Update the pause state + isPaused = true; + } +} diff --git a/Assets/Scripts/UI/PauseMenu.cs.meta b/Assets/Scripts/UI/PauseMenu.cs.meta new file mode 100644 index 0000000..eb39398 --- /dev/null +++ b/Assets/Scripts/UI/PauseMenu.cs.meta @@ -0,0 +1,11 @@ +fileFormatVersion: 2 +guid: 3c20bad5f6ef76d429d398dfba893d40 +MonoImporter: + externalObjects: {} + serializedVersion: 2 + defaultReferences: [] + executionOrder: 0 + icon: {instanceID: 0} + userData: + assetBundleName: + assetBundleVariant: