Compare commits

..

No commits in common. 'dev-hazimBeforeMerge' and 'main' have entirely different histories.

@ -10,14 +10,13 @@ MonoBehaviour:
m_Enabled: 1 m_Enabled: 1
m_EditorHideFlags: 0 m_EditorHideFlags: 0
m_Script: {fileID: 11500000, guid: 4e7350d0607d7cc46a92f7ff596ad88d, type: 3} m_Script: {fileID: 11500000, guid: 4e7350d0607d7cc46a92f7ff596ad88d, type: 3}
m_Name: DashNCrash m_Name: SlowZoneAbility
m_EditorClassIdentifier: m_EditorClassIdentifier:
abilityKey: DashNCrash abilityName: Slowdown Area
abilityName: DashNCrash abilityKey: Slowdown
abilityRadius: 3 keybind: 113
abilityMagnitude: 0.3 cooldownTime: 3
abilityRadius: 4
abilityDuration: 3 abilityDuration: 3
abilityCooldownTime: 3 abilityMagnitude: 0.3
prefab: {fileID: 5818330108676053786, guid: 4979352732bf84b44a9c789bef80b18a, type: 3} abilityPrefab: {fileID: 5818330108676053786, guid: 4979352732bf84b44a9c789bef80b18a, type: 3}
dashSpeed: 15
dashDuration: 0.5

@ -13,9 +13,8 @@ GameObject:
- component: {fileID: 825873091886110301} - component: {fileID: 825873091886110301}
- component: {fileID: 8294231852451494523} - component: {fileID: 8294231852451494523}
- component: {fileID: 7596904637393423818} - component: {fileID: 7596904637393423818}
- component: {fileID: 1396255635289861961}
m_Layer: 0 m_Layer: 0
m_Name: DashNCrashPrefab m_Name: SlowDownZonePrefab
m_TagString: Untagged m_TagString: Untagged
m_Icon: {fileID: 0} m_Icon: {fileID: 0}
m_NavMeshLayer: 0 m_NavMeshLayer: 0
@ -98,7 +97,7 @@ MonoBehaviour:
m_Script: {fileID: 11500000, guid: d5a57f767e5e46a458fc5d3c628d0cbb, type: 3} m_Script: {fileID: 11500000, guid: d5a57f767e5e46a458fc5d3c628d0cbb, type: 3}
m_Name: m_Name:
m_EditorClassIdentifier: m_EditorClassIdentifier:
GlobalObjectIdHash: 1238939516 GlobalObjectIdHash: 725408325
InScenePlacedSourceGlobalObjectIdHash: 0 InScenePlacedSourceGlobalObjectIdHash: 0
AlwaysReplicateAsRoot: 0 AlwaysReplicateAsRoot: 0
SynchronizeTransform: 1 SynchronizeTransform: 1
@ -120,25 +119,3 @@ MonoBehaviour:
m_Name: m_Name:
m_EditorClassIdentifier: m_EditorClassIdentifier:
Ability: {fileID: 11400000, guid: e4794e2f71f66a74486c797344695ce7, type: 2} Ability: {fileID: 11400000, guid: e4794e2f71f66a74486c797344695ce7, type: 2}
visualEffectPrefab: {fileID: 3894374618083898175, guid: 63d404b949e644e4a92db7444ae88671, type: 3}
--- !u!135 &1396255635289861961
SphereCollider:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 5818330108676053786}
m_Material: {fileID: 0}
m_IncludeLayers:
serializedVersion: 2
m_Bits: 0
m_ExcludeLayers:
serializedVersion: 2
m_Bits: 0
m_LayerOverridePriority: 0
m_IsTrigger: 1
m_ProvidesContacts: 0
m_Enabled: 1
serializedVersion: 3
m_Radius: 3
m_Center: {x: 0, y: 2.46, z: 0}

@ -300,9 +300,6 @@ PrefabInstance:
- targetCorrespondingSourceObject: {fileID: 4600110157238723781, guid: 0d2d836e2e83b754fa1a1c4022d6d65d, type: 3} - targetCorrespondingSourceObject: {fileID: 4600110157238723781, guid: 0d2d836e2e83b754fa1a1c4022d6d65d, type: 3}
insertIndex: -1 insertIndex: -1
addedObject: {fileID: 7049454171559621213} addedObject: {fileID: 7049454171559621213}
- targetCorrespondingSourceObject: {fileID: 4600110157238723781, guid: 0d2d836e2e83b754fa1a1c4022d6d65d, type: 3}
insertIndex: -1
addedObject: {fileID: 4321537148236331373}
m_SourcePrefab: {fileID: 100100000, guid: 0d2d836e2e83b754fa1a1c4022d6d65d, type: 3} m_SourcePrefab: {fileID: 100100000, guid: 0d2d836e2e83b754fa1a1c4022d6d65d, type: 3}
--- !u!114 &741733315856861890 stripped --- !u!114 &741733315856861890 stripped
MonoBehaviour: MonoBehaviour:
@ -372,7 +369,6 @@ MonoBehaviour:
m_ServerCharacter: {fileID: 741733315856861890} m_ServerCharacter: {fileID: 741733315856861890}
m_PhysicsWrapper: {fileID: 6116655102486013040} m_PhysicsWrapper: {fileID: 6116655102486013040}
m_AbilitySystem: {fileID: 7049454171559621213} m_AbilitySystem: {fileID: 7049454171559621213}
m_UIMessageFeed: {fileID: 0}
--- !u!114 &4887850889182527394 --- !u!114 &4887850889182527394
MonoBehaviour: MonoBehaviour:
m_ObjectHideFlags: 0 m_ObjectHideFlags: 0
@ -751,18 +747,6 @@ MonoBehaviour:
abilities: abilities:
- {fileID: 11400000, guid: e4794e2f71f66a74486c797344695ce7, type: 2} - {fileID: 11400000, guid: e4794e2f71f66a74486c797344695ce7, type: 2}
currentAbilityIndicator: {fileID: 92142163933926358} currentAbilityIndicator: {fileID: 92142163933926358}
--- !u!114 &4321537148236331373
MonoBehaviour:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 6009713983291384756}
m_Enabled: 1
m_EditorHideFlags: 0
m_Script: {fileID: 11500000, guid: a73f85cd904406945a2192aaecb2c310, type: 3}
m_Name:
m_EditorClassIdentifier:
--- !u!4 &6009713983291384766 stripped --- !u!4 &6009713983291384766 stripped
Transform: Transform:
m_CorrespondingSourceObject: {fileID: 4600110157238723791, guid: 0d2d836e2e83b754fa1a1c4022d6d65d, type: 3} m_CorrespondingSourceObject: {fileID: 4600110157238723791, guid: 0d2d836e2e83b754fa1a1c4022d6d65d, type: 3}

