From 24a8f1b156ea92e7b0ad60052521e1430a77e13f Mon Sep 17 00:00:00 2001 From: Daniel Weipert Date: Mon, 30 Dec 2024 11:41:09 +0100 Subject: fix drop through wall bug --- character/character.gd | 31 +++++++++++++++++++------------ character/character.tscn | 4 ++-- 2 files changed, 21 insertions(+), 14 deletions(-) (limited to 'character') diff --git a/character/character.gd b/character/character.gd index ef18bbc..764c02e 100644 --- a/character/character.gd +++ b/character/character.gd @@ -150,21 +150,28 @@ func is_on_floor() -> bool: return $RayDownLeft.is_colliding() or $RayDownRight.is_colliding() -func is_on_ledge() -> bool: - return true - pass - # TODO: add two more down Rays - # and up rays for is_below wall and is_below_ledge - # to fix falling through wall - # funktion im base-game aber auch gar nicht vorhanden:) +func _is_on_ledge() -> bool: + var is_on := false + + if $RayDownLeft.is_colliding(): + is_on = is_on or $RayDownLeft.get_collider().is_ledge($RayDownLeft.get_collision_point()) + + if $RayDownRight.is_colliding(): + is_on = is_on or $RayDownRight.get_collider().is_ledge($RayDownRight.get_collision_point()) + + return is_on -func is_on_bottom_floor() -> bool: - var stage: Stage = get_tree().current_scene - var map: TileMapLayer = get_tree().get_first_node_in_group("tilemap") - var bottom = position.y + (get_sprite_size().y / 2) + map.tile_set.tile_size.y +func is_on_solid_floor() -> bool: + var is_on := false + + if $RayDownLeft.is_colliding(): + is_on = is_on or $RayDownLeft.get_collider().is_wall($RayDownLeft.get_collision_point()) + + if $RayDownRight.is_colliding(): + is_on = is_on or $RayDownRight.get_collider().is_wall($RayDownRight.get_collision_point()) - return bottom >= stage.get_world_boundaries()[Vector2.DOWN] + return is_on func is_below_ceiling() -> bool: diff --git a/character/character.tscn b/character/character.tscn index 7fb9776..4c163cd 100644 --- a/character/character.tscn +++ b/character/character.tscn @@ -25,11 +25,11 @@ shape = SubResource("RectangleShape2D_wfm33") [node name="RayLeft" type="RayCast2D" parent="."] target_position = Vector2(-8, 0) -collision_mask = 256 +collision_mask = 768 [node name="RayRight" type="RayCast2D" parent="."] target_position = Vector2(8, 0) -collision_mask = 256 +collision_mask = 768 [node name="RayUpLeft" type="RayCast2D" parent="."] position = Vector2(-6, 0) -- cgit v1.2.3