diff --git a/Game/Assets/Scripts/BedroomTask.cs b/Game/Assets/Scripts/BedroomTask.cs index 1fe1ba1..f77a02e 100644 --- a/Game/Assets/Scripts/BedroomTask.cs +++ b/Game/Assets/Scripts/BedroomTask.cs @@ -1,102 +1,95 @@ /* -Author: Reza -Date: 3/2/25 -Description: To track if cleaning/exploring bedroom task is done before allowing player to open door -*/ + * Author: Reza + * Date: 3/2/25 + * Description: To track if cleaning/exploring the bedroom task is done before allowing player to open the door + */ using System.Collections; -using System.Collections.Generic; +using System.Diagnostics.CodeAnalysis; using TMPro; using UnityEngine; -using UnityEngine.ProBuilder.Shapes; -using UnityEngine.XR.Interaction.Toolkit.Interactables; using UnityEngine.XR.Interaction.Toolkit; +using UnityEngine.XR.Interaction.Toolkit.Interactables; +[SuppressMessage("ReSharper", "GrammarMistakeInComment")] public class BedroomTask : MonoBehaviour { - private GameManager gameManager; - private PostProcessingManager postProcessingManager; - [Header("Task Requirement Values")] // To track how much trash has been collected so far - public int trashCollected = 0; - + public int trashCollected; + // Defines how much trash is needed to collect in order to unlock the door public int trashRequired = 10; - + // Defines the door - [Header("Door to Unlock")] - public GameObject door; - - // Defines the grab interactable to know when the door is grabbed - private XRGrabInteractable grabInteractable; - - // Defines door handle - private Collider doorCollider; - - // Defines door's rigidbody to lock it - private Rigidbody doorRigidbody; - + [Header("Door to Unlock")] public GameObject door; + // Defines UI references - [Header("UI References")] - public GameObject lockedDoorUI; + [Header("UI References")] public GameObject lockedDoorUI; + public GameObject storyPanelUI; public TMP_Text storyText; - + // Defines Audio References - [Header("Audio References")] - public AudioSource audioSource; + [Header("Audio References")] public AudioSource audioSource; + public AudioClip lockedSound; public AudioClip unlockedSound; public AudioClip footstepsSound; public AudioClip doorSlamSound; public AudioClip throwTrashSound; - void Start() + // Defines the door handle + private Collider _doorCollider; + + // Defines door's rigidbody to lock it + private Rigidbody _doorRigidbody; + private GameManager _gameManager; + + // Defines the grab interactable to know when the door is grabbed + private XRGrabInteractable _grabInteractable; + private PostProcessingManager _postProcessingManager; + + private void Start() { // Hide all UI prompts on start lockedDoorUI.SetActive(false); //unlockedDoorUI.SetActive(false); - - // Ensure door is not null + + // Ensure the door is not null if (door != null) { // Get the components of the door - grabInteractable = door.GetComponent(); - doorCollider = door.GetComponent(); - doorRigidbody = door.GetComponent(); + _grabInteractable = door.GetComponent(); + _doorCollider = door.GetComponent(); + _doorRigidbody = door.GetComponent(); // Ensure grab interactable is not null - if (grabInteractable != null) - { + if (_grabInteractable != null) // Detect when the door is grabbed - grabInteractable.selectEntered.AddListener(OnDoorGrabAttempt); - } + _grabInteractable.selectEntered.AddListener(OnDoorGrabAttempt); // Ensure rigidbody is not null - if (doorRigidbody != null) - { + if (_doorRigidbody != null) // Lock the door on start - LockDoor(); - } + LockDoor(); } - + // Hide the story panel at the start if (storyPanelUI != null) storyPanelUI.SetActive(false); // Subscribe to the event from DayPanelManager CanvasFade.OnDayPanelHidden += ShowStoryText; - + // if (storyPanelUI != null && storyText != null) // { // storyPanelUI.SetActive(true); // storyText.text = "My parents are still home... I should clean up first."; // StartCoroutine(ClearMessageAfterSeconds(7f)); // } - } - + private void OnDestroy() { // Unsubscribe to prevent memory leaks @@ -111,7 +104,7 @@ public class BedroomTask : MonoBehaviour private IEnumerator DelayedStoryText() { - yield return new WaitForSeconds(0.5f); // Small delay to ensure smooth transition + yield return new WaitForSeconds(0.5f); // Small delay to ensure a smooth transition if (storyPanelUI != null && storyText != null) { @@ -126,82 +119,68 @@ public class BedroomTask : MonoBehaviour { // Add to trash count trashCollected++; - + // Play sound only if no other sound is currently playing - if (!audioSource.isPlaying) - { - audioSource.PlayOneShot(throwTrashSound); - } - + if (!audioSource.isPlaying) audioSource.PlayOneShot(throwTrashSound); + Debug.Log($"Trash collected: {trashCollected}/{trashRequired}"); - // If player has collected/thrown required amount of trash + // If the player has collected/ thrown the required amount of trash if (trashCollected >= trashRequired) { if (GameManager.Instance == null) - { Debug.LogError("GameManager instance is null!"); - } else - { GameManager.Instance.BedroomTaskComplete(); - } - + // Call unlocking door function/sequence StartCoroutine(PlaySoundSequence()); } } - // Functions when door is locked + // Functions when the door is locked private void LockDoor() { // Ensure rigidbody is not null - if (doorRigidbody != null) + if (_doorRigidbody != null) { // Stops door movement - doorRigidbody.isKinematic = true; - - // Freezes the door to ensure door doesn't open - doorRigidbody.constraints = RigidbodyConstraints.FreezeAll; + _doorRigidbody.isKinematic = true; + + // Freezes the door to ensure the door doesn't open + _doorRigidbody.constraints = RigidbodyConstraints.FreezeAll; } // Ensure collider is not null - if (doorCollider != null) - { - // Prevents player from grabbing door handle - doorCollider.enabled = false; - } + if (_doorCollider != null) + // Prevents player from grabbing the door handle + _doorCollider.enabled = false; } // Functions when door is unlocked private void UnlockDoor() { // Ensure rigidbody is not null - if (doorRigidbody != null) + if (_doorRigidbody != null) { // Allows door movement - doorRigidbody.isKinematic = false; - + _doorRigidbody.isKinematic = false; + // Unfreezes door to let it open - doorRigidbody.constraints = RigidbodyConstraints.None; + _doorRigidbody.constraints = RigidbodyConstraints.None; } // Ensure collider is not null - if (doorCollider != null) - { + if (_doorCollider != null) // Allows player to grab the door handle - doorCollider.enabled = true; - } - + _doorCollider.enabled = true; + // Play sound only if no other sound is currently playing - if (!audioSource.isPlaying) - { - audioSource.PlayOneShot(unlockedSound); - } - + if (!audioSource.isPlaying) audioSource.PlayOneShot(unlockedSound); + // Show the unlocked door UI - // unlockedDoorUI.SetActive(true); - + // unlockedDoorUI.SetActive(true); + // Call the function to hide the UI after delay //StartCoroutine(HideMessageAfterSeconds(unlockedDoorUI, 5f)); Debug.Log("Room is clean! The door is now unlocked."); @@ -215,13 +194,10 @@ public class BedroomTask : MonoBehaviour { // Show the locked door UI lockedDoorUI.SetActive(true); - + // Play sound only if no other sound is currently playing - if (!audioSource.isPlaying) - { - audioSource.PlayOneShot(lockedSound); - } - + if (!audioSource.isPlaying) audioSource.PlayOneShot(lockedSound); + // Call the function to hide the UI after delay StartCoroutine(HidePanelAfterSeconds(lockedDoorUI, 5f)); Debug.Log("The door is locked! Clean the room first."); @@ -234,14 +210,14 @@ public class BedroomTask : MonoBehaviour // Trash collected is more or equal to trash required to collect return trashCollected >= trashRequired; } - + private IEnumerator PlaySoundSequence() { PostProcessingManager.Instance.TriggerEffect("Panic"); - - storyPanelUI.SetActive(true); + + storyPanelUI.SetActive(true); storyText.text = "!!!"; - + // Play footsteps of parents walking away audioSource.PlayOneShot(footstepsSound); yield return new WaitForSeconds(footstepsSound.length); @@ -249,20 +225,20 @@ public class BedroomTask : MonoBehaviour // Play a door slam after the footsteps clip ends audioSource.PlayOneShot(doorSlamSound); yield return new WaitForSeconds(doorSlamSound.length); - + // Stop the panic effect once the door slam sound ends PostProcessingManager.Instance.StopEffect(); - + // Clear the "!!!" storyText.text = ""; // Unlocks the door after the clips and update the story UnlockDoor(); - + storyText.text = "They finally left... just as soon as I finished cleaning. I can leave the room now."; StartCoroutine(ClearMessageAfterSeconds(7f)); } - + // Function to hide the UI after a delay private IEnumerator ClearMessageAfterSeconds(float delay) { @@ -270,11 +246,11 @@ public class BedroomTask : MonoBehaviour yield return new WaitForSeconds(delay); storyText.text = ""; } - + private IEnumerator HidePanelAfterSeconds(GameObject uiElement, float delay) { // Waits for delay to end and hides the UI yield return new WaitForSeconds(delay); uiElement.SetActive(false); } -} +} \ No newline at end of file