@ -1232,72 +1232,6 @@ MonoBehaviour:
ChildScenesToLoadConfig: ChildScenesToLoadConfig:
- {fileID: 102900000, guid: a542218ba547130469444ba04f9bef35, type: 3} - {fileID: 102900000, guid: a542218ba547130469444ba04f9bef35, type: 3}
- {fileID: 102900000, guid: f77e38f2b72c5f649902d637b3a70b42, type: 3} - {fileID: 102900000, guid: f77e38f2b72c5f649902d637b3a70b42, type: 3}
--- !u!1 &698889474
GameObject:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
serializedVersion: 6
m_Component:
- component: {fileID: 698889477}
- component: {fileID: 698889475}
- component: {fileID: 698889476}
m_Layer: 0
m_Name: ScoreManager
m_TagString: Untagged
m_Icon: {fileID: 0}
m_NavMeshLayer: 0
m_StaticEditorFlags: 0
m_IsActive: 1
--- !u!114 &698889475
MonoBehaviour:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 698889474}
m_Enabled: 1
m_EditorHideFlags: 0
m_Script: {fileID: 11500000, guid: d5a57f767e5e46a458fc5d3c628d0cbb, type: 3}
m_Name:
m_EditorClassIdentifier:
GlobalObjectIdHash: 2391970879
InScenePlacedSourceGlobalObjectIdHash: 0
AlwaysReplicateAsRoot: 0
SynchronizeTransform: 1
ActiveSceneSynchronization: 0
SceneMigrationSynchronization: 1
SpawnWithObservers: 1
DontDestroyWithOwner: 0
AutoObjectParentSync: 1
--- !u!114 &698889476
MonoBehaviour:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 698889474}
m_Enabled: 1
m_EditorHideFlags: 0
m_Script: {fileID: 11500000, guid: c42f66f946855da4b99f79c5bde1d545, type: 3}
m_Name:
m_EditorClassIdentifier:
--- !u!4 &698889477
Transform:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 698889474}
serializedVersion: 2
m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
m_LocalPosition: {x: 0, y: 0, z: 0}
m_LocalScale: {x: 1, y: 1, z: 1}
m_ConstrainProportionsScale: 0
m_Children: []
m_Father: {fileID: 0}
m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
--- !u!1001 &791609700 --- !u!1001 &791609700
PrefabInstance: PrefabInstance:
m_ObjectHideFlags: 0 m_ObjectHideFlags: 0
@ -8663,11 +8597,11 @@ PrefabInstance:
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 1676734515771252668, guid: 0193228de87741d40a42e561901c9083, type: 3} - target: {fileID: 1676734515771252668, guid: 0193228de87741d40a42e561901c9083, type: 3}
propertyPath: m_LocalRotation.w propertyPath: m_LocalRotation.w
value: 0.85294455 value: 0.8529446
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 1676734515771252668, guid: 0193228de87741d40a42e561901c9083, type: 3} - target: {fileID: 1676734515771252668, guid: 0193228de87741d40a42e561901c9083, type: 3}
propertyPath: m_LocalRotation.x propertyPath: m_LocalRotation.x
value: 0.3943448 value: 0.39434478
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 1676734515771252668, guid: 0193228de87741d40a42e561901c9083, type: 3} - target: {fileID: 1676734515771252668, guid: 0193228de87741d40a42e561901c9083, type: 3}
propertyPath: m_LocalRotation.y propertyPath: m_LocalRotation.y
@ -8675,7 +8609,7 @@ PrefabInstance:
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 1676734515771252668, guid: 0193228de87741d40a42e561901c9083, type: 3} - target: {fileID: 1676734515771252668, guid: 0193228de87741d40a42e561901c9083, type: 3}
propertyPath: m_LocalRotation.z propertyPath: m_LocalRotation.z
value: -0.14352979 value: -0.14352977
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 1676734516302391364, guid: 0193228de87741d40a42e561901c9083, type: 3} - target: {fileID: 1676734516302391364, guid: 0193228de87741d40a42e561901c9083, type: 3}
propertyPath: m_UpdateMethod propertyPath: m_UpdateMethod
@ -8707,11 +8641,11 @@ PrefabInstance:
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 1676734516695783279, guid: 0193228de87741d40a42e561901c9083, type: 3} - target: {fileID: 1676734516695783279, guid: 0193228de87741d40a42e561901c9083, type: 3}
propertyPath: m_LocalRotation.y propertyPath: m_LocalRotation.y
value: 0.3097298 value: 0.30972984
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 1676734516695783279, guid: 0193228de87741d40a42e561901c9083, type: 3} - target: {fileID: 1676734516695783279, guid: 0193228de87741d40a42e561901c9083, type: 3}
propertyPath: m_LocalRotation.z propertyPath: m_LocalRotation.z
value: -0.14506969 value: -0.1450697
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 1676734516724634599, guid: 0193228de87741d40a42e561901c9083, type: 3} - target: {fileID: 1676734516724634599, guid: 0193228de87741d40a42e561901c9083, type: 3}
propertyPath: m_LocalPosition.z propertyPath: m_LocalPosition.z
@ -8824,15 +8758,15 @@ PrefabInstance:
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 203267159508449512, guid: 36b3ee75677a1544191c0ddaaadd8140, type: 3} - target: {fileID: 203267159508449512, guid: 36b3ee75677a1544191c0ddaaadd8140, type: 3}
propertyPath: m_LocalRotation.x propertyPath: m_LocalRotation.x
value: 0.39434484 value: 0.3943448
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 203267159508449512, guid: 36b3ee75677a1544191c0ddaaadd8140, type: 3} - target: {fileID: 203267159508449512, guid: 36b3ee75677a1544191c0ddaaadd8140, type: 3}
propertyPath: m_LocalRotation.y propertyPath: m_LocalRotation.y
value: 0.3104465 value: 0.31044644
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 203267159508449512, guid: 36b3ee75677a1544191c0ddaaadd8140, type: 3} - target: {fileID: 203267159508449512, guid: 36b3ee75677a1544191c0ddaaadd8140, type: 3}
propertyPath: m_LocalRotation.z propertyPath: m_LocalRotation.z
value: -0.1435298 value: -0.14352976
objectReference: {fileID: 0} objectReference: {fileID: 0}
- target: {fileID: 203267159508449512, guid: 36b3ee75677a1544191c0ddaaadd8140, type: 3} - target: {fileID: 203267159508449512, guid: 36b3ee75677a1544191c0ddaaadd8140, type: 3}
propertyPath: m_LocalEulerAnglesHint.x propertyPath: m_LocalEulerAnglesHint.x
@ -9301,7 +9235,6 @@ MonoBehaviour:
m_Name: m_Name:
m_EditorClassIdentifier: m_EditorClassIdentifier:
confirmationPanel: {fileID: 125665959027215112} confirmationPanel: {fileID: 125665959027215112}
swapwithname: {fileID: 0}
--- !u!4 &1486746210 --- !u!4 &1486746210
Transform: Transform:
m_ObjectHideFlags: 0 m_ObjectHideFlags: 0
@ -10736,4 +10669,3 @@ SceneRoots:
- {fileID: 1690610726} - {fileID: 1690610726}
- {fileID: 1486746210} - {fileID: 1486746210}
- {fileID: 396364068} - {fileID: 396364068}
- {fileID: 698889477}

@ -38,7 +38,7 @@ RenderSettings:
m_ReflectionIntensity: 1 m_ReflectionIntensity: 1
m_CustomReflection: {fileID: 0} m_CustomReflection: {fileID: 0}
m_Sun: {fileID: 0} m_Sun: {fileID: 0}
m_IndirectSpecularColor: {r: 0, g: 0, b: 0, a: 1} m_IndirectSpecularColor: {r: 0.12731749, g: 0.13414757, b: 0.1210787, a: 1}
m_UseRadianceAmbientProbe: 0 m_UseRadianceAmbientProbe: 0
--- !u!157 &3 --- !u!157 &3
LightmapSettings: LightmapSettings:
@ -1524,10 +1524,6 @@ PrefabInstance:
serializedVersion: 3 serializedVersion: 3
m_TransformParent: {fileID: 0} m_TransformParent: {fileID: 0}
m_Modifications: m_Modifications:
- target: {fileID: 370034730102636685, guid: 4512c09d24f3fa147afb198fa90d63c6, type: 3}
propertyPath: SlowDownAbilityKey
value: DashNCrash
objectReference: {fileID: 0}
- target: {fileID: 370034730102636685, guid: 4512c09d24f3fa147afb198fa90d63c6, type: 3} - target: {fileID: 370034730102636685, guid: 4512c09d24f3fa147afb198fa90d63c6, type: 3}
propertyPath: m_GeneralSwapActionPrototype propertyPath: m_GeneralSwapActionPrototype
value: value:

@ -1,29 +1,28 @@
using Unity.BossRoom.Gameplay.GameplayObjects.Character;
using UnityEngine; using UnityEngine;
public abstract class Ability : ScriptableObject public abstract class Ability : ScriptableObject
{ {
public string abilityKey; [Header("Ability Settings")]
public string abilityName; public string abilityName;
public string abilityKey;
[Header("Common Ability Settings")] public KeyCode keybind; // Key to activate the ability
public float cooldownTime; // Cooldown duration in seconds
public float abilityRadius; public float abilityRadius;
public float abilityMagnitude;
public float abilityDuration; public float abilityDuration;
public float abilityCooldownTime; public float abilityMagnitude;
[Header("Ability Prefab")]
public GameObject prefab;
/// <summary> [SerializeField]
/// Executes the ability's specific behavior. private GameObject abilityPrefab; // Prefab associated with this ability
/// </summary>
public abstract void Execute(ServerCharacter character, Vector3 targetPosition);
/// <summary>
/// Retrieves the prefab associated with this ability.
/// </summary>
public GameObject GetPrefab() public GameObject GetPrefab()
{ {
return prefab; return abilityPrefab;
} }
}
public void ActivateAbility(GameObject owner)
{
Activate(owner);
}
protected abstract void Activate(GameObject owner); // Logic for the specific ability
}

