Add FloatingTextManager and FloatingText for displaying UI messages; update CollectableComponent and HealthComponent to utilize new floating text features

This commit is contained in:
2025-09-11 04:35:30 +02:00
parent f9cb59d182
commit f229ff5b7d
16 changed files with 131 additions and 139 deletions

View File

@@ -1,4 +1,4 @@
[gd_scene load_steps=22 format=4 uid="uid://bol7g83v2accs"]
[gd_scene load_steps=23 format=4 uid="uid://bol7g83v2accs"]
[ext_resource type="PackedScene" uid="uid://bqi5s710xb1ju" path="res://objects/entities/brick_player.tscn" id="1_dnj2y"]
[ext_resource type="PackedScene" uid="uid://cawlpch2lk3a2" path="res://objects/level/world_environment.tscn" id="2_1vw1j"]
@@ -13,6 +13,7 @@
[ext_resource type="TileSet" uid="uid://bc5a20s6kuy8e" path="res://resources/tilesets/village/entities.tres" id="10_ei558"]
[ext_resource type="TileSet" uid="uid://bbppo0irxdmqy" path="res://resources/tilesets/village/foreground.tres" id="11_w7c5i"]
[ext_resource type="PackedScene" uid="uid://d0s2abysa86rq" path="res://objects/entities/child.tscn" id="15_vqevu"]
[ext_resource type="PackedScene" uid="uid://bqom4cm7r18db" path="res://objects/entities/killzone.tscn" id="16_bxal3"]
[ext_resource type="PackedScene" uid="uid://12jnkdygpxwc" path="res://objects/entities/exit_level.tscn" id="16_chnw1"]
[ext_resource type="PackedScene" uid="uid://b4pdt1gv2ymyi" path="res://objects/tooltip.tscn" id="18_4bhfj"]
@@ -57,10 +58,7 @@ ease = 2
[node name="Brick Player" parent="." instance=ExtResource("1_dnj2y")]
z_index = 10
[node name="SkillManager" parent="Brick Player" index="15"]
script = null
[node name="HitParticles" parent="Brick Player" index="26"]
[node name="HitParticles" parent="Brick Player" index="25"]
process_material = SubResource("ParticleProcessMaterial_lgb3u")
[node name="WorldEnvironment" parent="." instance=ExtResource("2_1vw1j")]
@@ -144,6 +142,9 @@ Text = "LEVEL_1_TOOLTIP_2"
position = Vector2(-59, -247)
Text = "LEVEL_1_TOOLTIP_3"
[node name="Killzone" parent="." instance=ExtResource("16_bxal3")]
position = Vector2(704, 337)
[connection signal="Death" from="Brick Player/HealthComponent" to="UI Layer/DeathScreen" method="OnPlayerDeath"]
[connection signal="Death" from="Brick Player/HealthComponent" to="UI Layer/GameOverScreen" method="OnPlayerDeath"]

View File

