2025-04-18 15:54:50 -04:00
|
|
|
using UnityEngine;
|
|
|
|
|
using Game;
|
|
|
|
|
using Music;
|
|
|
|
|
using Player;
|
2025-01-17 19:46:17 -05:00
|
|
|
using UnityEngine.InputSystem;
|
|
|
|
|
|
2025-04-16 19:57:54 -04:00
|
|
|
namespace Player
|
|
|
|
|
{
|
2025-04-18 15:54:50 -04:00
|
|
|
/// <summary>
|
|
|
|
|
/// This class handles the punching mechanic for the player, including triggering animations,
|
|
|
|
|
/// enabling and disabling the hurtbox, and managing player speed during a punch.
|
|
|
|
|
/// </summary>
|
|
|
|
|
[RequireComponent(typeof(PlayerInput))]
|
|
|
|
|
[RequireComponent(typeof(AnimationPlayer))]
|
|
|
|
|
public class Punch : MonoBehaviour
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Determines whether the player can cancel their punch action.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public bool cancelable = true;
|
2025-04-16 19:57:54 -04:00
|
|
|
|
2025-04-18 15:54:50 -04:00
|
|
|
/// <summary>
|
|
|
|
|
/// The hurtbox used to detect collisions with other players or objects during a punch.
|
|
|
|
|
/// </summary>
|
|
|
|
|
[SerializeField] private BoxCollider2D hurtbox;
|
2025-01-17 19:46:17 -05:00
|
|
|
|
2025-04-18 15:54:50 -04:00
|
|
|
/// <summary>
|
|
|
|
|
/// The input actions associated with the player.
|
|
|
|
|
/// </summary>
|
|
|
|
|
private InputActionAsset actions;
|
2025-01-17 19:46:17 -05:00
|
|
|
|
2025-04-18 15:54:50 -04:00
|
|
|
/// <summary>
|
|
|
|
|
/// Initializes the player's input actions.
|
|
|
|
|
/// </summary>
|
|
|
|
|
private void Start()
|
|
|
|
|
{
|
|
|
|
|
actions = GetComponent<PlayerInput>().actions;
|
|
|
|
|
}
|
2025-01-17 19:46:17 -05:00
|
|
|
|
2025-04-18 15:54:50 -04:00
|
|
|
/// <summary>
|
|
|
|
|
/// Checks for punch input every frame and executes the punch if the action is triggered.
|
|
|
|
|
/// </summary>
|
|
|
|
|
private void Update()
|
2025-01-17 19:46:17 -05:00
|
|
|
{
|
2025-04-18 15:54:50 -04:00
|
|
|
// Executes punch when the "Punch" action is pressed
|
|
|
|
|
if (actions.FindAction("Punch").WasPressedThisFrame())
|
|
|
|
|
{
|
|
|
|
|
if (!cancelable) return; // Prevents punching if the action is not cancelable
|
|
|
|
|
ExecutePunch();
|
|
|
|
|
}
|
2025-01-17 19:46:17 -05:00
|
|
|
}
|
|
|
|
|
|
2025-04-18 15:54:50 -04:00
|
|
|
/// <summary>
|
|
|
|
|
/// Executes the punch action, triggering the punch animation and slowing the player down.
|
|
|
|
|
/// </summary>
|
|
|
|
|
private void ExecutePunch()
|
|
|
|
|
{
|
|
|
|
|
// Trigger the punch animation
|
|
|
|
|
GetComponent<AnimationPlayer>().Punch();
|
2025-02-08 18:54:21 -05:00
|
|
|
|
2025-04-18 15:54:50 -04:00
|
|
|
// Disable the ability to cancel the punch
|
|
|
|
|
DisableCancellation();
|
2025-01-17 19:46:17 -05:00
|
|
|
|
2025-04-18 15:54:50 -04:00
|
|
|
// Temporarily reduce the player's movement speed during the punch
|
|
|
|
|
GetComponent<PlayerMovement>().maxSpeedOverride = 1f;
|
|
|
|
|
}
|
2025-01-17 19:46:17 -05:00
|
|
|
|
2025-04-18 15:54:50 -04:00
|
|
|
/// <summary>
|
|
|
|
|
/// Enables the hurtbox, allowing the punch to interact with other objects.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public void EnableHurtbox()
|
|
|
|
|
{
|
|
|
|
|
if (hurtbox != null) hurtbox.enabled = true;
|
|
|
|
|
}
|
2025-01-17 19:46:17 -05:00
|
|
|
|
2025-04-18 15:54:50 -04:00
|
|
|
/// <summary>
|
|
|
|
|
/// Disables the hurtbox, preventing the punch from interacting with other objects.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public void DisableHurtbox()
|
|
|
|
|
{
|
|
|
|
|
if (hurtbox != null) hurtbox.enabled = false;
|
|
|
|
|
}
|
2025-02-08 18:54:21 -05:00
|
|
|
|
2025-04-18 15:54:50 -04:00
|
|
|
/// <summary>
|
|
|
|
|
/// Disables the ability to cancel the punch action.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public void DisableCancellation()
|
|
|
|
|
{
|
|
|
|
|
cancelable = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Enables the ability to cancel the punch action.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public void EnableCancellation()
|
|
|
|
|
{
|
|
|
|
|
cancelable = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Resets the player's movement speed to its maximum value after the punch is complete.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public void ReturnToMaxSpeed()
|
|
|
|
|
{
|
|
|
|
|
GetComponent<PlayerMovement>().maxSpeedOverride = GetComponent<PlayerMovement>().maxSpeed;
|
|
|
|
|
}
|
2025-02-08 18:54:21 -05:00
|
|
|
}
|
2025-01-17 19:46:17 -05:00
|
|
|
}
|