@ -1,7 +1,5 @@
using System.Collections; using System.Collections;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq;
using Unity.BossRoom.Gameplay.GameplayObjects.Character;
using Unity.Netcode; using Unity.Netcode;
using UnityEngine; using UnityEngine;
@ -10,8 +8,9 @@ public class AbilitySystem : NetworkBehaviour
[Header("Assigned Abilities")] [Header("Assigned Abilities")]
public List<Ability> abilities = new List<Ability>(); public List<Ability> abilities = new List<Ability>();
private Ability activeAbility; private Ability activeAbility; // Tracks the currently active ability in "spawn mode"
private bool isAbilityActive = false; private bool isAbilityActive = false;
private HashSet<Ability> abilitiesOnCooldown = new HashSet<Ability>(); private HashSet<Ability> abilitiesOnCooldown = new HashSet<Ability>();
[SerializeField] private GameObject currentAbilityIndicator; [SerializeField] private GameObject currentAbilityIndicator;
@ -28,6 +27,9 @@ public class AbilitySystem : NetworkBehaviour
} }
} }
/// <summary>
/// Activates an ability by its keybind.
/// </summary>
public void ActivateAbilityByKey(string key) public void ActivateAbilityByKey(string key)
{ {
foreach (var ability in abilities) foreach (var ability in abilities)
@ -50,7 +52,7 @@ public class AbilitySystem : NetworkBehaviour
public bool IsAbilityModeActive() public bool IsAbilityModeActive()
{ {
return isAbilityActive; return isAbilityActive; // Returns true if an ability mode is currently active
} }
private void ToggleAbilityMode(Ability ability) private void ToggleAbilityMode(Ability ability)
@ -69,7 +71,7 @@ public class AbilitySystem : NetworkBehaviour
{ {
isAbilityActive = true; isAbilityActive = true;
activeAbility = ability; activeAbility = ability;
currentAbilityIndicator?.SetActive(true); currentAbilityIndicator.SetActive(true);
Debug.Log($"Ability {ability.abilityName} activated! Click to use."); Debug.Log($"Ability {ability.abilityName} activated! Click to use.");
} }
@ -77,70 +79,67 @@ public class AbilitySystem : NetworkBehaviour
{ {
isAbilityActive = false; isAbilityActive = false;
activeAbility = null; activeAbility = null;
currentAbilityIndicator?.SetActive(false); currentAbilityIndicator.SetActive(false);
Debug.Log("Ability mode deactivated."); Debug.Log("Ability mode deactivated.");
} }
public void UseActiveAbility() private void UseActiveAbility()
{ {
if (activeAbility != null) if (activeAbility != null)
{ {
Debug.Log($"[AbilitySystem] Using active ability {activeAbility.abilityName}."); var spawnPosition = currentAbilityIndicator.transform.position;
Vector3 targetPosition = currentAbilityIndicator.transform.position; SpawnAbilityServerRpc(activeAbility.abilityKey, spawnPosition);
RequestAbilityActivationServerRpc(activeAbility.abilityKey, targetPosition);
StartCoroutine(StartCooldown(activeAbility)); StartCoroutine(StartCooldown(activeAbility));
DeactivateAbilityMode(); DeactivateAbilityMode();
} }
else
{
Debug.LogWarning("[AbilitySystem] No active ability to use.");
}
} }
[ServerRpc(RequireOwnership = false)] /// <summary>
private void RequestAbilityActivationServerRpc(string abilityKey, Vector3 targetPosition, ServerRpcParams rpcParams = default) /// Starts the cooldown coroutine for the ability.
/// </summary>
private IEnumerator StartCooldown(Ability ability)
{ {
ulong ownerClientId = rpcParams.Receive.SenderClientId; abilitiesOnCooldown.Add(ability);
Debug.Log($"{ability.abilityName} is now on cooldown for {ability.cooldownTime} seconds.");
Debug.Log($"[AbilitySystem] Received activation request for ability '{abilityKey}' from client {ownerClientId} at position {targetPosition}."); yield return new WaitForSeconds(ability.cooldownTime);
ExecuteAbilityOnServer(abilityKey, ownerClientId, targetPosition); abilitiesOnCooldown.Remove(ability);
Debug.Log($"{ability.abilityName} is off cooldown.");
} }
private void ExecuteAbilityOnServer(string abilityKey, ulong ownerClientId, Vector3 targetPosition) /// <summary>
/// Spawns the requested ability on the server.
/// </summary>
[ServerRpc(RequireOwnership = false)]
private void SpawnAbilityServerRpc(string abilityKey, Vector3 position, ServerRpcParams rpcParams = default)
{ {
// Find the player's ServerCharacter var ability = abilities.Find(a => a.abilityKey == abilityKey);
var playerObject = NetworkManager.Singleton.SpawnManager.SpawnedObjectsList if (ability == null)
.FirstOrDefault(obj => obj.OwnerClientId == ownerClientId && obj.GetComponent<ServerCharacter>());
if (playerObject == null || !playerObject.TryGetComponent(out ServerCharacter character))
{ {
Debug.LogError($"[AbilitySystem] No ServerCharacter component found for player {ownerClientId}."); Debug.LogError($"Ability {abilityKey} not found in the Ability System!");
return; return;
} }
// Find the ability var prefab = ability.GetPrefab(); // Ensure your Ability class has a method to get the prefab
var ability = abilities.Find(a => a.abilityKey == abilityKey); if (prefab == null)
if (ability == null)
{ {
Debug.LogError($"[AbilitySystem] Ability {abilityKey} not found in the Ability System."); Debug.LogError($"Prefab for Ability {abilityKey} is not assigned!");
return; return;
} }
// Activate the ability GameObject abilityInstance = Instantiate(prefab, position, Quaternion.identity);
Debug.Log($"[AbilitySystem] Activating ability {ability.abilityName} for player {ownerClientId} at {targetPosition}."); var networkObject = abilityInstance.GetComponent<NetworkObject>();
ability.Execute(character, targetPosition);
}
private IEnumerator StartCooldown(Ability ability)
{
abilitiesOnCooldown.Add(ability);
Debug.Log($"{ability.abilityName} is now on cooldown for {ability.abilityCooldownTime} seconds.");
yield return new WaitForSeconds(ability.abilityCooldownTime);
abilitiesOnCooldown.Remove(ability); if (networkObject != null)
Debug.Log($"{ability.abilityName} is off cooldown."); {
networkObject.Spawn();
Debug.Log($"Spawned {abilityKey} at {position}.");
}
else
{
Debug.LogError($"Ability prefab {abilityKey} must have a NetworkObject component.");
}
} }
private void UpdateIndicatorPosition() private void UpdateIndicatorPosition()
@ -149,11 +148,8 @@ public class AbilitySystem : NetworkBehaviour
Ray ray = Camera.main.ScreenPointToRay(Input.mousePosition); Ray ray = Camera.main.ScreenPointToRay(Input.mousePosition);
if (Physics.Raycast(ray, out RaycastHit hit)) if (Physics.Raycast(ray, out RaycastHit hit))
{ {
if (currentAbilityIndicator != null) currentAbilityIndicator.transform.position = hit.point;
{ currentAbilityIndicator.transform.localScale = Vector3.one * activeAbility.abilityRadius;
currentAbilityIndicator.transform.position = hit.point;
currentAbilityIndicator.transform.localScale = Vector3.one * activeAbility.abilityRadius;
}
} }
} }
} }

@ -111,8 +111,6 @@ public class CrowManager : NetworkBehaviour
} }
} }
/// <summary> /// <summary>
/// RPC to notify clients about the Crow change. /// RPC to notify clients about the Crow change.
/// </summary> /// </summary>
@ -183,5 +181,4 @@ public class CrowManager : NetworkBehaviour
{ {
return currentCrow; return currentCrow;
} }
} }

@ -1,47 +0,0 @@
using System.Collections;
using Unity.BossRoom.Gameplay.GameplayObjects.Character;
using UnityEngine;
using Unity.Netcode;
[CreateAssetMenu(menuName = "Abilities/DashNCrash")]
public class DashNCrashAbility : Ability
{
[Header("Dash Settings")]
public float dashSpeed = 10f;
public float dashDuration = 0.5f;
public override void Execute(ServerCharacter character, Vector3 targetPosition)
{
Debug.Log($"Executing DashNCrash for character {character.OwnerClientId} at {targetPosition}.");
// Start the dash
character.Movement.StartDash(targetPosition, dashSpeed, dashDuration);
// Delay spawning the slow zone until after the dash
character.StartCoroutine(SpawnSlowZoneAfterDash(character, targetPosition));
}
private IEnumerator SpawnSlowZoneAfterDash(ServerCharacter character, Vector3 position)
{
yield return new WaitForSeconds(dashDuration + 0.25f);
// Spawn the slow zone prefab at the dash's end position
var prefab = GetPrefab();
if (prefab != null)
{
GameObject instance = Instantiate(prefab, character.transform.position, Quaternion.identity);
var networkObject = instance.GetComponent<NetworkObject>();
if (networkObject != null)
{
networkObject.Spawn();
Debug.Log($"Slow Zone spawned at {position}.");
}
else
{
Debug.LogError("Slow Zone prefab must have a NetworkObject component.");
}
}
}
}

