|
|
@ -3,61 +3,83 @@ using System.Collections.Generic;
|
|
|
|
using Unity.BossRoom.Gameplay.GameplayObjects.Character;
|
|
|
|
using Unity.BossRoom.Gameplay.GameplayObjects.Character;
|
|
|
|
using Unity.Netcode;
|
|
|
|
using Unity.Netcode;
|
|
|
|
using UnityEngine;
|
|
|
|
using UnityEngine;
|
|
|
|
using UnityEngine.AI;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[RequireComponent(typeof(SphereCollider))]
|
|
|
|
public class SlowZonePrefab : NetworkBehaviour
|
|
|
|
public class SlowZonePrefab : NetworkBehaviour
|
|
|
|
{
|
|
|
|
{
|
|
|
|
[Header("Slow Zone Settings")]
|
|
|
|
[Header("Slow Zone Settings")]
|
|
|
|
public Ability Ability;
|
|
|
|
public Ability Ability;
|
|
|
|
|
|
|
|
public GameObject visualEffectPrefab; // Prefab for visualizing the area
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private HashSet<ServerCharacter> affectedPlayers = new HashSet<ServerCharacter>();
|
|
|
|
|
|
|
|
private SphereCollider zoneCollider;
|
|
|
|
|
|
|
|
private GameObject visualEffectInstance;
|
|
|
|
|
|
|
|
|
|
|
|
private void Start()
|
|
|
|
private void Start()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Start the process to slow down players when the zone is spawned
|
|
|
|
zoneCollider = GetComponent<SphereCollider>();
|
|
|
|
StartCoroutine(ApplySlowEffect());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private IEnumerator ApplySlowEffect()
|
|
|
|
// Spawn the visual effect
|
|
|
|
|
|
|
|
if (visualEffectPrefab)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Run the logic once immediately
|
|
|
|
visualEffectInstance = Instantiate(visualEffectPrefab, transform.position, Quaternion.identity);
|
|
|
|
ApplySlowToPlayers();
|
|
|
|
visualEffectInstance.transform.localScale = Vector3.one * Ability.abilityRadius * 2f; // Adjust scale to match the radius
|
|
|
|
|
|
|
|
}
|
|
|
|
// Optionally, repeat the check while the zone exists
|
|
|
|
|
|
|
|
yield return new WaitForSeconds(Ability.abilityDuration);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Destroy the zone after applying the slow effect
|
|
|
|
// Automatically destroy after the ability duration
|
|
|
|
DespawnZone();
|
|
|
|
StartCoroutine(DelayedDestroy());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void ApplySlowToPlayers()
|
|
|
|
private void OnTriggerEnter(Collider other)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (other.TryGetComponent<ServerCharacter>(out var player))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Find all colliders in the zone
|
|
|
|
if (!player.IsCrow && affectedPlayers.Add(player)) // Only affect non-crow players
|
|
|
|
Collider[] hitColliders = Physics.OverlapSphere(transform.position, Ability.abilityRadius);
|
|
|
|
|
|
|
|
foreach (var collider in hitColliders)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (collider.TryGetComponent<ServerCharacter>(out var player))
|
|
|
|
player.Movement.SetSpeedModifier(Ability.abilityMagnitude);
|
|
|
|
|
|
|
|
Debug.Log($"{player.name} entered the slow zone. Speed reduced.");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void OnTriggerExit(Collider other)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (other.TryGetComponent<ServerCharacter>(out var player))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Check if the player is NOT the crow
|
|
|
|
if (affectedPlayers.Remove(player))
|
|
|
|
if (!player.IsCrow)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Apply slow effect
|
|
|
|
player.Movement.ResetSpeedModifier();
|
|
|
|
StartCoroutine(SlowPlayer(player));
|
|
|
|
Debug.Log($"{player.name} exited the slow zone. Speed restored.");
|
|
|
|
Debug.Log($"{player.name} is slowed down!");
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void OnDestroy()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// Restore speed for all players when the zone is destroyed
|
|
|
|
|
|
|
|
foreach (var player in affectedPlayers)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
player.Movement.ResetSpeedModifier();
|
|
|
|
|
|
|
|
Debug.Log($"{player.name}'s speed restored due to slow zone destruction.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private IEnumerator SlowPlayer(ServerCharacter player)
|
|
|
|
affectedPlayers.Clear();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Destroy the visual effect
|
|
|
|
|
|
|
|
if (visualEffectInstance)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Halve the player's movement speed
|
|
|
|
Destroy(visualEffectInstance);
|
|
|
|
player.Movement.SetSpeedModifier(Ability.abilityMagnitude);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Wait for the slow duration
|
|
|
|
private IEnumerator DelayedDestroy()
|
|
|
|
|
|
|
|
{
|
|
|
|
yield return new WaitForSeconds(Ability.abilityDuration);
|
|
|
|
yield return new WaitForSeconds(Ability.abilityDuration);
|
|
|
|
|
|
|
|
|
|
|
|
// Restore the original speed
|
|
|
|
if (IsServer)
|
|
|
|
player.Movement.ResetSpeedModifier();
|
|
|
|
{
|
|
|
|
Debug.Log($"{player.name}'s speed is restored.");
|
|
|
|
DespawnZone();
|
|
|
|
Destroy(gameObject);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void DespawnZone()
|
|
|
|
private void DespawnZone()
|
|
|
@ -76,11 +98,4 @@ public class SlowZonePrefab : NetworkBehaviour
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Debug visualization for the slow zone in the editor
|
|
|
|
|
|
|
|
private void OnDrawGizmos()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
Gizmos.color = Color.cyan;
|
|
|
|
|
|
|
|
Gizmos.DrawWireSphere(transform.position, Ability.abilityRadius);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|