From 542251725c1641311fe197c9ec9921fc9cca7db0 Mon Sep 17 00:00:00 2001 From: Darius Date: Mon, 3 Feb 2025 21:02:30 -0500 Subject: [PATCH] badguys, autoloads, custom resources, collectibles --- .../assets/graphics/collectibles/coin.png | Bin 0 -> 500 bytes .../graphics/collectibles/coin.png.import | 34 ++ .../assets/graphics/enemies/slime_green.png | Bin 0 -> 908 bytes .../graphics/enemies/slime_green.png.import | 34 ++ dariusgodotproject/project.godot | 4 + dariusgodotproject/scenes/badguy.tscn | 73 +++ dariusgodotproject/scenes/coin.tscn | 115 +++++ dariusgodotproject/scenes/game.tscn | 30 +- dariusgodotproject/scenes/level2.tscn | 477 ++++++++++++++++++ dariusgodotproject/scripts/badguy.gd | 27 + dariusgodotproject/scripts/coin.gd | 8 + dariusgodotproject/scripts/gamecontroller.gd | 72 ++- .../scripts/res/characterstats.gd | 5 + .../scripts/res/playerstats.tres | 9 + .../scripts/res/slimestats.tres | 9 + dariusgodotproject/scripts/scenemanager.gd | 31 +- 16 files changed, 898 insertions(+), 30 deletions(-) create mode 100644 dariusgodotproject/assets/graphics/collectibles/coin.png create mode 100644 dariusgodotproject/assets/graphics/collectibles/coin.png.import create mode 100644 dariusgodotproject/assets/graphics/enemies/slime_green.png create mode 100644 dariusgodotproject/assets/graphics/enemies/slime_green.png.import create mode 100644 dariusgodotproject/scenes/badguy.tscn create mode 100644 dariusgodotproject/scenes/coin.tscn create mode 100644 dariusgodotproject/scenes/level2.tscn create mode 100644 dariusgodotproject/scripts/badguy.gd create mode 100644 dariusgodotproject/scripts/coin.gd create mode 100644 dariusgodotproject/scripts/res/characterstats.gd create mode 100644 dariusgodotproject/scripts/res/playerstats.tres create mode 100644 dariusgodotproject/scripts/res/slimestats.tres diff --git a/dariusgodotproject/assets/graphics/collectibles/coin.png b/dariusgodotproject/assets/graphics/collectibles/coin.png new file mode 100644 index 0000000000000000000000000000000000000000..01ae33d70b398db7f1f7bcafe883a0a469805201 GIT binary patch literal 500 zcmV^r!6hi!Wct>kSmw76A*+mkqIDVjdDL!Rb}5E?Td;C@2y9S zHih2xK(yTWh+gXdrTqK8Uwx^_$MoI4V|67Hn26^Qp-rJ*c_3P5d_*tx|6%^yEznE& zeE6^KHvJ|vI7934d=L#ytZIR)9hxaN1Jm8sZ6_j{Yx1#nTWt!D2<;1?{VNX?M*l~R zzukKP+i+D+FAlB;7qkOXfaGA?&h>EX&+$Oxqgs>{d4C#zhd05hUS`kO@{&+Bb`?-H zKXwYn7Ms9B!`F}PQh%-o65r;4=uy!A4;g>*6iCRL!wF!o{9{X0YM%Mf@U=DvM2}Kx zY#A;!e+4Y{Qh#m^NPMe5dkcj0f5`ZIy8@JYG2kpkh}LrU76{dHI?&Z}2LKX(>v1MX z4k6>OaQ_N1p97frj@jdSpELonJ&y=&3jN9h(K6#Bda3^x^WUBW>`ee7IfzLSUk<|l qVg27u071wNc?u+CjZ6R`YyJS*Ofbr5QwY-l0000JWrs--17qeTsRD5g z!(g=zZP^CRNrf+-+NH@KR$Td0s&mngVw3+xu0?EXcCBM}?K8i`C}Wk?V1NhZ=gNnL znwH6IezGFZ!~9a6?RHUyhPV4>Uu{?_FnfW>zS{qPKK*<4uVTZ$ce_63>1Q2~5psEW zx_|#J@#X97|9=sRdr@7gG^K>%S{q!=tk;zc{umA757CW^gF~?Y* zzL@Q4_FeSScBuyG05^_0b=8H-_E|RV`0{(oCG+JLF?=tr`x)+BFt>laYl`#E_4#US z^)8yV;ydQc)Lt=IzWv`O|NWa{=kBflzObA3)w^Aa^ZVqko^^cn|Ic5O3*}M*OaJxH zkT2-?mBRcbPJn+~%B^6jY(87p9(Mo#>Q7(h~rm&XFcnS2%Pu(#j4I<=R1EbeZ((y;O5o?wIy5Q|G$2J-k$H; z`tsE}e}z7FZ&xe&&T>;Ie$t&EuHB#RoL~6BudegQ(e6(xj^8Zaa&Il$W#4ySE~~5m zTfmt7%O>)U?6I5hEH)mc^Zy7i2AYE5_cS8+Pd zEL*XBwVBru|99M6hFkZ|y>aAN9DmO}@fM%8>yNRi-8VbG`yY1_&*gmzOfw=rUyaF+ zc6a>UWOJqT@=>+Yz0nhwE57CCn(*tmRI)?YzOxPXujg|0Ui|Qj8JN8oJYD@<);T3K F0RY5^vzq__ literal 0 HcmV?d00001 diff --git a/dariusgodotproject/assets/graphics/enemies/slime_green.png.import b/dariusgodotproject/assets/graphics/enemies/slime_green.png.import new file mode 100644 index 0000000..9f0b3f1 --- /dev/null +++ b/dariusgodotproject/assets/graphics/enemies/slime_green.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="CompressedTexture2D" +uid="uid://ds7phwfwavsqj" +path="res://.godot/imported/slime_green.png-5261ffd1254c816fe62b35227a9aa11d.ctex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://assets/graphics/enemies/slime_green.png" +dest_files=["res://.godot/imported/slime_green.png-5261ffd1254c816fe62b35227a9aa11d.ctex"] + +[params] + +compress/mode=0 +compress/high_quality=false +compress/lossy_quality=0.7 +compress/hdr_compression=1 +compress/normal_map=0 +compress/channel_pack=0 +mipmaps/generate=false +mipmaps/limit=-1 +roughness/mode=0 +roughness/src_normal="" +process/fix_alpha_border=true +process/premult_alpha=false +process/normal_map_invert_y=false +process/hdr_as_srgb=false +process/hdr_clamp_exposure=false +process/size_limit=0 +detect_3d/compress_to=1 diff --git a/dariusgodotproject/project.godot b/dariusgodotproject/project.godot index bb0bbac..75f9976 100644 --- a/dariusgodotproject/project.godot +++ b/dariusgodotproject/project.godot @@ -15,6 +15,10 @@ run/main_scene="res://scenes/game.tscn" config/features=PackedStringArray("4.3", "Forward Plus") config/icon="res://icon.svg" +[autoload] + +Gamecontroller="*res://scripts/gamecontroller.gd" + [display] window/size/viewport_width=320 diff --git a/dariusgodotproject/scenes/badguy.tscn b/dariusgodotproject/scenes/badguy.tscn new file mode 100644 index 0000000..b4af5a3 --- /dev/null +++ b/dariusgodotproject/scenes/badguy.tscn @@ -0,0 +1,73 @@ +[gd_scene load_steps=9 format=3 uid="uid://clitp4u6pd426"] + +[ext_resource type="Script" path="res://scripts/badguy.gd" id="1_pb36v"] +[ext_resource type="Texture2D" uid="uid://ds7phwfwavsqj" path="res://assets/graphics/enemies/slime_green.png" id="2_5h7r7"] + +[sub_resource type="AtlasTexture" id="AtlasTexture_s1yph"] +atlas = ExtResource("2_5h7r7") +region = Rect2(0, 24, 24, 24) + +[sub_resource type="AtlasTexture" id="AtlasTexture_ft2a6"] +atlas = ExtResource("2_5h7r7") +region = Rect2(24, 24, 24, 24) + +[sub_resource type="AtlasTexture" id="AtlasTexture_gg3ce"] +atlas = ExtResource("2_5h7r7") +region = Rect2(48, 24, 24, 24) + +[sub_resource type="AtlasTexture" id="AtlasTexture_dlo6y"] +atlas = ExtResource("2_5h7r7") +region = Rect2(72, 24, 24, 24) + +[sub_resource type="SpriteFrames" id="SpriteFrames_dgoyr"] +animations = [{ +"frames": [{ +"duration": 1.0, +"texture": SubResource("AtlasTexture_s1yph") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_ft2a6") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_gg3ce") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_dlo6y") +}], +"loop": true, +"name": &"idle", +"speed": 12.0 +}] + +[sub_resource type="RectangleShape2D" id="RectangleShape2D_i8bk0"] +size = Vector2(15, 18) + +[node name="Area2D" type="Area2D" groups=["enemies"]] +script = ExtResource("1_pb36v") +metadata/_edit_group_ = true + +[node name="AnimatedSprite2D" type="AnimatedSprite2D" parent="."] +texture_filter = 1 +sprite_frames = SubResource("SpriteFrames_dgoyr") +animation = &"idle" +frame_progress = 0.764829 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="."] +position = Vector2(0, 2) +shape = SubResource("RectangleShape2D_i8bk0") + +[node name="RightRay" type="RayCast2D" parent="."] +target_position = Vector2(14, 0) + +[node name="LeftRay" type="RayCast2D" parent="."] +target_position = Vector2(-14, 0) + +[node name="RightFloorRay" type="RayCast2D" parent="."] +position = Vector2(9, 0) +target_position = Vector2(0, 18) + +[node name="LeftFloorRay" type="RayCast2D" parent="."] +position = Vector2(-9, 0) +target_position = Vector2(0, 18) + +[connection signal="body_entered" from="." to="." method="_on_body_entered"] diff --git a/dariusgodotproject/scenes/coin.tscn b/dariusgodotproject/scenes/coin.tscn new file mode 100644 index 0000000..2d86cd8 --- /dev/null +++ b/dariusgodotproject/scenes/coin.tscn @@ -0,0 +1,115 @@ +[gd_scene load_steps=17 format=3 uid="uid://ix6oxq0kduyx"] + +[ext_resource type="Script" path="res://scripts/coin.gd" id="1_kw45h"] +[ext_resource type="Texture2D" uid="uid://ctbrb4hwshrkl" path="res://assets/graphics/collectibles/coin.png" id="1_tmebn"] + +[sub_resource type="AtlasTexture" id="AtlasTexture_irnie"] +atlas = ExtResource("1_tmebn") +region = Rect2(0, 0, 16, 16) + +[sub_resource type="AtlasTexture" id="AtlasTexture_jhywm"] +atlas = ExtResource("1_tmebn") +region = Rect2(16, 0, 16, 16) + +[sub_resource type="AtlasTexture" id="AtlasTexture_6rvld"] +atlas = ExtResource("1_tmebn") +region = Rect2(32, 0, 16, 16) + +[sub_resource type="AtlasTexture" id="AtlasTexture_cywpa"] +atlas = ExtResource("1_tmebn") +region = Rect2(48, 0, 16, 16) + +[sub_resource type="AtlasTexture" id="AtlasTexture_icagv"] +atlas = ExtResource("1_tmebn") +region = Rect2(64, 0, 16, 16) + +[sub_resource type="AtlasTexture" id="AtlasTexture_d4baf"] +atlas = ExtResource("1_tmebn") +region = Rect2(80, 0, 16, 16) + +[sub_resource type="AtlasTexture" id="AtlasTexture_ctthx"] +atlas = ExtResource("1_tmebn") +region = Rect2(96, 0, 16, 16) + +[sub_resource type="AtlasTexture" id="AtlasTexture_d8p0y"] +atlas = ExtResource("1_tmebn") +region = Rect2(112, 0, 16, 16) + +[sub_resource type="AtlasTexture" id="AtlasTexture_1gnvv"] +atlas = ExtResource("1_tmebn") +region = Rect2(128, 0, 16, 16) + +[sub_resource type="AtlasTexture" id="AtlasTexture_h2wnc"] +atlas = ExtResource("1_tmebn") +region = Rect2(144, 0, 16, 16) + +[sub_resource type="AtlasTexture" id="AtlasTexture_pri0k"] +atlas = ExtResource("1_tmebn") +region = Rect2(160, 0, 16, 16) + +[sub_resource type="AtlasTexture" id="AtlasTexture_gltpj"] +atlas = ExtResource("1_tmebn") +region = Rect2(176, 0, 16, 16) + +[sub_resource type="SpriteFrames" id="SpriteFrames_gsi5m"] +animations = [{ +"frames": [{ +"duration": 1.0, +"texture": SubResource("AtlasTexture_irnie") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_jhywm") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_6rvld") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_cywpa") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_icagv") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_d4baf") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_ctthx") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_d8p0y") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_1gnvv") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_h2wnc") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_pri0k") +}, { +"duration": 1.0, +"texture": SubResource("AtlasTexture_gltpj") +}], +"loop": true, +"name": &"idle", +"speed": 12.0 +}] + +[sub_resource type="CircleShape2D" id="CircleShape2D_4cxdg"] +radius = 3.0 + +[node name="Area2D" type="Area2D" groups=["collectibles"]] +script = ExtResource("1_kw45h") +metadata/_edit_group_ = true + +[node name="AnimatedSprite2D" type="AnimatedSprite2D" parent="."] +texture_filter = 1 +sprite_frames = SubResource("SpriteFrames_gsi5m") +animation = &"idle" +autoplay = "idle" +frame_progress = 0.730621 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="."] +shape = SubResource("CircleShape2D_4cxdg") + +[connection signal="body_entered" from="." to="." method="_on_body_entered"] diff --git a/dariusgodotproject/scenes/game.tscn b/dariusgodotproject/scenes/game.tscn index 6f0eae5..de7e0f4 100644 --- a/dariusgodotproject/scenes/game.tscn +++ b/dariusgodotproject/scenes/game.tscn @@ -1,7 +1,6 @@ -[gd_scene load_steps=16 format=4 uid="uid://dcmyx5g6dksl8"] +[gd_scene load_steps=17 format=4 uid="uid://dcmyx5g6dksl8"] [ext_resource type="PackedScene" uid="uid://d1ej2kiy7jcpv" path="res://scenes/crate.tscn" id="1_uivx3"] -[ext_resource type="Script" path="res://scripts/gamecontroller.gd" id="1_vhl00"] [ext_resource type="Script" path="res://scripts/trigger.gd" id="3_2qbah"] [ext_resource type="PackedScene" uid="uid://b75mow511wmmb" path="res://scenes/player.tscn" id="3_8h5jv"] [ext_resource type="Texture2D" uid="uid://jlbx6yvcmten" path="res://assets/graphics/terrains/backgrounds/forestbackground.png" id="3_umlo6"] @@ -10,6 +9,8 @@ [ext_resource type="PackedScene" uid="uid://dwfife67i1fmr" path="res://scenes/bullet.tscn" id="5_7yfvg"] [ext_resource type="Script" path="res://scripts/scenemanager.gd" id="6_n2kp0"] [ext_resource type="Texture2D" uid="uid://btdvc25chjgd" path="res://assets/graphics/terrains/Terrain (32x32).png" id="7_v20os"] +[ext_resource type="PackedScene" uid="uid://ix6oxq0kduyx" path="res://scenes/coin.tscn" id="10_nxy68"] +[ext_resource type="PackedScene" uid="uid://clitp4u6pd426" path="res://scenes/badguy.tscn" id="11_dbqj0"] [sub_resource type="TileSetAtlasSource" id="TileSetAtlasSource_3ut3v"] texture = ExtResource("7_v20os") @@ -381,7 +382,6 @@ distance = -181.0 [sub_resource type="CircleShape2D" id="CircleShape2D_mfh1j"] [node name="Game" type="Node2D"] -script = ExtResource("1_vhl00") [node name="SceneManager" type="Node" parent="."] unique_name_in_owner = true @@ -410,7 +410,7 @@ texture = ExtResource("4_201fr") [node name="TileMapLayer" type="TileMapLayer" parent="."] position = Vector2(-220, -413) -tile_map_data = PackedByteArray("AAALABMAAAAEAAEAAAALABQAAAAEAAEAAAALABUAAAAEAAEAAAALABYAAAAPAAQAAAAMABYAAAAQAAMAAAAMABcAAAAPAAQAAAANABcAAAABAAQAAAAOABcAAAAKAAMAAAAOABgAAAAAAAIAAAAPABcAAAACAAAAAAAPABgAAAAJAAQAAAAQABgAAAABAAQAAAARABgAAAABAAQAAAASABgAAAABAAQAAAATABgAAAACAAQAAAAUABkAAAAAAAQAAAAVABkAAAABAAQAAAAWABkAAAABAAQAAAAXABkAAAABAAQAAAAYABkAAAABAAQAAAAZABkAAAABAAQAAAAaABkAAAABAAQAAAAbABkAAAABAAQAAAAcABkAAAABAAQAAAAdABkAAAABAAQAAAAeABkAAAAKAAMAAAAeABoAAAAAAAIAAAAfABoAAAACAAIAAAAfABkAAAAJAAMAAAAgABkAAAAQAAQAAAAgABgAAAAPAAMAAAAhABgAAAABAAQAAAAiABgAAAABAAQAAAAjABgAAAACAAQAAAAJABIAAAABAAAAAAAKABIAAAABAAAAAAALABIAAAABAAAAAAAMABIAAAABAAAAAAANABIAAAABAAQAAAAIABIAAAABAAAAAAAHABIAAAAKAAMAAAAOABIAAAABAAQAAAAPABIAAAABAAQAAAAQABIAAAACAAQAAAATABIAAAAAAAQAAAAUABIAAAABAAQAAAAVABIAAAABAAQAAAAWABIAAAABAAQAAAAXABIAAAABAAQAAAAYABIAAAABAAQAAAAZABIAAAABAAQAAAAaABIAAAAKAAMAAAA=") +tile_map_data = PackedByteArray("AAALABMAAAAEAAEAAAALABQAAAAEAAEAAAALABUAAAAEAAEAAAALABYAAAAPAAQAAAAMABYAAAAQAAMAAAAMABcAAAAPAAQAAAANABcAAAABAAQAAAAOABcAAAAKAAMAAAAOABgAAAAAAAIAAAAPABcAAAACAAAAAAAPABgAAAAJAAQAAAAQABgAAAABAAQAAAARABgAAAABAAQAAAASABgAAAABAAQAAAATABgAAAACAAQAAAAUABkAAAAAAAQAAAAVABkAAAABAAQAAAAWABkAAAABAAQAAAAXABkAAAABAAQAAAAYABkAAAABAAQAAAAZABkAAAABAAQAAAAaABkAAAABAAQAAAAbABkAAAABAAQAAAAcABkAAAABAAQAAAAdABkAAAABAAQAAAAeABkAAAAKAAMAAAAeABoAAAAAAAIAAAAfABoAAAACAAIAAAAfABkAAAAJAAMAAAAgABkAAAAQAAQAAAAgABgAAAAPAAMAAAAhABgAAAABAAQAAAAiABgAAAABAAQAAAAjABgAAAACAAQAAAAJABIAAAABAAAAAAAKABIAAAABAAAAAAALABIAAAABAAAAAAAMABIAAAABAAAAAAANABIAAAABAAQAAAAIABIAAAABAAAAAAAHABIAAAAKAAMAAAAOABIAAAAMAAQAAAAPABIAAAAMAAQAAAAQABIAAAACAAQAAAATABIAAAAAAAQAAAAUABIAAAAMAAQAAAAVABIAAAAMAAQAAAAWABIAAAAMAAQAAAAXABIAAAAMAAQAAAAYABIAAAABAAQAAAAZABIAAAABAAQAAAAaABIAAAAKAAMAAAAPABEAAAAEAAEAAAAPABAAAAAPAAMAAAAQABAAAAANAAQAAAAQAA8AAAANAAMAAAARAA8AAAABAAQAAAASAA8AAAABAAQAAAATAA8AAAABAAQAAAAUAA8AAAACAAQAAAAUABAAAAAAAAQAAAAUABEAAAANAAMAAAAVABEAAAAPAAAAAAAOABEAAAAQAAMAAAAWABEAAAANAAMAAAAVABAAAAAQAAMAAAAXABEAAAAQAAMAAAA=") tile_set = SubResource("TileSet_ixl4j") [node name="StaticBody2D" type="StaticBody2D" parent="."] @@ -429,7 +429,7 @@ shape = SubResource("WorldBoundaryShape2D_bqh70") [node name="CharacterBody2D" parent="." instance=ExtResource("3_8h5jv")] [node name="Area2D" type="Area2D" parent="."] -position = Vector2(269, 55) +position = Vector2(359, 141) scale = Vector2(5, 5) script = ExtResource("3_2qbah") metadata/_edit_group_ = true @@ -463,5 +463,25 @@ rotation = 0.806532 position = Vector2(57, 39) rotation = 0.806532 +[node name="RigidBody2D6" parent="crates" instance=ExtResource("1_uivx3")] +position = Vector2(200, 74) +rotation = 0.806532 + +[node name="coins" type="Node2D" parent="."] + +[node name="Area2D3" parent="coins" instance=ExtResource("10_nxy68")] +position = Vector2(330, 40) + +[node name="Area2D" parent="coins" instance=ExtResource("10_nxy68")] +position = Vector2(370, 40) + +[node name="Area2D2" parent="coins" instance=ExtResource("10_nxy68")] +position = Vector2(400, 40) + +[node name="enemies" type="Node2D" parent="."] + +[node name="Area2D3" parent="enemies" instance=ExtResource("11_dbqj0")] +position = Vector2(369, 55) + [connection signal="areaTrigger" from="Area2D" to="." method="_on_trigger"] [connection signal="body_entered" from="Area2D" to="Area2D" method="_on_body_entered"] diff --git a/dariusgodotproject/scenes/level2.tscn b/dariusgodotproject/scenes/level2.tscn new file mode 100644 index 0000000..4388846 --- /dev/null +++ b/dariusgodotproject/scenes/level2.tscn @@ -0,0 +1,477 @@ +[gd_scene load_steps=15 format=4 uid="uid://d383o6j0l3d2m"] + +[ext_resource type="Script" path="res://scripts/scenemanager.gd" id="1_g37ru"] +[ext_resource type="Texture2D" uid="uid://jlbx6yvcmten" path="res://assets/graphics/terrains/backgrounds/forestbackground.png" id="2_ehg0h"] +[ext_resource type="Texture2D" uid="uid://8kaggg1kilxy" path="res://assets/graphics/terrains/backgrounds/skystrip.png" id="3_8wilj"] +[ext_resource type="Texture2D" uid="uid://b3smxb17ijk60" path="res://assets/graphics/terrains/backgrounds/midtrees.png" id="4_qwx2h"] +[ext_resource type="Texture2D" uid="uid://btdvc25chjgd" path="res://assets/graphics/terrains/Terrain (32x32).png" id="5_p6mo5"] +[ext_resource type="PackedScene" uid="uid://b75mow511wmmb" path="res://scenes/player.tscn" id="6_7tdkp"] +[ext_resource type="Script" path="res://scripts/trigger.gd" id="7_2y6a6"] +[ext_resource type="PackedScene" uid="uid://ix6oxq0kduyx" path="res://scenes/coin.tscn" id="9_fv1rd"] +[ext_resource type="PackedScene" uid="uid://d1ej2kiy7jcpv" path="res://scenes/crate.tscn" id="9_sys65"] + +[sub_resource type="TileSetAtlasSource" id="TileSetAtlasSource_3ut3v"] +texture = ExtResource("5_p6mo5") +texture_region_size = Vector2i(32, 32) +0:0/0 = 0 +0:0/0/terrain_set = 0 +0:0/0/terrain = 0 +0:0/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +0:0/0/terrains_peering_bit/right_side = 0 +0:0/0/terrains_peering_bit/bottom_right_corner = 0 +0:0/0/terrains_peering_bit/bottom_side = 0 +1:0/0 = 0 +1:0/0/terrain_set = 0 +1:0/0/terrain = 0 +1:0/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +1:0/0/terrains_peering_bit/right_side = 0 +1:0/0/terrains_peering_bit/bottom_right_corner = 0 +1:0/0/terrains_peering_bit/bottom_side = 0 +1:0/0/terrains_peering_bit/bottom_left_corner = 0 +1:0/0/terrains_peering_bit/left_side = 0 +2:0/0 = 0 +2:0/0/terrain_set = 0 +2:0/0/terrain = 0 +2:0/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +2:0/0/terrains_peering_bit/bottom_side = 0 +2:0/0/terrains_peering_bit/bottom_left_corner = 0 +2:0/0/terrains_peering_bit/left_side = 0 +4:0/0 = 0 +4:0/0/terrain_set = 0 +4:0/0/terrain = 0 +4:0/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +4:0/0/terrains_peering_bit/bottom_side = 0 +6:0/0 = 0 +6:0/0/terrain_set = 0 +6:0/0/terrain = 0 +6:0/0/terrains_peering_bit/right_side = 0 +6:0/0/terrains_peering_bit/bottom_side = 0 +6:0/0/terrains_peering_bit/bottom_left_corner = 0 +6:0/0/terrains_peering_bit/left_side = 0 +6:0/0/terrains_peering_bit/top_left_corner = 0 +6:0/0/terrains_peering_bit/top_side = 0 +6:0/0/terrains_peering_bit/top_right_corner = 0 +7:0/0 = 0 +7:0/0/terrain_set = 0 +7:0/0/terrain = 0 +7:0/0/terrains_peering_bit/right_side = 0 +7:0/0/terrains_peering_bit/bottom_right_corner = 0 +7:0/0/terrains_peering_bit/bottom_side = 0 +7:0/0/terrains_peering_bit/left_side = 0 +7:0/0/terrains_peering_bit/top_left_corner = 0 +7:0/0/terrains_peering_bit/top_side = 0 +7:0/0/terrains_peering_bit/top_right_corner = 0 +9:0/0 = 0 +9:0/0/terrain_set = 0 +9:0/0/terrain = 0 +9:0/0/terrains_peering_bit/right_side = 0 +9:0/0/terrains_peering_bit/bottom_right_corner = 0 +9:0/0/terrains_peering_bit/bottom_side = 0 +9:0/0/terrains_peering_bit/bottom_left_corner = 0 +9:0/0/terrains_peering_bit/left_side = 0 +9:0/0/terrains_peering_bit/top_side = 0 +10:0/0 = 0 +10:0/0/terrain_set = 0 +10:0/0/terrain = 0 +10:0/0/terrains_peering_bit/right_side = 0 +10:0/0/terrains_peering_bit/bottom_side = 0 +10:0/0/terrains_peering_bit/bottom_left_corner = 0 +10:0/0/terrains_peering_bit/left_side = 0 +10:0/0/terrains_peering_bit/top_left_corner = 0 +10:0/0/terrains_peering_bit/top_side = 0 +12:0/0 = 0 +12:0/0/terrain_set = 0 +12:0/0/terrain = 0 +12:0/0/terrains_peering_bit/right_side = 0 +12:0/0/terrains_peering_bit/bottom_right_corner = 0 +12:0/0/terrains_peering_bit/bottom_side = 0 +12:0/0/terrains_peering_bit/left_side = 0 +12:0/0/terrains_peering_bit/top_side = 0 +13:0/0 = 0 +13:0/0/terrain_set = 0 +13:0/0/terrain = 0 +13:0/0/terrains_peering_bit/right_side = 0 +13:0/0/terrains_peering_bit/bottom_side = 0 +13:0/0/terrains_peering_bit/bottom_left_corner = 0 +13:0/0/terrains_peering_bit/left_side = 0 +13:0/0/terrains_peering_bit/top_side = 0 +15:0/0 = 0 +15:0/0/terrain_set = 0 +15:0/0/terrain = 0 +15:0/0/terrains_peering_bit/right_side = 0 +15:0/0/terrains_peering_bit/bottom_side = 0 +15:0/0/terrains_peering_bit/left_side = 0 +15:0/0/terrains_peering_bit/top_side = 0 +0:1/0 = 0 +0:1/0/terrain_set = 0 +0:1/0/terrain = 0 +0:1/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +0:1/0/terrains_peering_bit/right_side = 0 +0:1/0/terrains_peering_bit/bottom_right_corner = 0 +0:1/0/terrains_peering_bit/bottom_side = 0 +0:1/0/terrains_peering_bit/top_side = 0 +0:1/0/terrains_peering_bit/top_right_corner = 0 +1:1/0 = 0 +2:1/0 = 0 +2:1/0/terrain_set = 0 +2:1/0/terrain = 0 +2:1/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +2:1/0/terrains_peering_bit/bottom_side = 0 +2:1/0/terrains_peering_bit/bottom_left_corner = 0 +2:1/0/terrains_peering_bit/left_side = 0 +2:1/0/terrains_peering_bit/top_left_corner = 0 +2:1/0/terrains_peering_bit/top_side = 0 +4:1/0 = 0 +4:1/0/terrain_set = 0 +4:1/0/terrain = 0 +4:1/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +4:1/0/terrains_peering_bit/bottom_side = 0 +4:1/0/terrains_peering_bit/top_side = 0 +6:1/0 = 0 +6:1/0/terrain_set = 0 +6:1/0/terrain = 0 +6:1/0/terrains_peering_bit/right_side = 0 +6:1/0/terrains_peering_bit/bottom_right_corner = 0 +6:1/0/terrains_peering_bit/bottom_side = 0 +6:1/0/terrains_peering_bit/bottom_left_corner = 0 +6:1/0/terrains_peering_bit/left_side = 0 +6:1/0/terrains_peering_bit/top_left_corner = 0 +6:1/0/terrains_peering_bit/top_side = 0 +7:1/0 = 0 +7:1/0/terrain_set = 0 +7:1/0/terrain = 0 +7:1/0/terrains_peering_bit/right_side = 0 +7:1/0/terrains_peering_bit/bottom_right_corner = 0 +7:1/0/terrains_peering_bit/bottom_side = 0 +7:1/0/terrains_peering_bit/bottom_left_corner = 0 +7:1/0/terrains_peering_bit/left_side = 0 +7:1/0/terrains_peering_bit/top_side = 0 +7:1/0/terrains_peering_bit/top_right_corner = 0 +9:1/0 = 0 +9:1/0/terrain_set = 0 +9:1/0/terrain = 0 +9:1/0/terrains_peering_bit/right_side = 0 +9:1/0/terrains_peering_bit/bottom_right_corner = 0 +9:1/0/terrains_peering_bit/bottom_side = 0 +9:1/0/terrains_peering_bit/top_side = 0 +9:1/0/terrains_peering_bit/top_right_corner = 0 +10:1/0 = 0 +10:1/0/terrain_set = 0 +10:1/0/terrain = 0 +10:1/0/terrains_peering_bit/right_side = 0 +10:1/0/terrains_peering_bit/bottom_side = 0 +10:1/0/terrains_peering_bit/left_side = 0 +10:1/0/terrains_peering_bit/top_left_corner = 0 +10:1/0/terrains_peering_bit/top_side = 0 +10:1/0/terrains_peering_bit/top_right_corner = 0 +12:1/0 = 0 +12:1/0/terrain_set = 0 +12:1/0/terrain = 0 +12:1/0/terrains_peering_bit/right_side = 0 +12:1/0/terrains_peering_bit/bottom_side = 0 +12:1/0/terrains_peering_bit/left_side = 0 +12:1/0/terrains_peering_bit/top_side = 0 +12:1/0/terrains_peering_bit/top_right_corner = 0 +13:1/0 = 0 +13:1/0/terrain_set = 0 +13:1/0/terrain = 0 +13:1/0/terrains_peering_bit/right_side = 0 +13:1/0/terrains_peering_bit/bottom_side = 0 +13:1/0/terrains_peering_bit/left_side = 0 +13:1/0/terrains_peering_bit/top_left_corner = 0 +13:1/0/terrains_peering_bit/top_side = 0 +15:1/0 = 0 +15:1/0/terrain_set = 0 +15:1/0/terrain = 0 +15:1/0/terrains_peering_bit/right_side = 0 +15:1/0/terrains_peering_bit/bottom_side = 0 +15:1/0/terrains_peering_bit/bottom_left_corner = 0 +15:1/0/terrains_peering_bit/left_side = 0 +15:1/0/terrains_peering_bit/top_side = 0 +15:1/0/terrains_peering_bit/top_right_corner = 0 +16:1/0 = 0 +16:1/0/terrain_set = 0 +16:1/0/terrain = 0 +16:1/0/terrains_peering_bit/right_side = 0 +16:1/0/terrains_peering_bit/bottom_right_corner = 0 +16:1/0/terrains_peering_bit/bottom_side = 0 +16:1/0/terrains_peering_bit/left_side = 0 +16:1/0/terrains_peering_bit/top_left_corner = 0 +16:1/0/terrains_peering_bit/top_side = 0 +0:2/0 = 0 +0:2/0/terrain_set = 0 +0:2/0/terrain = 0 +0:2/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +0:2/0/terrains_peering_bit/right_side = 0 +0:2/0/terrains_peering_bit/top_side = 0 +0:2/0/terrains_peering_bit/top_right_corner = 0 +1:2/0 = 0 +1:2/0/terrain_set = 0 +1:2/0/terrain = 0 +1:2/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +1:2/0/terrains_peering_bit/right_side = 0 +1:2/0/terrains_peering_bit/left_side = 0 +1:2/0/terrains_peering_bit/top_left_corner = 0 +1:2/0/terrains_peering_bit/top_side = 0 +1:2/0/terrains_peering_bit/top_right_corner = 0 +2:2/0 = 0 +2:2/0/terrain_set = 0 +2:2/0/terrain = 0 +2:2/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +2:2/0/terrains_peering_bit/left_side = 0 +2:2/0/terrains_peering_bit/top_left_corner = 0 +2:2/0/terrains_peering_bit/top_side = 0 +4:2/0 = 0 +4:2/0/terrain_set = 0 +4:2/0/terrain = 0 +4:2/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +4:2/0/terrains_peering_bit/top_side = 0 +6:3/0 = 0 +6:3/0/terrain_set = 0 +6:3/0/terrain = 0 +6:3/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, -0.25, -16, 0, 16, -16, 16) +6:3/0/terrains_peering_bit/right_side = 0 +6:3/0/terrains_peering_bit/bottom_side = 0 +6:3/0/terrains_peering_bit/top_side = 0 +6:3/0/terrains_peering_bit/top_right_corner = 0 +7:3/0 = 0 +7:3/0/terrain_set = 0 +7:3/0/terrain = 0 +7:3/0/physics_layer_0/polygon_0/points = PackedVector2Array(16, -16, -0.25, -16, 0, 16, 16, 16) +7:3/0/terrains_peering_bit/bottom_side = 0 +7:3/0/terrains_peering_bit/left_side = 0 +7:3/0/terrains_peering_bit/top_left_corner = 0 +7:3/0/terrains_peering_bit/top_side = 0 +9:3/0 = 0 +9:3/0/terrain_set = 0 +9:3/0/terrain = 0 +9:3/0/physics_layer_0/polygon_0/points = PackedVector2Array(16, -16, -16, -16, -16, -7, 16, -6.75) +9:3/0/terrains_peering_bit/right_side = 0 +9:3/0/terrains_peering_bit/bottom_side = 0 +9:3/0/terrains_peering_bit/bottom_left_corner = 0 +9:3/0/terrains_peering_bit/left_side = 0 +10:3/0 = 0 +10:3/0/terrain_set = 0 +10:3/0/terrain = 0 +10:3/0/physics_layer_0/polygon_0/points = PackedVector2Array(16, -16, -16, -16, -16, -7, 16, -6.75) +10:3/0/terrains_peering_bit/right_side = 0 +10:3/0/terrains_peering_bit/bottom_right_corner = 0 +10:3/0/terrains_peering_bit/bottom_side = 0 +10:3/0/terrains_peering_bit/left_side = 0 +12:3/0 = 0 +12:3/0/terrain_set = 0 +12:3/0/terrain = 0 +12:3/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, -16, 16, -6, 16, -6.5, -16) +12:3/0/terrains_peering_bit/right_side = 0 +12:3/0/terrains_peering_bit/bottom_side = 0 +12:3/0/terrains_peering_bit/top_side = 0 +13:3/0 = 0 +13:3/0/terrain_set = 0 +13:3/0/terrain = 0 +13:3/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, -16, -0.75, 7.5, 0.5, 8, 16, 16, 16, 16, -16) +13:3/0/terrains_peering_bit/right_side = 0 +13:3/0/terrains_peering_bit/bottom_side = 0 +13:3/0/terrains_peering_bit/left_side = 0 +15:3/0 = 0 +15:3/0/terrain_set = 0 +15:3/0/terrain = 0 +15:3/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, -16, 16, 16, 16, 16, -16) +15:3/0/terrains_peering_bit/right_side = 0 +15:3/0/terrains_peering_bit/bottom_side = 0 +16:3/0 = 0 +16:3/0/terrain_set = 0 +16:3/0/terrain = 0 +16:3/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, -16, 16, 16, 16, 16, -16) +16:3/0/terrains_peering_bit/bottom_side = 0 +16:3/0/terrains_peering_bit/left_side = 0 +0:4/0 = 0 +0:4/0/terrain_set = 0 +0:4/0/terrain = 0 +0:4/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +0:4/0/terrains_peering_bit/right_side = 0 +1:4/0 = 0 +1:4/0/terrain_set = 0 +1:4/0/terrain = 0 +1:4/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +1:4/0/terrains_peering_bit/right_side = 0 +1:4/0/terrains_peering_bit/left_side = 0 +2:4/0 = 0 +2:4/0/terrain_set = 0 +2:4/0/terrain = 0 +2:4/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +2:4/0/terrains_peering_bit/left_side = 0 +4:4/0 = 0 +4:4/0/terrain_set = 0 +4:4/0/terrain = 0 +4:4/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, 16, -16, 16, 16, -16, 16) +6:4/0 = 0 +6:4/0/terrain_set = 0 +6:4/0/terrain = 0 +6:4/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, -0.25, -16, 0, 16, -16, 16) +6:4/0/terrains_peering_bit/right_side = 0 +6:4/0/terrains_peering_bit/bottom_right_corner = 0 +6:4/0/terrains_peering_bit/bottom_side = 0 +6:4/0/terrains_peering_bit/top_side = 0 +7:4/0 = 0 +7:4/0/terrain_set = 0 +7:4/0/terrain = 0 +7:4/0/physics_layer_0/polygon_0/points = PackedVector2Array(16, -16, -0.25, -16, 0, 16, 16, 16) +7:4/0/terrains_peering_bit/bottom_side = 0 +7:4/0/terrains_peering_bit/bottom_left_corner = 0 +7:4/0/terrains_peering_bit/left_side = 0 +7:4/0/terrains_peering_bit/top_side = 0 +9:4/0 = 0 +9:4/0/terrain_set = 0 +9:4/0/terrain = 0 +9:4/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, 3.5, -16, 16, 16, 16, 16, 3.5) +9:4/0/terrains_peering_bit/right_side = 0 +9:4/0/terrains_peering_bit/left_side = 0 +9:4/0/terrains_peering_bit/top_left_corner = 0 +9:4/0/terrains_peering_bit/top_side = 0 +10:4/0 = 0 +10:4/0/terrain_set = 0 +10:4/0/terrain = 0 +10:4/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, 3.5, -16, 16, 16, 16, 16, 3.5) +10:4/0/terrains_peering_bit/right_side = 0 +10:4/0/terrains_peering_bit/left_side = 0 +10:4/0/terrains_peering_bit/top_side = 0 +10:4/0/terrains_peering_bit/top_right_corner = 0 +12:4/0 = 0 +12:4/0/terrain_set = 0 +12:4/0/terrain = 0 +12:4/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, -16, 16, 16, 16, 16, -16) +12:4/0/terrains_peering_bit/right_side = 0 +12:4/0/terrains_peering_bit/left_side = 0 +12:4/0/terrains_peering_bit/top_side = 0 +13:4/0 = 0 +13:4/0/terrain_set = 0 +13:4/0/terrain = 0 +13:4/0/physics_layer_0/polygon_0/points = PackedVector2Array(5.5, -16, 6.25, 16, 16, 16, 16, -16) +13:4/0/terrains_peering_bit/bottom_side = 0 +13:4/0/terrains_peering_bit/left_side = 0 +13:4/0/terrains_peering_bit/top_side = 0 +15:4/0 = 0 +15:4/0/terrain_set = 0 +15:4/0/terrain = 0 +15:4/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, -16, 16, 16, 16, 16, -16) +15:4/0/terrains_peering_bit/right_side = 0 +15:4/0/terrains_peering_bit/top_side = 0 +16:4/0 = 0 +16:4/0/terrain_set = 0 +16:4/0/terrain = 0 +16:4/0/physics_layer_0/polygon_0/points = PackedVector2Array(-16, -16, -16, 16, 16, 16, 16, -16) +16:4/0/terrains_peering_bit/left_side = 0 +16:4/0/terrains_peering_bit/top_side = 0 + +[sub_resource type="TileSet" id="TileSet_ixl4j"] +tile_size = Vector2i(32, 32) +physics_layer_0/collision_layer = 1 +terrain_set_0/mode = 0 +terrain_set_0/terrain_0/name = "leafy_ground" +terrain_set_0/terrain_0/color = Color(0.5, 0.34375, 0.25, 1) +sources/0 = SubResource("TileSetAtlasSource_3ut3v") + +[sub_resource type="RectangleShape2D" id="RectangleShape2D_1cyeq"] +size = Vector2(101, 20) + +[sub_resource type="WorldBoundaryShape2D" id="WorldBoundaryShape2D_bqh70"] +distance = -181.0 + +[sub_resource type="CircleShape2D" id="CircleShape2D_mfh1j"] + +[node name="Game" type="Node2D"] + +[node name="SceneManager" type="Node" parent="."] +unique_name_in_owner = true +script = ExtResource("1_g37ru") + +[node name="Background" type="Parallax2D" parent="."] +repeat_size = Vector2(320, 0) + +[node name="Sprite2D" type="Sprite2D" parent="Background"] +position = Vector2(160, 90) +texture = ExtResource("2_ehg0h") + +[node name="Sprite2D2" type="Sprite2D" parent="Background"] +position = Vector2(160, -68.5) +scale = Vector2(1, 5.56667) +texture = ExtResource("3_8wilj") + +[node name="Parallax2D2" type="Parallax2D" parent="."] +scroll_scale = Vector2(1.2, 1.2) +repeat_size = Vector2(320, 0) + +[node name="Sprite2D" type="Sprite2D" parent="Parallax2D2"] +texture_filter = 1 +position = Vector2(160, 90) +texture = ExtResource("4_qwx2h") + +[node name="TileMapLayer" type="TileMapLayer" parent="."] +position = Vector2(-220, -413) +tile_map_data = PackedByteArray("AAAJABIAAAABAAAAAAAKABIAAAABAAQAAAALABIAAAABAAQAAAAMABIAAAABAAQAAAANABIAAAABAAQAAAAIABIAAAABAAAAAAAHABIAAAAKAAMAAAAOABIAAAAMAAQAAAAPABIAAAAMAAQAAAAQABIAAAACAAQAAAATABIAAAAAAAQAAAAUABIAAAAMAAQAAAAVABIAAAAMAAQAAAAWABIAAAAMAAQAAAAXABIAAAAMAAQAAAAYABIAAAABAAQAAAAZABIAAAABAAQAAAAaABIAAAAKAAMAAAAPABEAAAAEAAEAAAAPABAAAAAPAAMAAAAQABAAAAANAAQAAAAQAA8AAAANAAMAAAARAA8AAAABAAQAAAASAA8AAAABAAQAAAATAA8AAAABAAQAAAAUAA8AAAACAAQAAAAUABAAAAAAAAQAAAAUABEAAAANAAMAAAAVABEAAAAPAAAAAAAOABEAAAAQAAMAAAAWABEAAAANAAMAAAAVABAAAAAQAAMAAAAXABEAAAAQAAMAAAAIAA8AAAAPAAMAAAAKAA8AAAAPAAMAAAAMABAAAAAPAAMAAAA=") +tile_set = SubResource("TileSet_ixl4j") + +[node name="StaticBody2D" type="StaticBody2D" parent="."] +position = Vector2(340, -161) +metadata/_edit_group_ = true + +[node name="CollisionShape2D" type="CollisionShape2D" parent="StaticBody2D"] +position = Vector2(-0.5, 0) +shape = SubResource("RectangleShape2D_1cyeq") + +[node name="floor" type="StaticBody2D" parent="."] + +[node name="CollisionShape2D" type="CollisionShape2D" parent="floor"] +shape = SubResource("WorldBoundaryShape2D_bqh70") + +[node name="CharacterBody2D" parent="." instance=ExtResource("6_7tdkp")] + +[node name="Area2D" type="Area2D" parent="."] +position = Vector2(359, 141) +scale = Vector2(5, 5) +script = ExtResource("7_2y6a6") +metadata/_edit_group_ = true + +[node name="CollisionShape2D" type="CollisionShape2D" parent="Area2D"] +shape = SubResource("CircleShape2D_mfh1j") +debug_color = Color(0.825765, 0.00158581, 0.954354, 0.42) + +[node name="crates" type="Node2D" parent="."] + +[node name="RigidBody2D" parent="crates" instance=ExtResource("9_sys65")] +position = Vector2(111, 135) +rotation = 0.806532 + +[node name="RigidBody2D5" parent="crates" instance=ExtResource("9_sys65")] +position = Vector2(395, 38) +rotation = 0.806532 + +[node name="RigidBody2D2" parent="crates" instance=ExtResource("9_sys65")] +position = Vector2(483, 20) +rotation = 0.806532 + +[node name="RigidBody2D3" parent="crates" instance=ExtResource("9_sys65")] +position = Vector2(596, 99) +rotation = 0.806532 + +[node name="RigidBody2D4" parent="crates" instance=ExtResource("9_sys65")] +position = Vector2(57, 39) +rotation = 0.806532 + +[node name="RigidBody2D6" parent="crates" instance=ExtResource("9_sys65")] +position = Vector2(200, 74) +rotation = 0.806532 + +[node name="coins" type="Node2D" parent="."] + +[node name="Area2D3" parent="coins" instance=ExtResource("9_fv1rd")] +position = Vector2(330, 40) + +[node name="Area2D" parent="coins" instance=ExtResource("9_fv1rd")] +position = Vector2(370, 40) + +[node name="Area2D2" parent="coins" instance=ExtResource("9_fv1rd")] +position = Vector2(400, 40) + +[connection signal="areaTrigger" from="Area2D" to="." method="_on_trigger"] +[connection signal="body_entered" from="Area2D" to="Area2D" method="_on_body_entered"] diff --git a/dariusgodotproject/scripts/badguy.gd b/dariusgodotproject/scripts/badguy.gd new file mode 100644 index 0000000..daec2ed --- /dev/null +++ b/dariusgodotproject/scripts/badguy.gd @@ -0,0 +1,27 @@ +class_name BadGuy extends Area2D +@onready var sprite: AnimatedSprite2D = $AnimatedSprite2D +@onready var right_ray: RayCast2D = $RightRay +@onready var left_ray: RayCast2D = $LeftRay +@onready var right_floor_ray: RayCast2D = $RightFloorRay +@onready var left_floor_ray: RayCast2D = $LeftFloorRay +const speed = 60 +var direction = 1 + + #signals +signal playerDamage + +func _process(delta: float) -> void: + if not right_floor_ray.is_colliding(): + #about to fall on the right... + direction = -1 + sprite.flip_h = true + if not left_floor_ray.is_colliding(): + #about to fall on the left... + direction = 1 + sprite.flip_h = false + + position.x += direction * speed * delta +func _on_body_entered(body: Node2D) -> void: + if body.is_in_group("player"): + print("Bad Guy Collided") + playerDamage.emit() diff --git a/dariusgodotproject/scripts/coin.gd b/dariusgodotproject/scripts/coin.gd new file mode 100644 index 0000000..6608fed --- /dev/null +++ b/dariusgodotproject/scripts/coin.gd @@ -0,0 +1,8 @@ +class_name Coin extends Area2D + +signal coinCollected + +func _on_body_entered(body: Node2D) -> void: + if body.is_in_group("player"): + coinCollected.emit() + queue_free() diff --git a/dariusgodotproject/scripts/gamecontroller.gd b/dariusgodotproject/scripts/gamecontroller.gd index 6332716..6f3b9f9 100644 --- a/dariusgodotproject/scripts/gamecontroller.gd +++ b/dariusgodotproject/scripts/gamecontroller.gd @@ -1,45 +1,75 @@ extends Node2D -var boxTotal = 4 +var boxTotal := 4 var timer:=Timer.new() -var countdown = 10 -var totalCrates = 0 +var countdown := 10 +var totalCrates := 0 +var cratesDestroyed := 0 +var totalCoins := 0 +var totalCoinsCollected := 0 +var totalBadGuys := 0 + +var player:Resource + +#level information +var levels = ["res://scenes/game.tscn","res://scenes/level2.tscn"] +var timers = [10, 15] +var currentLevel = 0 +#Signals from GC signal destroyBox(body) +signal levelComplete (levelToLoad) + + + # C alled when the node enters the scene tree for the first time. func _ready() -> void: + player = load("res://scripts/res/playerstats.tres") + print("Player health " +str(player.health)) + print("Number of levels: " +str(levels.size())) + reset() add_child(timer) timer.wait_time = 1 timer.one_shot = false timer.connect("timeout", secondCounter) - #timer.start() + timer.start() pass # Replace with function body. + +func reset(): + countdown = timers[currentLevel] + func secondCounter(): # print("one second") countdown -=1 if countdown <=0: print("YOU LOSE") - get_tree().reload_current_scene() - -# Called every frame. 'delta' is the elapsed time since the previous frame. -func _process(delta: float) -> void: - pass - - -func _on_trigger(effect: Variant, body) -> void: - print("Game Controller sees an alert.") - if body is RigidBody2D: - print("I see a rigid body.") - body.queue_free() - boxTotal -=1 - if boxTotal <=0: - print("YOU WON!!") - get_tree().reload_current_scene() + levelComplete.emit(levels[currentLevel]) +func coinCollected(): + totalCoinsCollected +=1 + print("GC knows coin collected") +func playerDamaged(): + print("GC knows player taking damage") + player.health -=20 + print("Health remaining: " +str(player.health)) func bulletHit(body): print("Game controller knows bullet hit something") if body.is_in_group("destructable"): destroyBox.emit(body) - + totalCrates -=1 + cratesDestroyed +=1 + if totalCrates <=0: + print("YOU WON!!") + currentLevel +=1 + if currentLevel >= levels.size(): + currentLevel = 0 + levelComplete.emit(levels[currentLevel]) + else: + print("Crates Remaining " +str(totalCrates)) +# Coming from SceneManager func countCrates(value): totalCrates = value +func countCoins(value): + totalCoins = value +func countBadGuys(value): + totalBadGuys = value diff --git a/dariusgodotproject/scripts/res/characterstats.gd b/dariusgodotproject/scripts/res/characterstats.gd new file mode 100644 index 0000000..d10a15f --- /dev/null +++ b/dariusgodotproject/scripts/res/characterstats.gd @@ -0,0 +1,5 @@ +class_name CharacterStats extends Resource + +@export var max_health:int = 100 +@export var starting_health:int = 100 +@export var health:int = 100 diff --git a/dariusgodotproject/scripts/res/playerstats.tres b/dariusgodotproject/scripts/res/playerstats.tres new file mode 100644 index 0000000..5931bec --- /dev/null +++ b/dariusgodotproject/scripts/res/playerstats.tres @@ -0,0 +1,9 @@ +[gd_resource type="Resource" script_class="CharacterStats" load_steps=2 format=3 uid="uid://c3v847h6im2q4"] + +[ext_resource type="Script" path="res://scripts/res/characterstats.gd" id="1_80q3k"] + +[resource] +script = ExtResource("1_80q3k") +max_health = 150 +starting_health = 100 +health = 100 diff --git a/dariusgodotproject/scripts/res/slimestats.tres b/dariusgodotproject/scripts/res/slimestats.tres new file mode 100644 index 0000000..b9d1bda --- /dev/null +++ b/dariusgodotproject/scripts/res/slimestats.tres @@ -0,0 +1,9 @@ +[gd_resource type="Resource" script_class="CharacterStats" load_steps=2 format=3 uid="uid://cfc2x0bcvbp4k"] + +[ext_resource type="Script" path="res://scripts/res/characterstats.gd" id="1_34pqp"] + +[resource] +script = ExtResource("1_34pqp") +max_health = 60 +starting_health = 50 +health = 50 diff --git a/dariusgodotproject/scripts/scenemanager.gd b/dariusgodotproject/scripts/scenemanager.gd index df274d5..a55f419 100644 --- a/dariusgodotproject/scripts/scenemanager.gd +++ b/dariusgodotproject/scripts/scenemanager.gd @@ -1,22 +1,45 @@ extends Node -@onready var game: Node2D = $".." @onready var crates: Node2D = $"../crates" +@onready var coins: Node2D = $"../coins" +@onready var enemies: Node2D = $"../enemies" var bullet = preload("res://scenes/bullet.tscn") var bulletArray:Array = [] var bulletsMadeTotal :=0 -var totalCrates = 0 + + +var totalCrates := 0 # Called when the node enters the scene tree for the first time. func _ready() -> void: - game.destroyBox.connect(boxDestroy) + #Give GC number of crates + Gamecontroller.destroyBox.connect(boxDestroy) for obj in crates.get_children(): if obj.is_in_group("destructable"): #increase the box counter totalCrates +=1 + var totalCoins = 0 + for obj in coins.get_children(): + if obj.is_in_group("collectibles"): + totalCoins +=1 + obj.coinCollected.connect(Gamecontroller.coinCollected) + var totalEnemies = 0 + for obj in enemies.get_children(): + if obj.is_in_group("enemies"): + totalEnemies +=1 + obj.playerDamage.connect(Gamecontroller.playerDamaged) + Gamecontroller.countBadGuys(totalEnemies) + Gamecontroller.countCoins(totalCoins) + Gamecontroller.countCrates(totalCrates) + + #Subscribe to vital events from GC + Gamecontroller.levelComplete.connect(changeLevel) + Gamecontroller.reset() +func changeLevel(level): + get_tree().change_scene_to_file(level) # Called every frame. 'delta' is the elapsed time since the previous frame. func _process(delta: float) -> void: pass @@ -46,7 +69,7 @@ func onBulletHit(bullet, body): bullet.position = Vector2(-100,-100) bullet.setSpeed(0) print("Scene manager knows bullet hit") - game.bulletHit(body) + Gamecontroller.bulletHit(body) func boxDestroy(body): print("test") body.queue_free()