@ -1,101 +0,0 @@
using System.Collections;
using System.Collections.Generic;
using Unity.BossRoom.Gameplay.GameplayObjects.Character;
using Unity.Netcode;
using UnityEngine;
[RequireComponent(typeof(SphereCollider))]
public class DashNCrashPrefab : NetworkBehaviour
{
[Header("Slow Zone Settings")]
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()
{
zoneCollider = GetComponent<SphereCollider>();
// Spawn the visual effect
if (visualEffectPrefab)
{
visualEffectInstance = Instantiate(visualEffectPrefab, transform.position, Quaternion.identity);
visualEffectInstance.transform.localScale = Vector3.one * Ability.abilityRadius * 2f; // Adjust scale to match the radius
}
// Automatically destroy after the ability duration
StartCoroutine(DelayedDestroy());
}
private void OnTriggerEnter(Collider other)
{
if (other.TryGetComponent<ServerCharacter>(out var player))
{
if (!player.IsCrow && affectedPlayers.Add(player)) // Only affect non-crow players
{
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))
{
if (affectedPlayers.Remove(player))
{
player.Movement.ResetSpeedModifier();
Debug.Log($"{player.name} exited the slow zone. Speed restored.");
}
}
}
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.");
}
affectedPlayers.Clear();
// Destroy the visual effect
if (visualEffectInstance)
{
Destroy(visualEffectInstance);
}
}
private IEnumerator DelayedDestroy()
{
yield return new WaitForSeconds(Ability.abilityDuration);
if (IsServer)
{
DespawnZone();
}
}
private void DespawnZone()
{
if (IsServer)
{
var networkObject = GetComponent<NetworkObject>();
if (networkObject != null)
{
networkObject.Despawn(true); // Despawn and destroy on the server
Debug.Log("SlowZonePrefab has been despawned and destroyed.");
}
else
{
Debug.LogError("SlowZonePrefab is missing a NetworkObject component!");
}
}
}
}

@ -144,12 +144,8 @@ namespace Unity.BossRoom.Gameplay.GameplayObjects.Character
public ulong? PendingSwapRequest { get; set; } public ulong? PendingSwapRequest { get; set; }
public int? TargetPlatformId { get; private set; } = null; public int? TargetPlatformId { get; private set; } = null;
public int? CurrentPlatformId { get; private set; } = null;
public int? PreviousPlatformId { get; private set; } = null;
public bool IsOnAPlatform { get; private set; } = false; public bool IsOnAPlatform { get; private set; } = false;
public bool IsCrow { get; private set; } = false; public bool IsCrow { get; private set; } = false;
public bool IsSwapping { get; private set; } = false;
public UIStateDisplayHandler uIStateDisplayHandler; public UIStateDisplayHandler uIStateDisplayHandler;
@ -182,112 +178,49 @@ namespace Unity.BossRoom.Gameplay.GameplayObjects.Character
{ {
Debug.LogError("SwapConfirmationPanel not found in the scene!"); Debug.LogError("SwapConfirmationPanel not found in the scene!");
} }
} //// Show the confirmation panel for the specific player
} //var panel = FindObjectOfType<SwapConfirmationPanel>();
//if (panel != null)
//{
// panel.ShowPanel(this); // Pass the current ServerCharacter reference
//}
//else
//{
// Debug.LogError("SwapConfirmationPanel not found in the scene!");
//}
public void SetKinematic(bool isKinematic)
{
if (physicsWrapper != null)
{
var rigidbody = physicsWrapper.GetComponent<Rigidbody>();
if (rigidbody != null)
{
rigidbody.isKinematic = isKinematic;
}
}
}
public void SetAsCrow(bool status)
{
if (IsServer)
{
IsCrow = status; // Update on the server
UpdateCrowStatusClientRpc(status); // Notify all clients
}
else
{
Debug.LogWarning("SetAsCrow should only be called on the server.");
} }
} }
public void SetAsCrow(bool status)
[ClientRpc]
private void UpdateCrowStatusClientRpc(bool status)
{ {
IsCrow = status; // Update the value for all clients IsCrow = status;
} }
public void SetTargetPlatform(int platformId) public void SetTargetPlatform(int platformId)
{ {
if (IsServer) TargetPlatformId = platformId;
{
TargetPlatformId = platformId; // Update on the server
UpdateTargetPlatformClientRpc(platformId); // Notify all clients
}
else
{
Debug.LogWarning("SetTargetPlatform should only be called on the server.");
}
} }
public void ClearTargetPlatform() public void ClearTargetPlatform()
{ {
if (IsServer) TargetPlatformId = null;
{
TargetPlatformId = null; // Update on the server
UpdateTargetPlatformClientRpc(-1); // Notify all clients (use -1 to indicate no platform)
}
else
{
Debug.LogWarning("ClearTargetPlatform should only be called on the server.");
}
} }
[ClientRpc] public void OnArrivalOnPlatform()
private void UpdateTargetPlatformClientRpc(int platformId)
{
TargetPlatformId = platformId != -1 ? platformId : (int?)null; // Update the value for all clients
}
public void OnArrivalOnPlatform(int platformId)
{ {
ClearTargetPlatform(); ClearTargetPlatform();
SetOnPlatform(true, platformId); // Automatically syncs to all clients SetOnPlatform(true);
} }
public void OnLeavingPlatform(int platformId) public void OnLeavingPlatform()
{ {
SetOnPlatform(false);
SetOnPlatform(false, platformId); // Automatically syncs to all clients
} }
public void SetOnPlatform(bool status, int platformId) public void SetOnPlatform(bool status)
{ {
if (IsServer) IsOnAPlatform = status;
{
IsOnAPlatform = status; // Update on the server
UpdatePlatformStatusClientRpc(status, platformId); // Notify all clients
}
else
{
Debug.LogWarning("SetOnPlatform should only be called on the server.");
}
}
[ClientRpc]
private void UpdatePlatformStatusClientRpc(bool status, int platformId)
{
IsOnAPlatform = status; // Update the value for all clients
IsSwapping = false;
if (status)
{
CurrentPlatformId = platformId;
}
else
{
PreviousPlatformId = platformId;
CurrentPlatformId = null;
}
} }
@ -312,7 +245,6 @@ namespace Unity.BossRoom.Gameplay.GameplayObjects.Character
var pltpos = PlatformManager.Instance.GetPlatformPosition(platform.PlatformID); var pltpos = PlatformManager.Instance.GetPlatformPosition(platform.PlatformID);
pltpos.y = 0; pltpos.y = 0;
Debug.Log($"Platform position: {pltpos}."); Debug.Log($"Platform position: {pltpos}.");
IsSwapping = true;
ServerSendCharacterInputRpc(pltpos); ServerSendCharacterInputRpc(pltpos);
} }

@ -91,74 +91,14 @@ namespace Unity.BossRoom.Gameplay.GameplayObjects.Character
m_NavPath.SetTargetPosition(position); m_NavPath.SetTargetPosition(position);
} }
public void StartDash(Vector3 targetPosition, float dashSpeed, float duration)
{
if (!IsServer)
{
Debug.LogWarning("[ServerCharacterMovement] StartDash called on a client. This should only run on the server.");
return;
}
if (m_NavMeshAgent == null || m_Rigidbody == null)
{
Debug.LogError("[ServerCharacterMovement] NavMeshAgent or Rigidbody is null. Ensure they are assigned.");
return;
}
Debug.Log($"[ServerCharacterMovement] StartDash initiated. Target position: {targetPosition}, Speed: {dashSpeed}, Duration: {duration}");
Vector3 direction = (targetPosition - transform.position).normalized;
if (direction.sqrMagnitude > 0.001f)
{
transform.rotation = Quaternion.LookRotation(direction);
Debug.Log($"[ServerCharacterMovement] Adjusted rotation towards {targetPosition}.");
}
else
{
Debug.LogWarning("[ServerCharacterMovement] Dash direction vector is too small. Aborting dash.");
return;
}
StartForwardCharge(dashSpeed, duration);
Debug.Log("[ServerCharacterMovement] Dash executed successfully.");
}
public void StartForwardCharge(float speed, float duration) public void StartForwardCharge(float speed, float duration)
{ {
if (!IsServer)
{
Debug.LogWarning("[ServerCharacterMovement] StartForwardCharge called on a client. This should only run on the server.");
return;
}
if (m_NavMeshAgent == null)
{
Debug.LogError("[ServerCharacterMovement] NavMeshAgent is null. Ensure it is assigned.");
return;
}
Debug.Log($"[ServerCharacterMovement] Starting forward charge for {name} with speed {speed} and duration {duration}.");
m_NavPath.Clear(); m_NavPath.Clear();
m_MovementState = MovementState.Charging; m_MovementState = MovementState.Charging;
m_ForcedSpeed = speed; m_ForcedSpeed = speed;
m_SpecialModeDurationRemaining = duration; m_SpecialModeDurationRemaining = duration;
} }
public void SetKinematic(bool isKinematic)
{
m_Rigidbody.isKinematic = isKinematic;
m_NavMeshAgent.enabled = !isKinematic; // Disable NavMeshAgent while kinematic
if (isKinematic)
{
m_Rigidbody.velocity = Vector3.zero; // Stop ongoing movement
}
}
public void StartKnockback(Vector3 knocker, float speed, float duration) public void StartKnockback(Vector3 knocker, float speed, float duration)
{ {
m_NavPath.Clear(); m_NavPath.Clear();

@ -81,7 +81,7 @@ namespace Unity.BossRoom.Gameplay.GameplayObjects
public Action DropActionPrototype => m_DropActionPrototype; public Action DropActionPrototype => m_DropActionPrototype;
public Action PickUpActionPrototype => m_PickUpActionPrototype; public Action PickUpActionPrototype => m_PickUpActionPrototype;
public string SlowDownAbilityKey = "DashNCrash"; public string SlowDownAbilityKey = "Slowdown";
List<Action> m_AllActions; List<Action> m_AllActions;

@ -44,29 +44,13 @@ namespace Unity.Multiplayer.Samples.BossRoom
return; return;
} }
bool giveScore = player.PreviousPlatformId != PlatformID;
// Check if the player who occupied this platform had this platform as their target platform
if (giveScore)
{
if (player.TargetPlatformId.HasValue && player.TargetPlatformId.Value == PlatformID)
{
// Successful swap
ScoreManager.Instance.AddPlayerScore(player.OwnerClientId, 10);
Debug.Log($"Player {player.OwnerClientId} successfully swapped to Platform {PlatformID}. Awarded 10 score.");
}
else
{
ScoreManager.Instance.AddPlayerScore(player.OwnerClientId, 20);
Debug.Log($"Crow Player {player.OwnerClientId} successfully stole Platform {PlatformID}. Awarded 20 score.");
}
}
IsOccupied = true; IsOccupied = true;
OccupierId.Value = player.OwnerClientId; OccupierId.Value = player.OwnerClientId;
player.OnArrivalOnPlatform(PlatformID); player.SetOnPlatform(true);
Debug.Log($"Platform {PlatformID} is now occupied by Player {player.OwnerClientId}."); Debug.Log($"Platform {PlatformID} is now occupied by Player {player.OwnerClientId}.");
} }
public void Vacate(ServerCharacter player) public void Vacate(ServerCharacter player)
{ {
if (!IsServer) if (!IsServer)
@ -83,7 +67,7 @@ namespace Unity.Multiplayer.Samples.BossRoom
IsOccupied = false; IsOccupied = false;
OccupierId.Value = 0; OccupierId.Value = 0;
player.OnLeavingPlatform(PlatformID); player.SetOnPlatform(false);
Debug.Log($"Platform {PlatformID} is now vacated."); Debug.Log($"Platform {PlatformID} is now vacated.");
} }
@ -97,6 +81,7 @@ namespace Unity.Multiplayer.Samples.BossRoom
if (!IsOccupied) if (!IsOccupied)
{ {
Occupy(player); Occupy(player);
player.OnArrivalOnPlatform();
} }
else else
{ {
@ -117,6 +102,7 @@ namespace Unity.Multiplayer.Samples.BossRoom
if (other.TryGetComponent<ServerCharacter>(out var player) && OccupierId.Value == player.OwnerClientId) if (other.TryGetComponent<ServerCharacter>(out var player) && OccupierId.Value == player.OwnerClientId)
{ {
Vacate(player); Vacate(player);
player.OnLeavingPlatform();
} }
} }
} }

