몬스터 감지 범위 캐릭터 따라가지 않던 문제 수정
This commit is contained in:
@@ -83,7 +83,7 @@ namespace TON
|
|||||||
void Start()
|
void Start()
|
||||||
{
|
{
|
||||||
|
|
||||||
ReadCSV();
|
ReadCsv();
|
||||||
|
|
||||||
// dicMonster 사용 예시
|
// dicMonster 사용 예시
|
||||||
if (dicMonster.ContainsKey("1")) // 키 존재 확인
|
if (dicMonster.ContainsKey("1")) // 키 존재 확인
|
||||||
@@ -111,7 +111,7 @@ namespace TON
|
|||||||
_animator.Play(newState);
|
_animator.Play(newState);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ReadCSV()
|
private void ReadCsv()
|
||||||
{
|
{
|
||||||
TextAsset csvFile = Resources.Load<TextAsset>("Monster");
|
TextAsset csvFile = Resources.Load<TextAsset>("Monster");
|
||||||
|
|
||||||
@@ -166,7 +166,6 @@ namespace TON
|
|||||||
|
|
||||||
if (_isWalking)
|
if (_isWalking)
|
||||||
{
|
{
|
||||||
// walking 상태에서 walkingTime을 초과할 경우 idle 애니메이션 재생
|
|
||||||
transform.Translate(_direction * speed * Time.deltaTime);
|
transform.Translate(_direction * speed * Time.deltaTime);
|
||||||
|
|
||||||
if (Time.realtimeSinceStartup - _currentTime >= walkingTime)
|
if (Time.realtimeSinceStartup - _currentTime >= walkingTime)
|
||||||
@@ -178,10 +177,8 @@ namespace TON
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// 지금 기다렸던 시간이 idleTime을 초과할 경우에 walk 애니메이션 재생
|
|
||||||
if (Time.realtimeSinceStartup - _currentTime >= _idleTime)
|
if (Time.realtimeSinceStartup - _currentTime >= _idleTime)
|
||||||
{
|
{
|
||||||
// 초기화
|
|
||||||
_currentTime = Time.realtimeSinceStartup;
|
_currentTime = Time.realtimeSinceStartup;
|
||||||
|
|
||||||
if (_isWalking == false)
|
if (_isWalking == false)
|
||||||
@@ -195,6 +192,21 @@ namespace TON
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Detect 및 공격 처리
|
||||||
|
if (_isDetect && _target != null)
|
||||||
|
{
|
||||||
|
// 플레이어와 몬스터 간의 거리 계산
|
||||||
|
float distance = Vector3.Distance(transform.position, _target.transform.position);
|
||||||
|
|
||||||
|
if (distance < 1.5f) // 일정 거리 이내에서 공격
|
||||||
|
{
|
||||||
|
Attack(_target);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Detect(_target); // 플레이어가 가까이 오면 추적
|
||||||
|
}
|
||||||
|
}
|
||||||
// 걷기 애니메이션으로 변경
|
// 걷기 애니메이션으로 변경
|
||||||
// ChangeAnimationState(AniWalk);
|
// ChangeAnimationState(AniWalk);
|
||||||
// _animator.SetBool("Walk", _isWalking); // 걷기 애니메이션
|
// _animator.SetBool("Walk", _isWalking); // 걷기 애니메이션
|
||||||
@@ -224,8 +236,7 @@ namespace TON
|
|||||||
public void Attack(GameObject player)
|
public void Attack(GameObject player)
|
||||||
{
|
{
|
||||||
ChangeAnimationState(AniAttack);
|
ChangeAnimationState(AniAttack);
|
||||||
// _animator.Play("Attack");
|
|
||||||
_animator.SetTrigger("Attack");
|
|
||||||
// 임시 반영 수정 예정
|
// 임시 반영 수정 예정
|
||||||
DamageCalculator damageCalculator = new DamageCalculator();
|
DamageCalculator damageCalculator = new DamageCalculator();
|
||||||
|
|
||||||
@@ -241,28 +252,16 @@ namespace TON
|
|||||||
|
|
||||||
public void Detect(GameObject target)
|
public void Detect(GameObject target)
|
||||||
{
|
{
|
||||||
if (target == null) return; // 타겟이 null이면 함수 종료
|
if (target == null) return;
|
||||||
|
|
||||||
// 타겟의 위치에서 내 현재 위치를 빼서 방향 벡터를 구함
|
|
||||||
UnityEngine.Vector2 direction = target.transform.position - transform.position;
|
UnityEngine.Vector2 direction = target.transform.position - transform.position;
|
||||||
|
|
||||||
// 방향 벡터의 크기가 0이 아니면 (즉, 타겟이 존재하면) 이동
|
|
||||||
if (direction.magnitude > 0)
|
if (direction.magnitude > 0)
|
||||||
{
|
{
|
||||||
// 방향 벡터를 정규화하여 길이를 1로 만들고, 속도를 곱하여 이동
|
|
||||||
transform.Translate(direction.normalized * speed * Time.deltaTime);
|
transform.Translate(direction.normalized * speed * Time.deltaTime);
|
||||||
|
ChangeAnimationState(AniWalk);
|
||||||
// 걷기 애니메이션 재생
|
|
||||||
_animator.SetBool("Walk", true);
|
|
||||||
|
|
||||||
// 타겟 방향으로 몬스터 이미지 뒤집기
|
|
||||||
_spriteRenderer.flipX = direction.x < 0;
|
_spriteRenderer.flipX = direction.x < 0;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
// 타겟과 몬스터가 같은 위치에 있으면 걷기 애니메이션 중지
|
|
||||||
_animator.SetBool("Walk", false);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user