started adding enemy factory
This commit is contained in:
60
Assets/Darkmatter/Code/Domain/Enemy/AttackState.cs
Normal file
60
Assets/Darkmatter/Code/Domain/Enemy/AttackState.cs
Normal file
@@ -0,0 +1,60 @@
|
||||
using Darkmatter.Core;
|
||||
using System;
|
||||
using UnityEngine;
|
||||
|
||||
namespace Darkmatter.Domain
|
||||
{
|
||||
public class AttackState : State<EnemyStateMachine>
|
||||
{
|
||||
public AttackState(EnemyStateMachine runner) : base(runner) { }
|
||||
private IEnemyAnimController enemyAnimController => runner.enemyAnimController;
|
||||
private IEnemyPawn enemyPawn => runner.enemyPawn;
|
||||
|
||||
public override void Enter()
|
||||
{
|
||||
base.Enter();
|
||||
Debug.Log("Entered Attack State");
|
||||
Debug.Log("Attacking Player");
|
||||
enemyAnimController.PlayAttackAnim(true);
|
||||
enemyPawn.OnHealthDecreased += HandleHealth;
|
||||
}
|
||||
|
||||
private void HandleHealth(float health)
|
||||
{
|
||||
if (health <= 0)
|
||||
{
|
||||
runner.Die();
|
||||
}
|
||||
}
|
||||
public override void Update()
|
||||
{
|
||||
if (enemyPawn.isDead) return;
|
||||
base.Update();
|
||||
HandleAttack();
|
||||
CheckForStateBreak();
|
||||
|
||||
}
|
||||
|
||||
private void CheckForStateBreak()
|
||||
{
|
||||
if(!runner.PlayerInAttackRange())
|
||||
{
|
||||
runner.ChangeState(new ChaseState(runner));
|
||||
}
|
||||
}
|
||||
|
||||
private void HandleAttack()
|
||||
{
|
||||
Vector3 dir = (enemyPawn.PlayerTarget.position - enemyPawn.ReturnMyPos()).normalized;
|
||||
//rotate towards player and handle Attack here
|
||||
}
|
||||
|
||||
public override void Exit()
|
||||
{
|
||||
base.Exit();
|
||||
Debug.Log("Exiting Attack State");
|
||||
enemyAnimController.PlayAttackAnim(false);
|
||||
enemyPawn.OnHealthDecreased -= HandleHealth;
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user