@ -1,34 +0,0 @@
using UnityEngine;
using Unity.Netcode;
public class PlayerScoreComponent : NetworkBehaviour
{
public int CurrentScore { get; private set; }
public override void OnNetworkSpawn()
{
if (IsOwner && IsClient)
{
Debug.Log($"[PlayerScoreComponent] Requesting score initialization for Player {OwnerClientId}");
ScoreManager.Instance?.InitializePlayerScoreServerRpc(OwnerClientId);
}
// For the server player (host), ensure the PlayerScoreComponent is registered properly
if (IsServer && OwnerClientId == NetworkManager.Singleton.LocalClientId)
{
ScoreManager.Instance?.InitializePlayerScoreServerRpc(OwnerClientId);
}
}
public void UpdateScore(int newScore)
{
CurrentScore = newScore;
Debug.Log($"[PlayerScoreComponent] Player {OwnerClientId} score updated to {newScore}.");
UpdateScoreUI();
}
private void UpdateScoreUI()
{
// Update the player's score display in the UI.
Debug.Log($"[PlayerScoreComponent] Updated score UI for Player {OwnerClientId}: {CurrentScore}");
}
}

@ -1,11 +0,0 @@
fileFormatVersion: 2
guid: a73f85cd904406945a2192aaecb2c310
MonoImporter:
externalObjects: {}
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant:

@ -1,167 +0,0 @@
using System.Collections;
using System.Collections.Generic;
using Unity.Multiplayer.Samples.BossRoom;
using UnityEngine;
using Unity.Netcode;
public class ScoreManager : NetworkBehaviour
{
public static ScoreManager Instance { get; private set; }
private Dictionary<ulong, int> playerScores = new Dictionary<ulong, int>();
private void Awake()
{
if (Instance != null && Instance != this)
{
Destroy(gameObject);
return;
}
Instance = this;
}
public override void OnNetworkSpawn()
{
if (IsServer)
{
StartCrowPenaltyCoroutineServerRpc();
}
}
[ServerRpc(RequireOwnership = false)]
public void InitializePlayerScoreServerRpc(ulong ownerClientId)
{
if (!playerScores.ContainsKey(ownerClientId))
{
playerScores[ownerClientId] = 200;
Debug.Log($"[ScoreManager] Player {ownerClientId} initialized with a starting score of 200.");
UpdatePlayerScoreClientRpc(ownerClientId, 200);
}
else
{
Debug.LogWarning($"[ScoreManager] Player {ownerClientId} already initialized.");
}
}
public void UpdatePlayerScore(ulong ownerClientId, int newScore)
{
if (playerScores.ContainsKey(ownerClientId))
{
playerScores[ownerClientId] = newScore;
Debug.Log($"[ScoreManager] Updating Player {ownerClientId} score to {newScore}.");
UpdatePlayerScoreClientRpc(ownerClientId, newScore);
}
else
{
Debug.LogError($"[ScoreManager] No entry found for Player {ownerClientId}. Cannot update score.");
}
}
public void AddPlayerScore(ulong ownerClientId, int newScore)
{
if (playerScores.ContainsKey(ownerClientId))
{
playerScores[ownerClientId] += newScore;
Debug.Log($"[ScoreManager] Updating Player {ownerClientId} score to {playerScores[ownerClientId]}.");
UpdatePlayerScoreClientRpc(ownerClientId, playerScores[ownerClientId]);
}
else
{
Debug.LogError($"[ScoreManager] No entry found for Player {ownerClientId}. Cannot update score.");
}
}
public void SubtractPlayerScore(ulong ownerClientId, int scoreToSubtract)
{
if (playerScores.ContainsKey(ownerClientId))
{
int value = Mathf.Max(0, playerScores[ownerClientId] - scoreToSubtract);
playerScores[ownerClientId] = value;
Debug.Log($"[ScoreManager] Updating Player {ownerClientId} score to {playerScores[ownerClientId]}.");
UpdatePlayerScoreClientRpc(ownerClientId, playerScores[ownerClientId]);
}
else
{
Debug.LogError($"[ScoreManager] No entry found for Player {ownerClientId}. Cannot update score.");
}
}
public int GetPlayerScore(ulong ownerClientId)
{
if (playerScores.TryGetValue(ownerClientId, out var score))
{
return score;
}
Debug.LogError($"[ScoreManager] No entry found for Player {ownerClientId}.");
return 0; // Default score
}
[ServerRpc]
public void StartCrowPenaltyCoroutineServerRpc()
{
StartCoroutine(ApplyCrowPenaltyCoroutine());
}
private IEnumerator ApplyCrowPenaltyCoroutine()
{
yield return new WaitUntil(() => PlatformManager.Instance != null && PlatformManager.Instance.AreAllPlatformsOccupied());
while (true)
{
var modifications = new List<KeyValuePair<ulong, int>>();
foreach (var entry in playerScores)
{
var ownerClientId = entry.Key;
var score = entry.Value;
// Check if the player is the crow
if (CrowManager.Instance != null && CrowManager.Instance.GetCurrentCrow().OwnerClientId == ownerClientId)
{
var newScore = score - 2;
modifications.Add(new KeyValuePair<ulong, int>(ownerClientId, newScore));
Debug.Log($"[ScoreManager] Applied crow penalty to Player {ownerClientId}. New score: {newScore}");
}
}
// Apply the modifications after the iteration
foreach (var modification in modifications)
{
UpdatePlayerScore(modification.Key, modification.Value);
}
// Wait for the next penalty application
yield return new WaitForSeconds(5f);
}
}
[ClientRpc]
public void UpdatePlayerScoreClientRpc(ulong ownerClientId, int newScore)
{
Debug.Log($"[ScoreManager] Received score update for Player {ownerClientId}: {newScore}");
var playerScoreComponent = FindPlayerScoreComponent(ownerClientId);
if (playerScoreComponent != null)
{
playerScoreComponent.UpdateScore(newScore);
}
else
{
Debug.LogError($"[ScoreManager] Could not find PlayerScoreComponent for Player {ownerClientId}");
}
}
private PlayerScoreComponent FindPlayerScoreComponent(ulong ownerClientId)
{
foreach (var scoreComponent in FindObjectsOfType<PlayerScoreComponent>())
{
if (scoreComponent.OwnerClientId == ownerClientId)
{
return scoreComponent;
}
}
Debug.LogError($"[ScoreManager] Could not find PlayerScoreComponent for Player {ownerClientId}");
return null;
}
}

@ -1,11 +0,0 @@
fileFormatVersion: 2
guid: c42f66f946855da4b99f79c5bde1d545
MonoImporter:
externalObjects: {}
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant:

