Fix enemy return ball two times each time
This commit is contained in:
parent
a9a9f05296
commit
2b11ec8638
|
@ -4,7 +4,7 @@ extends CharacterBody2D
|
||||||
const y_offset = -10
|
const y_offset = -10
|
||||||
const player_path = "/root/Main/TileMap/Player"
|
const player_path = "/root/Main/TileMap/Player"
|
||||||
const enemy_path = "/root/Main/TileMap/Enemy"
|
const enemy_path = "/root/Main/TileMap/Enemy"
|
||||||
signal notify_enemy(new_target)
|
signal notify_enemy(ball_target: Vector2i)
|
||||||
var speed = 100
|
var speed = 100
|
||||||
var target = Vector2.ZERO
|
var target = Vector2.ZERO
|
||||||
@onready var tile_map: TileMap = get_parent()
|
@onready var tile_map: TileMap = get_parent()
|
||||||
|
@ -23,12 +23,14 @@ func update_target(new_target: Vector2i):
|
||||||
tile_map.reset_and_set_target_cell(new_target)
|
tile_map.reset_and_set_target_cell(new_target)
|
||||||
|
|
||||||
func _on_player_hit_ball():
|
func _on_player_hit_ball():
|
||||||
var new_target = tile_map.get_random_top_cell()
|
var new_target: Vector2i = tile_map.get_random_top_cell()
|
||||||
update_target(new_target)
|
update_target(new_target)
|
||||||
notify_enemy.emit(new_target)
|
notify_enemy.emit(new_target)
|
||||||
|
|
||||||
func _on_enemy_hit_ball():
|
func _on_enemy_hit_ball():
|
||||||
update_target(tile_map.get_random_bottom_cell())
|
var new_target: Vector2i = tile_map.get_random_bottom_cell()
|
||||||
|
update_target(new_target)
|
||||||
|
notify_enemy.emit(new_target)
|
||||||
|
|
||||||
func connect_player():
|
func connect_player():
|
||||||
var player = get_node(player_path)
|
var player = get_node(player_path)
|
||||||
|
|
|
@ -3,8 +3,8 @@ extends ConditionLeaf
|
||||||
|
|
||||||
func tick(actor, _blackboard):
|
func tick(actor, _blackboard):
|
||||||
if (
|
if (
|
||||||
actor.next_target != null &&
|
|
||||||
actor.ball_in_game() &&
|
actor.ball_in_game() &&
|
||||||
|
actor.next_destination != null &&
|
||||||
!actor.collide_with_ball
|
!actor.collide_with_ball
|
||||||
):
|
):
|
||||||
return SUCCESS
|
return SUCCESS
|
||||||
|
|
|
@ -4,8 +4,8 @@ extends ConditionLeaf
|
||||||
func tick(actor, _blackboard):
|
func tick(actor, _blackboard):
|
||||||
if (
|
if (
|
||||||
actor.ball_in_game() &&
|
actor.ball_in_game() &&
|
||||||
actor.next_target != null &&
|
actor.collide_with_ball &&
|
||||||
actor.collide_with_ball
|
!actor.ball_aims_to_bottom
|
||||||
):
|
):
|
||||||
return SUCCESS
|
return SUCCESS
|
||||||
return FAILURE
|
return FAILURE
|
||||||
|
|
|
@ -1,10 +0,0 @@
|
||||||
class_name CanWaitCodition
|
|
||||||
extends ConditionLeaf
|
|
||||||
|
|
||||||
func tick(actor, _blackboard):
|
|
||||||
if (
|
|
||||||
actor.next_target == null
|
|
||||||
):
|
|
||||||
|
|
||||||
return SUCCESS
|
|
||||||
return FAILURE
|
|
|
@ -2,5 +2,5 @@ class_name GetBallDestinationAction
|
||||||
extends ActionLeaf
|
extends ActionLeaf
|
||||||
|
|
||||||
func tick(actor: Node, blackboard: Blackboard):
|
func tick(actor: Node, blackboard: Blackboard):
|
||||||
blackboard.set_value("destination", actor.next_target)
|
blackboard.set_value("destination", actor.next_destination)
|
||||||
return SUCCESS
|
return SUCCESS
|
||||||
|
|
|
@ -11,6 +11,7 @@ func tick(actor: Node, blackboard: Blackboard):
|
||||||
actor.move_to(destination)
|
actor.move_to(destination)
|
||||||
|
|
||||||
if actor.position == destination:
|
if actor.position == destination:
|
||||||
|
actor.next_destination == null
|
||||||
return SUCCESS
|
return SUCCESS
|
||||||
return RUNNING
|
return RUNNING
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@ extends ActionLeaf
|
||||||
func before_run(actor, _blackboard):
|
func before_run(actor, _blackboard):
|
||||||
actor.play_hit_ball_animation()
|
actor.play_hit_ball_animation()
|
||||||
|
|
||||||
func tick(actor, blackboard):
|
func tick(actor, _blackboard):
|
||||||
if !actor.hit_ball_animation_finished:
|
if !actor.hit_ball_animation_finished:
|
||||||
return RUNNING
|
return RUNNING
|
||||||
actor.throw_ball()
|
actor.throw_ball()
|
||||||
|
|
|
@ -1,8 +0,0 @@
|
||||||
class_name WaitAction
|
|
||||||
extends ActionLeaf
|
|
||||||
|
|
||||||
func before_run(actor, _blackboard):
|
|
||||||
actor.play_idle_animation()
|
|
||||||
|
|
||||||
func tick(_actor, _blackboard):
|
|
||||||
return RUNNING
|
|
|
@ -6,9 +6,10 @@ const ball_name = "Ball"
|
||||||
const y_spawn_offset = -8
|
const y_spawn_offset = -8
|
||||||
signal hit_ball
|
signal hit_ball
|
||||||
var speed = 80
|
var speed = 80
|
||||||
var next_target
|
var next_destination
|
||||||
var collide_with_ball = false
|
var collide_with_ball = false
|
||||||
var hit_ball_animation_finished = false
|
var hit_ball_animation_finished = false
|
||||||
|
var ball_aims_to_bottom = false
|
||||||
@onready var tile_map: TileMap = get_parent()
|
@onready var tile_map: TileMap = get_parent()
|
||||||
@onready var animation_player = $AnimationPlayer
|
@onready var animation_player = $AnimationPlayer
|
||||||
@onready var sprite = $Sprite2D
|
@onready var sprite = $Sprite2D
|
||||||
|
@ -32,7 +33,6 @@ func throw_ball():
|
||||||
|
|
||||||
func return_ball():
|
func return_ball():
|
||||||
hit_ball.emit()
|
hit_ball.emit()
|
||||||
next_target = null
|
|
||||||
|
|
||||||
func flip_sprite(destination):
|
func flip_sprite(destination):
|
||||||
sprite.flip_h = position.x > destination.x
|
sprite.flip_h = position.x > destination.x
|
||||||
|
@ -52,9 +52,13 @@ func play_walk_animation():
|
||||||
func _on_hit_ball_animation_finished(_anim_name):
|
func _on_hit_ball_animation_finished(_anim_name):
|
||||||
hit_ball_animation_finished = true
|
hit_ball_animation_finished = true
|
||||||
|
|
||||||
func _on_notify_enemy(new_target):
|
func _on_notify_enemy(ball_target: Vector2i):
|
||||||
# TODO: add to new_target an offset depending from where the enemy come from
|
if tile_map.is_in_bottom_area(ball_target):
|
||||||
next_target = tile_map.map_to_local(new_target)
|
ball_aims_to_bottom = true
|
||||||
|
else:
|
||||||
|
ball_aims_to_bottom = false
|
||||||
|
# TODO: add to ball_target an offset depending from where the enemy come from
|
||||||
|
next_destination = tile_map.map_to_local(ball_target)
|
||||||
|
|
||||||
func _on_area_2d_body_entered(_body):
|
func _on_area_2d_body_entered(_body):
|
||||||
collide_with_ball = true
|
collide_with_ball = true
|
||||||
|
|
|
@ -31,38 +31,36 @@ func draw_wall():
|
||||||
for x in range(map_width):
|
for x in range(map_width):
|
||||||
set_cell(1, Vector2i(x - 1, middle_height - 1), wall_tile_source_id, Vector2i(0, 0), 0) # why have we to add -1?
|
set_cell(1, Vector2i(x - 1, middle_height - 1), wall_tile_source_id, Vector2i(0, 0), 0) # why have we to add -1?
|
||||||
|
|
||||||
func get_top_spawn_cell():
|
func get_top_spawn_cell() -> Vector2i:
|
||||||
return Vector2i(floor(map_width / 2.0), 1)
|
return Vector2i(floor(map_width / 2.0), 1)
|
||||||
|
|
||||||
func get_bottom_spawn_cell():
|
func get_bottom_spawn_cell() -> Vector2i:
|
||||||
return Vector2i(floor(map_width / 2.0), map_height - 2)
|
return Vector2i(floor(map_width / 2.0), map_height - 2)
|
||||||
|
|
||||||
func get_random_top_cell():
|
func get_random_top_cell() -> Vector2i:
|
||||||
var w = get_area_width()
|
var w = get_area_width()
|
||||||
var h = get_top_area_height()
|
var h = get_top_area_height()
|
||||||
|
|
||||||
return Vector2i(randi_range(w.x, w.y), randi_range(h.x, h.y))
|
return Vector2i(randi_range(w.x, w.y), randi_range(h.x, h.y))
|
||||||
|
|
||||||
func get_random_bottom_cell():
|
func get_random_bottom_cell() -> Vector2i:
|
||||||
var w = get_area_width()
|
var w = get_area_width()
|
||||||
var h = get_bottom_area_height()
|
var h = get_bottom_area_height()
|
||||||
|
|
||||||
return Vector2i(randi_range(w.x, w.y), randi_range(h.x, h.y))
|
return Vector2i(randi_range(w.x, w.y), randi_range(h.x, h.y))
|
||||||
|
|
||||||
func is_in_bottom_area(local_position: Vector2):
|
func is_in_bottom_area(cell: Vector2i) -> bool:
|
||||||
var map_position = local_to_map(local_position)
|
|
||||||
var height = get_bottom_area_height()
|
var height = get_bottom_area_height()
|
||||||
|
return cell.y >= height.x && cell.y <= height.y
|
||||||
return map_position.y >= height.x && map_position.y <= height.y
|
|
||||||
|
|
||||||
func get_area_width():
|
func get_area_width() -> Vector2i:
|
||||||
return Vector2i(0, map_width - 1)
|
return Vector2i(0, map_width - 1)
|
||||||
|
|
||||||
func get_top_area_height():
|
func get_top_area_height() -> Vector2i:
|
||||||
var middle_height = floor(map_height / 2.0)
|
var middle_height = floor(map_height / 2.0)
|
||||||
return Vector2i(0, middle_height - 1)
|
return Vector2i(0, middle_height - 1)
|
||||||
|
|
||||||
func get_bottom_area_height():
|
func get_bottom_area_height() -> Vector2i:
|
||||||
var middle_height = floor(map_height / 2.0)
|
var middle_height = floor(map_height / 2.0)
|
||||||
return Vector2i(middle_height + 1, map_height - 1)
|
return Vector2i(middle_height + 1, map_height - 1)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue