Fixed blood and also made blood better
This commit is contained in:
parent
8f7d31d742
commit
5dc812c55f
|
@ -1,6 +1,7 @@
|
||||||
using System.Collections;
|
using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using UnityEngine;
|
using UnityEngine;
|
||||||
|
using UnityEngine.AI;
|
||||||
|
|
||||||
public class EnemyAnimationHandler : MonoBehaviour
|
public class EnemyAnimationHandler : MonoBehaviour
|
||||||
{
|
{
|
||||||
|
@ -15,6 +16,9 @@ public class EnemyAnimationHandler : MonoBehaviour
|
||||||
}
|
}
|
||||||
void EnemyDie()
|
void EnemyDie()
|
||||||
{
|
{
|
||||||
|
GetComponent<Collider2D>().enabled = false;
|
||||||
|
GetComponent<NavMeshAgent>().enabled = false;
|
||||||
|
|
||||||
StartCoroutine(AnimationDie());
|
StartCoroutine(AnimationDie());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,6 +29,7 @@ public class EnemyPathFinding : MonoBehaviour
|
||||||
Vector2 dir = closestTarget.position - transform.position;
|
Vector2 dir = closestTarget.position - transform.position;
|
||||||
if (Physics2D.Raycast(transform.position, dir.normalized, ropeDistCheck, ropeCheckMask)) return;
|
if (Physics2D.Raycast(transform.position, dir.normalized, ropeDistCheck, ropeCheckMask)) return;
|
||||||
|
|
||||||
|
|
||||||
agent.SetDestination(closestTarget.position);
|
agent.SetDestination(closestTarget.position);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ using UnityUtils;
|
||||||
|
|
||||||
public class HealthComponent : MonoBehaviour, ISquezeDamageReceiver
|
public class HealthComponent : MonoBehaviour, ISquezeDamageReceiver
|
||||||
{
|
{
|
||||||
|
[SerializeField] private bool onlyCallZeroHealthOnce = true;
|
||||||
[SerializeField] float maxHealth = 100;
|
[SerializeField] float maxHealth = 100;
|
||||||
|
|
||||||
[SerializeField] float damageTickDelay = 0.25f;
|
[SerializeField] float damageTickDelay = 0.25f;
|
||||||
|
@ -26,6 +27,8 @@ public class HealthComponent : MonoBehaviour, ISquezeDamageReceiver
|
||||||
[SerializeField]
|
[SerializeField]
|
||||||
float squezeDamageScalor = 1f;
|
float squezeDamageScalor = 1f;
|
||||||
|
|
||||||
|
bool alreadyReachedZero = false;
|
||||||
|
|
||||||
void Awake()
|
void Awake()
|
||||||
{
|
{
|
||||||
currentHealth = maxHealth;
|
currentHealth = maxHealth;
|
||||||
|
@ -62,12 +65,19 @@ public class HealthComponent : MonoBehaviour, ISquezeDamageReceiver
|
||||||
accumulatedDamageInTick += damage;
|
accumulatedDamageInTick += damage;
|
||||||
|
|
||||||
if (currentHealth <= 0) {
|
if (currentHealth <= 0) {
|
||||||
|
if (alreadyReachedZero && onlyCallZeroHealthOnce) return;
|
||||||
|
|
||||||
|
alreadyReachedZero = true;
|
||||||
// Make sure to flush accumulated when dying
|
// Make sure to flush accumulated when dying
|
||||||
if (accumulatedDamageInTick > 1f)
|
if (accumulatedDamageInTick > 1f)
|
||||||
OnHealthChangeAtPos?.Invoke(transform.position.Add(y: 2f), accumulatedDamageInTick);
|
OnHealthChangeAtPos?.Invoke(transform.position.Add(y: 2f), accumulatedDamageInTick);
|
||||||
|
|
||||||
OnHealthZero?.Invoke();
|
OnHealthZero?.Invoke();
|
||||||
BloodComputeShader.Instance.createBlood(transform.position, (int)(maxHealth *maxHealth * BloodComputeShader.Instance.scoreMult), maxHealth / 8.0f);
|
|
||||||
|
int blood = (int)(maxHealth * 100.0f * BloodComputeShader.Instance.scoreMult);
|
||||||
|
|
||||||
|
BloodComputeShader.Instance.createBlood(transform.position, blood/2, maxHealth / 8.0f);
|
||||||
|
BloodComputeShader.Instance.createBlood(transform.position, blood / 2, maxHealth / 8.0f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue