serious improvements on Ai and now has reload and rudimentary search
This commit is contained in:
@@ -1,6 +1,17 @@
|
||||
extends EnemyState
|
||||
class_name EnemyAttack
|
||||
|
||||
@export var initial_wait_time : float = 1.0
|
||||
@export var between_shot_time : Vector2 = Vector2(.5,2.0)
|
||||
@export var alert_sound : AudioStreamPlayer3D
|
||||
|
||||
var initial_timer
|
||||
var shot_timer = 0.0
|
||||
|
||||
func Enter():
|
||||
initial_timer = initial_wait_time
|
||||
alert_sound.play()
|
||||
|
||||
func Physics_Update(delta):
|
||||
if enemy.is_player_visible():
|
||||
#get player location
|
||||
@@ -10,10 +21,58 @@ func Physics_Update(delta):
|
||||
#move and look at location
|
||||
move_to_nav_point(delta)
|
||||
turret_look3D(delta)
|
||||
|
||||
#Initial wait time
|
||||
if initial_timer > 0:
|
||||
initial_timer -= delta
|
||||
else:
|
||||
#fire if player in view
|
||||
if enemy.ammo > 0:
|
||||
if shot_timer > 0:
|
||||
shot_timer -= delta
|
||||
else:
|
||||
shot_timer = randf_range(between_shot_time.x,between_shot_time.y)
|
||||
enemy.turret_material.emission_enabled = true
|
||||
await get_tree().create_timer(.1).timeout
|
||||
attack()
|
||||
else:
|
||||
await get_tree().create_timer(.5).timeout
|
||||
Transitioned.emit(self,"reload")
|
||||
|
||||
else:
|
||||
Transitioned.emit(self,"idle") #when search is working make this search
|
||||
Transitioned.emit(self,"search")
|
||||
|
||||
func update_player_target():
|
||||
move_target = enemy.player_last_seen
|
||||
look_target = enemy.player_last_seen + Vector3(0,.75,0)
|
||||
enemy.nav_agent.set_target_position(move_target)
|
||||
|
||||
func attack():
|
||||
fire(enemy.barrel_1)
|
||||
enemy.smoke.emitting = true
|
||||
await get_tree().create_timer(.1).timeout
|
||||
fire(enemy.barrel_2)
|
||||
enemy.smoke_2.emitting = true
|
||||
enemy.turret_material.emission_enabled = false
|
||||
|
||||
func fire(barrel):
|
||||
enemy.ammo -= 1
|
||||
var instance_bullet = enemy.bullet.instantiate()
|
||||
instance_bullet.position = barrel.global_position
|
||||
instance_bullet.transform.basis = barrel.global_transform.basis
|
||||
instance_bullet.bullet_speed = enemy.bullet_speed
|
||||
instance_bullet.bullet_drop = enemy.bullet_drop
|
||||
instance_bullet.random_spread_amt = enemy.random_spread_amt
|
||||
instance_bullet.bullet_damage = enemy.bullet_damage
|
||||
instance_bullet.fired_by = enemy
|
||||
instance_bullet.target_type = enemy.enemy_type
|
||||
get_tree().get_root().add_child(instance_bullet)
|
||||
enemy.audio_fire.play()
|
||||
spawn_casing()
|
||||
|
||||
func spawn_casing():
|
||||
var instance_casing = enemy.casing.instantiate()
|
||||
instance_casing.position = enemy.casing_ejector.global_position
|
||||
instance_casing.transform.basis = enemy.casing_ejector.global_transform.basis
|
||||
instance_casing.player_velocity = enemy.velocity * enemy.transform.basis
|
||||
get_tree().get_root().add_child(instance_casing)
|
||||
|
||||
Reference in New Issue
Block a user