look like it works now, i did a workaround, dunno what this issue was 💀

This commit is contained in:
Tabby 2025-08-11 23:34:05 +10:00
parent 7584cf0b19
commit 8c0860a840
8 changed files with 64 additions and 44 deletions

View file

@ -3,6 +3,8 @@ extends CharacterBody2D
const SPEED = 170.0
const JUMP_VELOCITY = -400.0
var ready_to_door : bool = true
@export var doorBox : Area2D
func _physics_process(delta: float) -> void:
@ -16,22 +18,33 @@ func _physics_process(delta: float) -> void:
# Get the input direction and handle the movement/deceleration.
# As good practice, you should replace UI actions with custom gameplay actions.
var direction := Input.get_vector("left","right","up","down")
if direction:
if direction and Router.player_mode:
velocity = direction * SPEED
else:
velocity = velocity.move_toward(Vector2(0,0), SPEED)
move_and_slide()
if !doorBox.has_overlapping_areas():
ready_to_door = true
func _on_door_box_area_entered(area: Area2D) -> void:
print(area.name)
if area.name == "DoorIn":
global_position = area.get_parent().get_parent().door_out_node.global_position
Router.activate_seg.emit(Router.cur_id + 1)
# +1 seg
elif area.name == "DoorOut":
global_position = area.get_parent().get_parent().door_in_node.global_position
Router.activate_seg.emit(Router.cur_id - 1)
# -1 seg
if ready_to_door:
if area.name == "DoorIn":
global_position = area.get_parent().get_parent().door_out_node.global_position
#Router.activate_seg.emit(Router.cur_id + 1)
if (area.get_parent().get_parent().prev_seg):
Router.activate_seg.emit(area.get_parent().get_parent().prev_seg.seg_id)
ready_to_door = false
# +1 seg
elif area.name == "DoorOut":
global_position = area.get_parent().get_parent().door_in_node.global_position
if (area.get_parent().get_parent().this_seg):
Router.activate_seg.emit(area.get_parent().get_parent().this_seg.seg_id)
ready_to_door = false
#Router.activate_seg.emit(Router.cur_id - 1)
# -1 seg