Compare commits
4 Commits
456cc8dafb
...
f2a1834589
Author | SHA1 | Date | |
---|---|---|---|
f2a1834589 | |||
2e1f3ccf7e | |||
fc2f18d9cb | |||
6938b246dc |
BIN
Assets/JYY/Prefabs/Alien Big Blink.prefab
(Stored with Git LFS)
BIN
Assets/JYY/Prefabs/Alien Big Blink.prefab
(Stored with Git LFS)
Binary file not shown.
BIN
Assets/JYY/Prefabs/Bullets/Magic Missaile.prefab
(Stored with Git LFS)
BIN
Assets/JYY/Prefabs/Bullets/Magic Missaile.prefab
(Stored with Git LFS)
Binary file not shown.
BIN
Assets/JYY/Scenes/MonsterTest.unity
(Stored with Git LFS)
BIN
Assets/JYY/Scenes/MonsterTest.unity
(Stored with Git LFS)
Binary file not shown.
@ -28,7 +28,7 @@ public class VerticalAoeController : AoeControllerBase
|
||||
protected override void HitCheck()
|
||||
{
|
||||
// 박스 판정 (사각형 직선)
|
||||
Vector3 halfExtents = new Vector3(_data.radius, 1f, _data.radius * 2f);
|
||||
Vector3 halfExtents = new Vector3(_data.radius, 1f, _data.radius * 2f) * 0.5f;
|
||||
Collider[] hits = Physics.OverlapBox(transform.position, halfExtents, transform.rotation, _data.targetLayer);
|
||||
|
||||
foreach (var hit in hits)
|
||||
@ -47,7 +47,7 @@ public class VerticalAoeController : AoeControllerBase
|
||||
|
||||
private void OnDrawGizmosSelected()
|
||||
{
|
||||
Gizmos.color = Color.red;
|
||||
Gizmos.color = Color.yellow;
|
||||
Vector3 center = transform.position;
|
||||
Vector3 size = new Vector3(_data.radius, 1f, _data.radius * 2f);
|
||||
Gizmos.matrix = Matrix4x4.TRS(center, transform.rotation, Vector3.one);
|
||||
|
@ -26,6 +26,9 @@ public class BulletBase : MonoBehaviour
|
||||
// 내부용
|
||||
private Vector3 _direction = Vector3.forward;
|
||||
private float _timer;
|
||||
private Vector3 _prevPosition;
|
||||
|
||||
[SerializeField] private LayerMask _targetLayer;
|
||||
|
||||
public virtual void Initialize(BulletData bulletData)
|
||||
{
|
||||
@ -40,31 +43,41 @@ public class BulletBase : MonoBehaviour
|
||||
transform.rotation = Quaternion.LookRotation(_direction);
|
||||
|
||||
_timer = 0f;
|
||||
_prevPosition = transform.position;
|
||||
}
|
||||
|
||||
private void Update()
|
||||
{
|
||||
// 1) 이동
|
||||
transform.position += _direction * (_speed * Time.deltaTime);
|
||||
float moveDist = _speed * Time.deltaTime;
|
||||
|
||||
// 2) 수명 카운트
|
||||
// 1) Raycast 충돌 검사
|
||||
if (Physics.Raycast(_prevPosition, _direction, out RaycastHit hit, moveDist, _targetLayer))
|
||||
{
|
||||
// 닿은 지점으로 이동
|
||||
transform.position = hit.point;
|
||||
OnBulletHit(hit);
|
||||
return;
|
||||
}
|
||||
|
||||
// 2) 실제 이동
|
||||
transform.position += _direction * moveDist;
|
||||
_prevPosition = transform.position;
|
||||
|
||||
// 3) 수명 검사
|
||||
_timer += Time.deltaTime;
|
||||
if (_timer >= _lifeTime)
|
||||
{
|
||||
DestroyBullet();
|
||||
}
|
||||
}
|
||||
|
||||
private void OnTriggerEnter(Collider other)
|
||||
private void OnBulletHit(RaycastHit hit)
|
||||
{
|
||||
// TODO: 주인공 캐릭터를 찾는 로직 추가 필요
|
||||
// 주인공 스크립트를 찾아 처리할 것.
|
||||
var character = other.GetComponent<CharacterBase>();
|
||||
if (character != null)
|
||||
PlayerController playerController = hit.transform.GetComponent<PlayerController>();
|
||||
Debug.Log(hit.transform.name);
|
||||
if (playerController != null)
|
||||
{
|
||||
character.TakeDamage(_damage);
|
||||
DestroyBullet();
|
||||
playerController.TakeDamage(_damage);
|
||||
}
|
||||
DestroyBullet();
|
||||
}
|
||||
|
||||
protected virtual void DestroyBullet()
|
||||
|
@ -5,8 +5,6 @@ using Random = UnityEngine.Random;
|
||||
|
||||
public class CasterDemonController : EnemyController
|
||||
{
|
||||
|
||||
|
||||
// Animation
|
||||
public static readonly int Cast = Animator.StringToHash("Cast");
|
||||
public static readonly int Flee = Animator.StringToHash("Flee");
|
||||
|
Loading…
x
Reference in New Issue
Block a user