@ -0,0 +1,11 @@
using UnityEngine;
[CreateAssetMenu(menuName = "Abilities/Slow Zone Ability")]
public class SlowZoneAbility : Ability
{
protected override void Activate(GameObject owner)
{
// No direct logic here, spawning is handled in AbilitySystem
Debug.Log($"SlowZoneAbility activated by {owner.name}.");
}
}

@ -0,0 +1,86 @@
using System.Collections;
using System.Collections.Generic;
using Unity.BossRoom.Gameplay.GameplayObjects.Character;
using Unity.Netcode;
using UnityEngine;
using UnityEngine.AI;
public class SlowZonePrefab : NetworkBehaviour
{
[Header("Slow Zone Settings")]
public Ability Ability;
private void Start()
{
// Start the process to slow down players when the zone is spawned
StartCoroutine(ApplySlowEffect());
}
private IEnumerator ApplySlowEffect()
{
// Run the logic once immediately
ApplySlowToPlayers();
// Optionally, repeat the check while the zone exists
yield return new WaitForSeconds(Ability.abilityDuration);
// Destroy the zone after applying the slow effect
DespawnZone();
}
private void ApplySlowToPlayers()
{
// Find all colliders in the zone
Collider[] hitColliders = Physics.OverlapSphere(transform.position, Ability.abilityRadius);
foreach (var collider in hitColliders)
{
if (collider.TryGetComponent<ServerCharacter>(out var player))
{
// Check if the player is NOT the crow
if (!player.IsCrow)
{
// Apply slow effect
StartCoroutine(SlowPlayer(player));
Debug.Log($"{player.name} is slowed down!");
}
}
}
}
private IEnumerator SlowPlayer(ServerCharacter player)
{
// Halve the player's movement speed
player.Movement.SetSpeedModifier(Ability.abilityMagnitude);
// Wait for the slow duration
yield return new WaitForSeconds(Ability.abilityDuration);
// Restore the original speed
player.Movement.ResetSpeedModifier();
Debug.Log($"{player.name}'s speed is restored.");
Destroy(gameObject);
}
private void DespawnZone()
{
if (IsServer)
{
var networkObject = GetComponent<NetworkObject>();
if (networkObject != null)
{
networkObject.Despawn(true); // Despawn and destroy on the server
Debug.Log("SlowZonePrefab has been despawned and destroyed.");
}
else
{
Debug.LogError("SlowZonePrefab is missing a NetworkObject component!");
}
}
}
// Debug visualization for the slow zone in the editor
private void OnDrawGizmos()
{
Gizmos.color = Color.cyan;
Gizmos.DrawWireSphere(transform.position, Ability.abilityRadius);
}
}

@ -4,7 +4,7 @@
QualitySettings: QualitySettings:
m_ObjectHideFlags: 0 m_ObjectHideFlags: 0
serializedVersion: 5 serializedVersion: 5
m_CurrentQuality: 0 m_CurrentQuality: 4
m_QualitySettings: m_QualitySettings:
- serializedVersion: 3 - serializedVersion: 3
name: Low name: Low
@ -29,7 +29,6 @@ QualitySettings:
billboardsFaceCameraPosition: 0 billboardsFaceCameraPosition: 0
useLegacyDetailDistribution: 1 useLegacyDetailDistribution: 1
vSyncCount: 0 vSyncCount: 0
realtimeGICPUUsage: 25
lodBias: 0.3 lodBias: 0.3
maximumLODLevel: 1 maximumLODLevel: 1
enableLODCrossFade: 1 enableLODCrossFade: 1
@ -80,7 +79,6 @@ QualitySettings:
billboardsFaceCameraPosition: 0 billboardsFaceCameraPosition: 0
useLegacyDetailDistribution: 1 useLegacyDetailDistribution: 1
vSyncCount: 0 vSyncCount: 0
realtimeGICPUUsage: 25
lodBias: 0.4 lodBias: 0.4
maximumLODLevel: 0 maximumLODLevel: 0
enableLODCrossFade: 1 enableLODCrossFade: 1
@ -131,7 +129,6 @@ QualitySettings:
billboardsFaceCameraPosition: 1 billboardsFaceCameraPosition: 1
useLegacyDetailDistribution: 1 useLegacyDetailDistribution: 1
vSyncCount: 0 vSyncCount: 0
realtimeGICPUUsage: 25
lodBias: 1.5 lodBias: 1.5
maximumLODLevel: 0 maximumLODLevel: 0
enableLODCrossFade: 1 enableLODCrossFade: 1
@ -182,7 +179,6 @@ QualitySettings:
billboardsFaceCameraPosition: 1 billboardsFaceCameraPosition: 1
useLegacyDetailDistribution: 1 useLegacyDetailDistribution: 1
vSyncCount: 0 vSyncCount: 0
realtimeGICPUUsage: 50
lodBias: 2 lodBias: 2
maximumLODLevel: 0 maximumLODLevel: 0
enableLODCrossFade: 1 enableLODCrossFade: 1
@ -233,7 +229,6 @@ QualitySettings:
billboardsFaceCameraPosition: 0 billboardsFaceCameraPosition: 0
useLegacyDetailDistribution: 1 useLegacyDetailDistribution: 1
vSyncCount: 0 vSyncCount: 0
realtimeGICPUUsage: 50
lodBias: 0.4 lodBias: 0.4
maximumLODLevel: 1 maximumLODLevel: 1
enableLODCrossFade: 1 enableLODCrossFade: 1
@ -283,7 +278,6 @@ QualitySettings:
billboardsFaceCameraPosition: 0 billboardsFaceCameraPosition: 0
useLegacyDetailDistribution: 1 useLegacyDetailDistribution: 1
vSyncCount: 0 vSyncCount: 0
realtimeGICPUUsage: 100
lodBias: 1 lodBias: 1
maximumLODLevel: 0 maximumLODLevel: 0
enableLODCrossFade: 1 enableLODCrossFade: 1
@ -333,7 +327,6 @@ QualitySettings:
billboardsFaceCameraPosition: 0 billboardsFaceCameraPosition: 0
useLegacyDetailDistribution: 1 useLegacyDetailDistribution: 1
vSyncCount: 0 vSyncCount: 0
realtimeGICPUUsage: 25
lodBias: 1.5 lodBias: 1.5
maximumLODLevel: 0 maximumLODLevel: 0
enableLODCrossFade: 1 enableLODCrossFade: 1

Loading…
Cancel
Save