@@ -1,4 +1,4 @@
[gd_scene load_steps=25 format=4 uid="uid://chqb11pfoqmeb"]
[gd_scene load_steps=26 format=4 uid="uid://chqb11pfoqmeb"]
[ext_resource type="PackedScene" uid="uid://bqi5s710xb1ju" path="res://objects/entities/brick_player.tscn" id="1_wcma7"]
[ext_resource type="PackedScene" uid="uid://cawlpch2lk3a2" path="res://objects/level/world_environment.tscn" id="2_ot3dy"]
@@ -13,6 +13,7 @@
[ext_resource type="TileSet" uid="uid://bbppo0irxdmqy" path="res://resources/tilesets/village/foreground.tres" id="11_r0ngp"]
[ext_resource type="TileSet" uid="uid://ccffmjebvuoaj" path="res://resources/tilesets/village/small_foreground.tres" id="13_lc0ll"]
[ext_resource type="PackedScene" uid="uid://12jnkdygpxwc" path="res://objects/entities/exit_level.tscn" id="15_hcsb6"]
[ext_resource type="PackedScene" uid="uid://bockkmyn8il4c" path="res://objects/entities/basic_enemy.tscn" id="16_h4uvs"]
[ext_resource type="PackedScene" uid="uid://d0s2abysa86rq" path="res://objects/entities/child.tscn" id="16_lc0ll"]
[ext_resource type="PackedScene" uid="uid://to2xnqev0pu1" path="res://objects/entities/cage.tscn" id="17_h4uvs"]
[ext_resource type="PackedScene" uid="uid://bwdlmualj6xbw" path="res://objects/entities/enemy.tscn" id="18_girek"]
@@ -59,6 +60,7 @@ ease = 2
[node name="Brick Player" parent="." instance=ExtResource("1_wcma7")]
z_index = 1
position = Vector2(-203, 9)
[node name="HitParticles" parent="Brick Player" index="25"]
process_material = SubResource("ParticleProcessMaterial_lgb3u")
@@ -66,9 +68,6 @@ process_material = SubResource("ParticleProcessMaterial_lgb3u")
[node name="VisibleOnScreenNotifier2D" parent="Brick Player" index="28"]
process_mode = 4
[node name="KillPlayerOutOfScreen" parent="Brick Player" index="29"]
process_mode = 4
[node name="WorldEnvironment" parent="." instance=ExtResource("2_ot3dy")]
[node name="UI Layer" parent="." instance=ExtResource("3_cjqhe")]
@@ -84,7 +83,7 @@ ComponentsToDisable = [NodePath("../../Brick Player")]
[node name="Camera2D" parent="." instance=ExtResource("5_8nvkd")]
physics_interpolation_mode = 1
position = Vector2(32, -16)
position = Vector2(-171, -7)
process_callback = 0
limit_left = -1952
limit_top = -1744
@@ -93,7 +92,7 @@ limit_bottom = 560
[node name="PhantomCamera2D" type="Node2D" parent="." node_paths=PackedStringArray("follow_target")]
top_level = true
position = Vector2(32, -16)
position = Vector2(-171, -7)
script = ExtResource("6_ono4h")
follow_mode = 5
follow_target = NodePath("../Brick Player")
@@ -142,6 +141,18 @@ position = Vector2(-1329, 184)
[node name="Enemies" type="Node" parent="."]
[node name="Enemy5" parent="Enemies" instance=ExtResource("16_h4uvs")]
position = Vector2(187, -784)
[node name="Enemy7" parent="Enemies" instance=ExtResource("16_h4uvs")]
position = Vector2(792, -784)
[node name="Enemy8" parent="Enemies" instance=ExtResource("16_h4uvs")]
position = Vector2(1147, -783)
[node name="Enemy10" parent="Enemies" instance=ExtResource("16_h4uvs")]
position = Vector2(1272, -143)
[node name="Enemy" parent="Enemies" instance=ExtResource("18_girek")]
position = Vector2(-1526, 256)
@@ -154,21 +165,9 @@ position = Vector2(-1190, 175)
[node name="Enemy4" parent="Enemies" instance=ExtResource("18_girek")]
position = Vector2(-1326, 320)
[node name="Enemy5" parent="Enemies" instance=ExtResource("18_girek")]
position = Vector2(1272, -143)
[node name="Enemy6" parent="Enemies" instance=ExtResource("18_girek")]
position = Vector2(1648, -352)
[node name="Enemy7" parent="Enemies" instance=ExtResource("18_girek")]
position = Vector2(1147, -783)
[node name="Enemy8" parent="Enemies" instance=ExtResource("18_girek")]
position = Vector2(187, -784)
[node name="Enemy9" parent="Enemies" instance=ExtResource("18_girek")]
position = Vector2(792, -784)
[node name="Lever" parent="." instance=ExtResource("20_h4uvs")]
position = Vector2(-231, -776)

View File

@@ -1,4 +1,4 @@
[gd_scene load_steps=30 format=4 uid="uid://h60obxmju6mo"]
[gd_scene load_steps=31 format=4 uid="uid://h60obxmju6mo"]
[ext_resource type="PackedScene" uid="uid://dyp4i4ru2j2jh" path="res://objects/fxs/explosion_fx.tscn" id="1_p30ax"]
[ext_resource type="PackedScene" uid="uid://dx80ivlvuuew4" path="res://objects/fxs/fire_fx.tscn" id="2_a7yjf"]
@@ -19,6 +19,7 @@
[ext_resource type="PackedScene" uid="uid://b4pdt1gv2ymyi" path="res://objects/tooltip.tscn" id="18_l3a7y"]
[ext_resource type="PackedScene" uid="uid://cawlpch2lk3a2" path="res://objects/level/world_environment.tscn" id="20_embdf"]
[ext_resource type="PackedScene" uid="uid://cywsu7yrtjdog" path="res://objects/level/global_light.tscn" id="21_fytod"]
[ext_resource type="PackedScene" uid="uid://bqom4cm7r18db" path="res://objects/entities/killzone.tscn" id="21_p30ax"]
[ext_resource type="PackedScene" uid="uid://t6h2ra7kjyq" path="res://objects/entities/small_heal_potion.tscn" id="23_m6h4x"]
[sub_resource type="TileSetAtlasSource" id="TileSetAtlasSource_j7bvy"]
@@ -294,7 +295,7 @@ z_index = 5
position = Vector2(903, -118)
metadata/_edit_group_ = true
[node name="HitParticles" parent="Brick Player" index="26"]
[node name="HitParticles" parent="Brick Player" index="25"]
process_material = SubResource("ParticleProcessMaterial_lgb3u")
[node name="Camera2D" parent="." instance=ExtResource("12_qhkyq")]
@@ -350,6 +351,9 @@ position = Vector2(1244, -41)
[node name="SmallHealPotion3" parent="." instance=ExtResource("23_m6h4x")]
position = Vector2(1359, -42)
[node name="Killzone" parent="." instance=ExtResource("21_p30ax")]
position = Vector2(2456, 815)
[connection signal="Death" from="Brick Player/HealthComponent" to="UI Layer/DeathScreen" method="OnPlayerDeath"]
[connection signal="Death" from="Brick Player/HealthComponent" to="UI Layer/GameOverScreen" method="OnPlayerDeath"]

View File

@@ -1,4 +1,4 @@
[gd_scene load_steps=37 format=4 uid="uid://bhad760x3vvco"]
[gd_scene load_steps=38 format=4 uid="uid://bhad760x3vvco"]
[ext_resource type="PackedScene" uid="uid://bqi5s710xb1ju" path="res://objects/entities/brick_player.tscn" id="1_k3uyd"]
[ext_resource type="PackedScene" uid="uid://bon6raeddf3tu" path="res://objects/entities/chaser.tscn" id="1_xraal"]
@@ -20,6 +20,7 @@
[ext_resource type="Script" uid="uid://ctg4awndvgfd8" path="res://scripts/components/WaveTriggerComponent.cs" id="20_e6jir"]
[ext_resource type="PackedScene" uid="uid://to2xnqev0pu1" path="res://objects/entities/cage.tscn" id="20_l8w2k"]
[ext_resource type="PackedScene" uid="uid://dkqa3q6j2gof4" path="res://objects/entities/spaceship_exit.tscn" id="21_e6jir"]
[ext_resource type="Script" uid="uid://diw6opv6yutgi" path="res://scripts/components/KillPlayerOutOfScreenComponent.cs" id="21_o1yb3"]
[sub_resource type="Gradient" id="Gradient_l8w2k"]
offsets = PackedFloat32Array(0)
@@ -194,10 +195,7 @@ process_mode = 4
[node name="OneWayPlatformAbility" parent="Brick Player/Movements" index="3"]
process_mode = 4
[node name="SkillManager" parent="Brick Player" index="15"]
script = null
[node name="HitParticles" parent="Brick Player" index="26"]
[node name="HitParticles" parent="Brick Player" index="25"]
process_material = SubResource("ParticleProcessMaterial_lgb3u")
[node name="Enemies" type="Node2D" parent="."]
@@ -302,6 +300,12 @@ collision_mask = 4
[node name="CollisionShape2D" type="CollisionShape2D" parent="First Wave Area"]
shape = SubResource("RectangleShape2D_o1yb3")
[node name="KillPlayerOutOfScreenComponent" type="Node" parent="." node_paths=PackedStringArray("ScreenNotifier", "HealthComponent")]
script = ExtResource("21_o1yb3")
ScreenNotifier = NodePath("../Brick Player/VisibleOnScreenNotifier2D")
HealthComponent = NodePath("../Brick Player/HealthComponent")
metadata/_custom_type_script = "uid://diw6opv6yutgi"
[connection signal="Death" from="Brick Player/HealthComponent" to="UI Layer/DeathScreen" method="OnPlayerDeath"]
[connection signal="Death" from="Brick Player/HealthComponent" to="UI Layer/GameOverScreen" method="OnPlayerDeath"]
[connection signal="SpaceshipEntered" from="Spaceship Enter" to="Chaser/ChaseLevelComponent" method="OnShipEntered"]