Added level mods and updated sprite imports
This commit is contained in:
		
							parent
							
								
									417044bfda
								
							
						
					
					
						commit
						7843bf2b8d
					
				@ -1,35 +0,0 @@
 | 
			
		||||
[remap]
 | 
			
		||||
 | 
			
		||||
importer="texture"
 | 
			
		||||
type="StreamTexture"
 | 
			
		||||
path="res://.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex"
 | 
			
		||||
metadata={
 | 
			
		||||
"vram_texture": false
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
[deps]
 | 
			
		||||
 | 
			
		||||
source_file="res://icon.png"
 | 
			
		||||
dest_files=[ "res://.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex" ]
 | 
			
		||||
 | 
			
		||||
[params]
 | 
			
		||||
 | 
			
		||||
compress/mode=0
 | 
			
		||||
compress/lossy_quality=0.7
 | 
			
		||||
compress/hdr_mode=0
 | 
			
		||||
compress/bptc_ldr=0
 | 
			
		||||
compress/normal_map=0
 | 
			
		||||
flags/repeat=0
 | 
			
		||||
flags/filter=true
 | 
			
		||||
flags/mipmaps=false
 | 
			
		||||
flags/anisotropic=false
 | 
			
		||||
flags/srgb=2
 | 
			
		||||
process/fix_alpha_border=true
 | 
			
		||||
process/premult_alpha=false
 | 
			
		||||
process/HDR_as_SRGB=false
 | 
			
		||||
process/invert_color=false
 | 
			
		||||
process/normal_map_invert_y=false
 | 
			
		||||
stream=false
 | 
			
		||||
size_limit=0
 | 
			
		||||
detect_3d=true
 | 
			
		||||
svg/scale=1.0
 | 
			
		||||
@ -34,7 +34,6 @@ _global_script_class_icons={
 | 
			
		||||
 | 
			
		||||
config/name="roger"
 | 
			
		||||
run/main_scene="res://scenes/stage.tscn"
 | 
			
		||||
config/icon="res://icon.png"
 | 
			
		||||
 | 
			
		||||
[display]
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										47
									
								
								scenes/UI.tscn
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								scenes/UI.tscn
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,47 @@
 | 
			
		||||
[gd_scene load_steps=6 format=2]
 | 
			
		||||
 | 
			
		||||
[ext_resource path="res://roger-roger/fonts/8-BIT WONDER.TTF" type="DynamicFontData" id=1]
 | 
			
		||||
[ext_resource path="res://scripts/UI.gd" type="Script" id=2]
 | 
			
		||||
[ext_resource path="res://roger-roger/ui/music-enabled.png" type="Texture" id=3]
 | 
			
		||||
 | 
			
		||||
[sub_resource type="DynamicFont" id=1]
 | 
			
		||||
font_data = ExtResource( 1 )
 | 
			
		||||
 | 
			
		||||
[sub_resource type="Theme" id=2]
 | 
			
		||||
default_font = SubResource( 1 )
 | 
			
		||||
 | 
			
		||||
[node name="GUI" type="Node2D"]
 | 
			
		||||
script = ExtResource( 2 )
 | 
			
		||||
 | 
			
		||||
[node name="MarginContainer" type="MarginContainer" parent="."]
 | 
			
		||||
margin_left = 20.0
 | 
			
		||||
margin_top = 20.0
 | 
			
		||||
margin_right = 1279.0
 | 
			
		||||
margin_bottom = 257.0
 | 
			
		||||
 | 
			
		||||
[node name="HBoxContainer" type="HBoxContainer" parent="MarginContainer"]
 | 
			
		||||
margin_right = 1259.0
 | 
			
		||||
margin_bottom = 237.0
 | 
			
		||||
 | 
			
		||||
[node name="TimeLabel" type="RichTextLabel" parent="MarginContainer/HBoxContainer"]
 | 
			
		||||
margin_right = 1227.0
 | 
			
		||||
margin_bottom = 237.0
 | 
			
		||||
size_flags_horizontal = 3
 | 
			
		||||
size_flags_vertical = 3
 | 
			
		||||
theme = SubResource( 2 )
 | 
			
		||||
text = "Time 60"
 | 
			
		||||
 | 
			
		||||
[node name="VBoxContainer" type="VBoxContainer" parent="MarginContainer/HBoxContainer"]
 | 
			
		||||
margin_left = 1231.0
 | 
			
		||||
margin_right = 1259.0
 | 
			
		||||
margin_bottom = 237.0
 | 
			
		||||
 | 
			
		||||
[node name="ToolButton" type="ToolButton" parent="MarginContainer/HBoxContainer/VBoxContainer"]
 | 
			
		||||
margin_right = 28.0
 | 
			
		||||
margin_bottom = 24.0
 | 
			
		||||
toggle_mode = true
 | 
			
		||||
icon = ExtResource( 3 )
 | 
			
		||||
 | 
			
		||||
[node name="GameTimer" type="Timer" parent="."]
 | 
			
		||||
 | 
			
		||||
[connection signal="toggled" from="MarginContainer/HBoxContainer/VBoxContainer/ToolButton" to="." method="_on_ToolButton_toggled"]
 | 
			
		||||
@ -1,8 +1,10 @@
 | 
			
		||||
[gd_scene load_steps=2 format=2]
 | 
			
		||||
[gd_scene load_steps=3 format=2]
 | 
			
		||||
 | 
			
		||||
[ext_resource path="res://roger-roger/tree.png" type="Texture" id=1]
 | 
			
		||||
[ext_resource path="res://scripts/decor.gd" type="Script" id=2]
 | 
			
		||||
 | 
			
		||||
[node name="Tree" type="Node2D"]
 | 
			
		||||
[node name="Decor" type="Node2D"]
 | 
			
		||||
script = ExtResource( 2 )
 | 
			
		||||
 | 
			
		||||
[node name="Sprite" type="Sprite" parent="."]
 | 
			
		||||
scale = Vector2( 6, 6 )
 | 
			
		||||
@ -4,20 +4,19 @@
 | 
			
		||||
[ext_resource path="res://roger-roger/chadHouse.png" type="Texture" id=2]
 | 
			
		||||
 | 
			
		||||
[sub_resource type="CapsuleShape2D" id=3]
 | 
			
		||||
radius = 12.2857
 | 
			
		||||
height = 2.57142
 | 
			
		||||
radius = 12.4286
 | 
			
		||||
height = 4.85714
 | 
			
		||||
 | 
			
		||||
[sub_resource type="RectangleShape2D" id=4]
 | 
			
		||||
extents = Vector2( 86, 63.5 )
 | 
			
		||||
[sub_resource type="ConvexPolygonShape2D" id=6]
 | 
			
		||||
 | 
			
		||||
[sub_resource type="RectangleShape2D" id=2]
 | 
			
		||||
extents = Vector2( 3.5, 2 )
 | 
			
		||||
[sub_resource type="RectangleShape2D" id=5]
 | 
			
		||||
extents = Vector2( 142.5, 73.1641 )
 | 
			
		||||
 | 
			
		||||
[node name="House" type="Node2D"]
 | 
			
		||||
script = ExtResource( 1 )
 | 
			
		||||
 | 
			
		||||
[node name="Sprite" type="Sprite" parent="."]
 | 
			
		||||
position = Vector2( 0, -125 )
 | 
			
		||||
position = Vector2( 7, -125 )
 | 
			
		||||
scale = Vector2( 5, 5 )
 | 
			
		||||
texture = ExtResource( 2 )
 | 
			
		||||
 | 
			
		||||
@ -26,19 +25,18 @@ collision_layer = 4
 | 
			
		||||
collision_mask = 7
 | 
			
		||||
 | 
			
		||||
[node name="CollisionShape2D" type="CollisionShape2D" parent="HouseBody"]
 | 
			
		||||
position = Vector2( -7, -90 )
 | 
			
		||||
position = Vector2( -4.76837e-07, -90 )
 | 
			
		||||
scale = Vector2( 7, 7 )
 | 
			
		||||
shape = SubResource( 3 )
 | 
			
		||||
 | 
			
		||||
[node name="CollisionShape2D2" type="CollisionShape2D" parent="HouseBody"]
 | 
			
		||||
position = Vector2( -6, -49.5 )
 | 
			
		||||
shape = SubResource( 4 )
 | 
			
		||||
position = Vector2( 0, -49 )
 | 
			
		||||
shape = SubResource( 6 )
 | 
			
		||||
 | 
			
		||||
[node name="DoorBody" type="StaticBody2D" parent="."]
 | 
			
		||||
scale = Vector2( 7, 7 )
 | 
			
		||||
collision_layer = 4
 | 
			
		||||
collision_mask = 2
 | 
			
		||||
[node name="DoorArea2D" type="Area2D" parent="."]
 | 
			
		||||
 | 
			
		||||
[node name="CollisionShape2D" type="CollisionShape2D" parent="DoorBody"]
 | 
			
		||||
position = Vector2( -0.857143, 1.57143 )
 | 
			
		||||
shape = SubResource( 2 )
 | 
			
		||||
[node name="CollisionShape2D" type="CollisionShape2D" parent="DoorArea2D"]
 | 
			
		||||
position = Vector2( 0, 36.836 )
 | 
			
		||||
shape = SubResource( 5 )
 | 
			
		||||
 | 
			
		||||
[connection signal="body_entered" from="DoorArea2D" to="." method="_on_DoorArea2D_body_entered"]
 | 
			
		||||
 | 
			
		||||
@ -48,8 +48,7 @@ shape = SubResource( 3 )
 | 
			
		||||
position = Vector2( 1, -29 )
 | 
			
		||||
scale = Vector2( 5, 5 )
 | 
			
		||||
frames = SubResource( 1 )
 | 
			
		||||
animation = "walk"
 | 
			
		||||
frame = 2
 | 
			
		||||
animation = "idle"
 | 
			
		||||
playing = true
 | 
			
		||||
 | 
			
		||||
[node name="CollisionShape2D" type="CollisionShape2D" parent="."]
 | 
			
		||||
 | 
			
		||||
@ -1,4 +1,4 @@
 | 
			
		||||
[gd_scene load_steps=13 format=2]
 | 
			
		||||
[gd_scene load_steps=15 format=2]
 | 
			
		||||
 | 
			
		||||
[ext_resource path="res://roger-roger/runningSprites/Rogers5.png" type="Texture" id=1]
 | 
			
		||||
[ext_resource path="res://roger-roger/runningSprites/Rogers4.png" type="Texture" id=2]
 | 
			
		||||
@ -10,6 +10,8 @@
 | 
			
		||||
[ext_resource path="res://roger-roger/runningSprites/RogersStart.png" type="Texture" id=8]
 | 
			
		||||
[ext_resource path="res://scripts/player.gd" type="Script" id=9]
 | 
			
		||||
[ext_resource path="res://roger-roger/mrRogers.png" type="Texture" id=10]
 | 
			
		||||
[ext_resource path="res://roger-roger/chevron_pointer.png" type="Texture" id=11]
 | 
			
		||||
[ext_resource path="res://scenes/UI.tscn" type="PackedScene" id=12]
 | 
			
		||||
 | 
			
		||||
[sub_resource type="CapsuleShape2D" id=2]
 | 
			
		||||
radius = 13.0
 | 
			
		||||
@ -48,3 +50,11 @@ playing = true
 | 
			
		||||
 | 
			
		||||
[node name="Camera2D" type="Camera2D" parent="."]
 | 
			
		||||
current = true
 | 
			
		||||
 | 
			
		||||
[node name="ChevronSprite" type="Sprite" parent="."]
 | 
			
		||||
position = Vector2( 0, -111 )
 | 
			
		||||
scale = Vector2( 3, 3 )
 | 
			
		||||
texture = ExtResource( 11 )
 | 
			
		||||
 | 
			
		||||
[node name="GUI" parent="." instance=ExtResource( 12 )]
 | 
			
		||||
position = Vector2( -640, -481 )
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										24
									
								
								scenes/pop.tscn
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								scenes/pop.tscn
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,24 @@
 | 
			
		||||
[gd_scene load_steps=7 format=2]
 | 
			
		||||
 | 
			
		||||
[ext_resource path="res://roger-roger/effects/pop-4.png" type="Texture" id=1]
 | 
			
		||||
[ext_resource path="res://roger-roger/effects/pop-3.png" type="Texture" id=2]
 | 
			
		||||
[ext_resource path="res://roger-roger/effects/pop-1.png" type="Texture" id=3]
 | 
			
		||||
[ext_resource path="res://roger-roger/effects/pop-2.png" type="Texture" id=4]
 | 
			
		||||
[ext_resource path="res://scripts/pop.gd" type="Script" id=5]
 | 
			
		||||
 | 
			
		||||
[sub_resource type="SpriteFrames" id=1]
 | 
			
		||||
animations = [ {
 | 
			
		||||
"frames": [ ExtResource( 3 ), ExtResource( 4 ), ExtResource( 2 ), ExtResource( 1 ) ],
 | 
			
		||||
"loop": true,
 | 
			
		||||
"name": "pop",
 | 
			
		||||
"speed": 8.0
 | 
			
		||||
} ]
 | 
			
		||||
 | 
			
		||||
[node name="Pop" type="AnimatedSprite"]
 | 
			
		||||
position = Vector2( 0, -40 )
 | 
			
		||||
scale = Vector2( 7, 7 )
 | 
			
		||||
frames = SubResource( 1 )
 | 
			
		||||
animation = "pop"
 | 
			
		||||
script = ExtResource( 5 )
 | 
			
		||||
 | 
			
		||||
[connection signal="animation_finished" from="." to="." method="_on_Pop_animation_finished"]
 | 
			
		||||
@ -12,7 +12,7 @@
 | 
			
		||||
[ext_resource path="res://roger-roger/tilemap/StreetVerticalRight.png" type="Texture" id=10]
 | 
			
		||||
[ext_resource path="res://roger-roger/tilemap/grass1.png" type="Texture" id=11]
 | 
			
		||||
[ext_resource path="res://roger-roger/tilemap/justRoad.png" type="Texture" id=12]
 | 
			
		||||
[ext_resource path="res://scenes/tree.tscn" type="PackedScene" id=13]
 | 
			
		||||
[ext_resource path="res://scenes/decor.tscn" type="PackedScene" id=13]
 | 
			
		||||
 | 
			
		||||
[sub_resource type="ConvexPolygonShape2D" id=3]
 | 
			
		||||
points = PoolVector2Array( 0, 0, 16, 0, 16, 16, 0, 16 )
 | 
			
		||||
@ -139,6 +139,7 @@ tile_data = PoolIntArray( -13, 7, 0, -12, 7, 0, -11, 3, 0, -10, 1, 0, -9, 0, 0,
 | 
			
		||||
 | 
			
		||||
[node name="Tree" parent="YSort" instance=ExtResource( 13 )]
 | 
			
		||||
position = Vector2( 412.655, 542.278 )
 | 
			
		||||
SPRITE_ASSET = "tree"
 | 
			
		||||
 | 
			
		||||
[node name="Tree2" parent="YSort" instance=ExtResource( 13 )]
 | 
			
		||||
position = Vector2( 862.175, 801.526 )
 | 
			
		||||
@ -148,6 +149,7 @@ position = Vector2( 1506.73, 1272.45 )
 | 
			
		||||
 | 
			
		||||
[node name="Tree4" parent="YSort" instance=ExtResource( 13 )]
 | 
			
		||||
position = Vector2( 1045.31, 479.251 )
 | 
			
		||||
SPRITE_ASSET = "lamppos"
 | 
			
		||||
 | 
			
		||||
[node name="Tree5" parent="YSort" instance=ExtResource( 13 )]
 | 
			
		||||
position = Vector2( -64.6703, 908.108 )
 | 
			
		||||
@ -159,22 +161,34 @@ position = Vector2( -68.0338, 1333.6 )
 | 
			
		||||
position = Vector2( 935.996, 1365.56 )
 | 
			
		||||
 | 
			
		||||
[node name="Trolley" parent="YSort" instance=ExtResource( 4 )]
 | 
			
		||||
position = Vector2( 111.946, -51.4683 )
 | 
			
		||||
position = Vector2( 116.441, -118.892 )
 | 
			
		||||
 | 
			
		||||
[node name="Player" parent="YSort" instance=ExtResource( 1 )]
 | 
			
		||||
position = Vector2( 521.375, 114 )
 | 
			
		||||
 | 
			
		||||
[node name="House" parent="YSort" instance=ExtResource( 3 )]
 | 
			
		||||
[node name="House1" parent="YSort" instance=ExtResource( 3 )]
 | 
			
		||||
position = Vector2( 1972.13, 1965.82 )
 | 
			
		||||
 | 
			
		||||
[node name="Neighbor" parent="YSort" instance=ExtResource( 5 )]
 | 
			
		||||
position = Vector2( 760.201, 407.292 )
 | 
			
		||||
[node name="House2" parent="YSort" instance=ExtResource( 3 )]
 | 
			
		||||
position = Vector2( 1079.23, 1518.43 )
 | 
			
		||||
 | 
			
		||||
[node name="House3" parent="YSort" instance=ExtResource( 3 )]
 | 
			
		||||
position = Vector2( -210.104, 1038.94 )
 | 
			
		||||
 | 
			
		||||
[node name="House4" parent="YSort" instance=ExtResource( 3 )]
 | 
			
		||||
position = Vector2( 1471.88, 482.054 )
 | 
			
		||||
 | 
			
		||||
[node name="Neighbor1" parent="YSort" instance=ExtResource( 5 )]
 | 
			
		||||
position = Vector2( 1561.16, 1687.12 )
 | 
			
		||||
 | 
			
		||||
[node name="Neighbor2" parent="YSort" instance=ExtResource( 5 )]
 | 
			
		||||
position = Vector2( 521.578, 319.171 )
 | 
			
		||||
position = Vector2( 487.675, 1641.38 )
 | 
			
		||||
 | 
			
		||||
[node name="Neighbor3" parent="YSort" instance=ExtResource( 5 )]
 | 
			
		||||
position = Vector2( 477.85, 707.714 )
 | 
			
		||||
position = Vector2( -23.5379, 746.218 )
 | 
			
		||||
 | 
			
		||||
[node name="Neighbor4" parent="YSort" instance=ExtResource( 5 )]
 | 
			
		||||
position = Vector2( -324.858, 684.091 )
 | 
			
		||||
position = Vector2( 985.045, 718.4 )
 | 
			
		||||
 | 
			
		||||
[node name="Decor" parent="YSort" instance=ExtResource( 13 )]
 | 
			
		||||
position = Vector2( 1353.08, 1162.06 )
 | 
			
		||||
 | 
			
		||||
@ -34,3 +34,4 @@ position = Vector2( 0, -2.25 )
 | 
			
		||||
shape = SubResource( 3 )
 | 
			
		||||
 | 
			
		||||
[connection signal="body_entered" from="TrolleySeatArea" to="." method="_on_TrolleySeatArea_body_entered"]
 | 
			
		||||
[connection signal="body_exited" from="TrolleySeatArea" to="." method="_on_TrolleySeatArea_body_exited"]
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										18
									
								
								scripts/UI.gd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								scripts/UI.gd
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,18 @@
 | 
			
		||||
extends Node2D
 | 
			
		||||
 | 
			
		||||
onready var time_label := $MarginContainer/HBoxContainer/TimeLabel
 | 
			
		||||
onready var game_timer := $GameTimer
 | 
			
		||||
 | 
			
		||||
func start_timer(seconds: int) -> void:
 | 
			
		||||
	game_timer.start(seconds)
 | 
			
		||||
 | 
			
		||||
func _ready() -> void:
 | 
			
		||||
	start_timer(60)
 | 
			
		||||
	
 | 
			
		||||
func _process(delta: float) -> void:
 | 
			
		||||
	var time = int(game_timer.get_time_left())
 | 
			
		||||
	time_label.text = "Time %s" % time
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
func _on_ToolButton_toggled(button_pressed: bool) -> void:
 | 
			
		||||
	print(button_pressed)
 | 
			
		||||
							
								
								
									
										15
									
								
								scripts/decor.gd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								scripts/decor.gd
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,15 @@
 | 
			
		||||
extends Node2D
 | 
			
		||||
 | 
			
		||||
onready var sprite := $Sprite
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
const SpriteAsset = {bush1 = "bush1", bush2 = "bush2", tree = "tree", lamppost = "lamppost"}
 | 
			
		||||
export var SPRITE_ASSET := SpriteAsset.bush1
 | 
			
		||||
 | 
			
		||||
func _ready() -> void:
 | 
			
		||||
	if SPRITE_ASSET in SpriteAsset:
 | 
			
		||||
		sprite.texture = load("res://roger-roger/%s.png" % SPRITE_ASSET)
 | 
			
		||||
	else:
 | 
			
		||||
		print("ERROR - Provided Sprite asset is either not defined or misspelled: %s FIXME %s" % [SPRITE_ASSET, self.name])
 | 
			
		||||
		sprite.texture = load("res://roger-roger/%s.png" % SpriteAsset.bush1)
 | 
			
		||||
	
 | 
			
		||||
@ -1,6 +1,18 @@
 | 
			
		||||
extends Node2D
 | 
			
		||||
 | 
			
		||||
onready var sprite = $Sprite
 | 
			
		||||
onready var door_area = $DoorArea2D
 | 
			
		||||
 | 
			
		||||
signal come_home
 | 
			
		||||
 | 
			
		||||
var id : int
 | 
			
		||||
 | 
			
		||||
func _ready() -> void:
 | 
			
		||||
	sprite.set_modulate(Color(1.0, 0.0, 0.0))
 | 
			
		||||
	id = int(self.name[-1])
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
func _on_DoorArea2D_body_entered(body: Node) -> void:
 | 
			
		||||
	if body is Neighbor:
 | 
			
		||||
		if body.id == id:
 | 
			
		||||
			emit_signal("come_home")
 | 
			
		||||
 | 
			
		||||
@ -2,11 +2,12 @@ extends KinematicBody2D
 | 
			
		||||
 | 
			
		||||
class_name Neighbor
 | 
			
		||||
 | 
			
		||||
signal neighbor_following_roger
 | 
			
		||||
signal found_home(id)
 | 
			
		||||
 | 
			
		||||
onready var roger_area := $RogerArea2D
 | 
			
		||||
onready var sprite := $AnimatedSprite
 | 
			
		||||
onready var wander_timer := $WanderTimer
 | 
			
		||||
onready var chevron_sprite := $ChevronSprite
 | 
			
		||||
 | 
			
		||||
export var MAX_SPEED := 225
 | 
			
		||||
export var ACCELERATION := 1000
 | 
			
		||||
@ -17,13 +18,20 @@ var neighbor_velocity := Vector2.ZERO
 | 
			
		||||
var leader: KinematicBody2D
 | 
			
		||||
var follower: KinematicBody2D
 | 
			
		||||
var rng := RandomNumberGenerator.new()
 | 
			
		||||
var is_wandering := false
 | 
			
		||||
var wander_direction := Vector2.ZERO
 | 
			
		||||
var matching_house_node : Node2D
 | 
			
		||||
var house_position := Vector2.ZERO
 | 
			
		||||
var house_direction := Vector2.ZERO
 | 
			
		||||
var id : int
 | 
			
		||||
 | 
			
		||||
var pop_effect_scene = preload("res://scenes/pop.tscn")
 | 
			
		||||
 | 
			
		||||
enum State {
 | 
			
		||||
	MOVE,
 | 
			
		||||
	WANDER,
 | 
			
		||||
	IDLE
 | 
			
		||||
	IDLE,
 | 
			
		||||
	GO_HOME,
 | 
			
		||||
	FOUND_HOME
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func reset_leads() -> void:
 | 
			
		||||
@ -33,26 +41,31 @@ func reset_leads() -> void:
 | 
			
		||||
	follower = null
 | 
			
		||||
 | 
			
		||||
func _ready() -> void:
 | 
			
		||||
	sprite.set_modulate(Color(.5,0,0))
 | 
			
		||||
	id = int(self.name[-1])
 | 
			
		||||
	rng.set_seed(id)
 | 
			
		||||
	matching_house_node = get_parent().get_node("House%s" % id)
 | 
			
		||||
	matching_house_node.connect("come_home", self, "_on_house_come_home")
 | 
			
		||||
 | 
			
		||||
func _physics_process(delta: float) -> void:
 | 
			
		||||
	house_position = matching_house_node.global_position
 | 
			
		||||
	house_direction = (house_position - global_position).normalized()
 | 
			
		||||
	match state:
 | 
			
		||||
		State.MOVE:
 | 
			
		||||
			move_state(delta)
 | 
			
		||||
			_move_state(delta)
 | 
			
		||||
		State.WANDER:
 | 
			
		||||
			wander_state(delta)
 | 
			
		||||
			_wander_state(delta)
 | 
			
		||||
		State.IDLE:
 | 
			
		||||
			idle_state(delta)
 | 
			
		||||
			_idle_state(delta)
 | 
			
		||||
		State.GO_HOME:
 | 
			
		||||
			_go_home_state(delta)
 | 
			
		||||
 | 
			
		||||
func move_state(delta: float) -> void:
 | 
			
		||||
#	var player := get_parent().get_node("Player") as Player
 | 
			
		||||
#	leader.follower = self
 | 
			
		||||
func _move_state(delta: float) -> void:
 | 
			
		||||
	if leader == null:
 | 
			
		||||
		state = State.IDLE
 | 
			
		||||
		return
 | 
			
		||||
	var result_vector := leader.global_position - global_position
 | 
			
		||||
	if result_vector.length() > 100:
 | 
			
		||||
		move_neighbor(result_vector)
 | 
			
		||||
		_move_neighbor(result_vector)
 | 
			
		||||
	else:
 | 
			
		||||
		state = State.IDLE
 | 
			
		||||
	if result_vector.length() > 250:
 | 
			
		||||
@ -63,32 +76,15 @@ func move_state(delta: float) -> void:
 | 
			
		||||
			follower = null
 | 
			
		||||
		state = State.IDLE
 | 
			
		||||
 | 
			
		||||
func wander_state(delta: float) -> void:
 | 
			
		||||
func _wander_state(delta: float) -> void:
 | 
			
		||||
	if leader != null:
 | 
			
		||||
		state = State.MOVE
 | 
			
		||||
		return
 | 
			
		||||
	move_neighbor(wander_direction, true)
 | 
			
		||||
	
 | 
			
		||||
	_move_neighbor(wander_direction, true)
 | 
			
		||||
 | 
			
		||||
func move_neighbor(direction_vector: Vector2, is_wander: bool = false) -> void:
 | 
			
		||||
		sprite.play("run") if not is_wander else sprite.play("walk")
 | 
			
		||||
		var move_vector := Vector2(direction_vector).normalized()
 | 
			
		||||
		if move_vector.x < 0 and not sprite.flip_h:
 | 
			
		||||
			sprite.flip_h = true
 | 
			
		||||
		elif move_vector.x > 0 and sprite.flip_h:
 | 
			
		||||
			sprite.flip_h = false
 | 
			
		||||
		if move_vector != Vector2.ZERO:
 | 
			
		||||
			var velocity := move_vector * MAX_SPEED if not is_wander else move_vector * MAX_SPEED / 3
 | 
			
		||||
			neighbor_velocity = neighbor_velocity.move_toward(velocity, ACCELERATION * get_physics_process_delta_time())
 | 
			
		||||
		else:
 | 
			
		||||
			neighbor_velocity = neighbor_velocity.move_toward(Vector2.ZERO, FRICTION * get_physics_process_delta_time())
 | 
			
		||||
		
 | 
			
		||||
		neighbor_velocity = move_and_slide(neighbor_velocity)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
func idle_state(delta: float) -> void:
 | 
			
		||||
func _idle_state(delta: float) -> void:
 | 
			
		||||
	if wander_timer.is_stopped():
 | 
			
		||||
		wander_timer.start(rng.randf_range(0, 1.5))
 | 
			
		||||
		wander_timer.start(rng.randf_range(1.8, 6.5))
 | 
			
		||||
	sprite.play("idle")
 | 
			
		||||
	for body in roger_area.get_overlapping_bodies():
 | 
			
		||||
		if body.is_class("KinematicBody2D") and not body is Trolley and leader == null and body.follower == null and body.leader != null:
 | 
			
		||||
@ -97,31 +93,63 @@ func idle_state(delta: float) -> void:
 | 
			
		||||
	if leader != null:
 | 
			
		||||
		state = State.MOVE
 | 
			
		||||
 | 
			
		||||
func _go_home_state(delta: float) -> void:
 | 
			
		||||
	_move_neighbor(house_direction, true)
 | 
			
		||||
#	print((house_position - global_position).length())
 | 
			
		||||
	if ((house_position - global_position).length() < 30):
 | 
			
		||||
		emit_signal("found_home", id)
 | 
			
		||||
		queue_free()
 | 
			
		||||
 | 
			
		||||
func _move_neighbor(direction_vector: Vector2, is_walk: bool = false) -> void:
 | 
			
		||||
		sprite.play("run") if not is_walk else sprite.play("walk")
 | 
			
		||||
		var move_vector := Vector2(direction_vector).normalized()
 | 
			
		||||
		if move_vector.x < 0 and not sprite.flip_h:
 | 
			
		||||
			sprite.flip_h = true
 | 
			
		||||
		elif move_vector.x > 0 and sprite.flip_h:
 | 
			
		||||
			sprite.flip_h = false
 | 
			
		||||
		if move_vector != Vector2.ZERO:
 | 
			
		||||
			var velocity := move_vector * MAX_SPEED if not is_walk else move_vector * MAX_SPEED / 3
 | 
			
		||||
			neighbor_velocity = neighbor_velocity.move_toward(velocity, ACCELERATION * get_physics_process_delta_time())
 | 
			
		||||
		else:
 | 
			
		||||
			neighbor_velocity = neighbor_velocity.move_toward(Vector2.ZERO, FRICTION * get_physics_process_delta_time())
 | 
			
		||||
		
 | 
			
		||||
		neighbor_velocity = move_and_slide(neighbor_velocity)
 | 
			
		||||
 | 
			
		||||
func _on_RogerArea2D_body_entered(body: Node) -> void:
 | 
			
		||||
	if body != self and leader == null:
 | 
			
		||||
		if body is Player and body.follower == null:
 | 
			
		||||
			body.follower = self
 | 
			
		||||
			leader = body
 | 
			
		||||
		elif body.is_class("KinematicBody2D") and not body is Trolley and body.follower == null:
 | 
			
		||||
			print('Got neighbor body')
 | 
			
		||||
			if body.leader != null:
 | 
			
		||||
				print('Following the leader')
 | 
			
		||||
				leader = body
 | 
			
		||||
				leader.follower = self
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
func _on_WanderTimer_timeout() -> void:
 | 
			
		||||
	if state == State.IDLE:
 | 
			
		||||
		print('wander timer done')
 | 
			
		||||
		var rand_x = rng.randf_range(-1.0, 1.0)
 | 
			
		||||
		var rand_y = rng.randf_range(-1.0, 1.0)
 | 
			
		||||
		var wander_time = rng.randf_range(1.0, 1.5)
 | 
			
		||||
		var wander_time = rng.randf_range(0.3, 1.2)
 | 
			
		||||
		state = State.WANDER
 | 
			
		||||
		wander_direction = Vector2(rand_x, rand_y)
 | 
			
		||||
		wander_timer.start(wander_time)
 | 
			
		||||
	elif state == State.WANDER:
 | 
			
		||||
		print('Done wandering')
 | 
			
		||||
		var wait_time = rng.randf_range(1.0, 5.5)
 | 
			
		||||
		var wait_time = rng.randf_range(1.8, 6.5)
 | 
			
		||||
		state = State.IDLE
 | 
			
		||||
		wander_timer.start(wait_time)
 | 
			
		||||
	elif state == State.FOUND_HOME:
 | 
			
		||||
		state = State.GO_HOME
 | 
			
		||||
		
 | 
			
		||||
 | 
			
		||||
func _on_house_come_home() -> void:
 | 
			
		||||
	sprite.play("idle")
 | 
			
		||||
	wander_timer.start(0.5)
 | 
			
		||||
	var instance = pop_effect_scene.instance()
 | 
			
		||||
	get_parent().add_child(instance)
 | 
			
		||||
	instance.global_position = Vector2(global_position.x, global_position.y - 50)
 | 
			
		||||
	if follower == null:
 | 
			
		||||
		leader.follower = null
 | 
			
		||||
	else:
 | 
			
		||||
		leader.follower = follower
 | 
			
		||||
		follower.leader = leader
 | 
			
		||||
	state = State.FOUND_HOME
 | 
			
		||||
 | 
			
		||||
@ -9,8 +9,10 @@ export var FRICTION := 2000
 | 
			
		||||
var player_velocity = Vector2.ZERO
 | 
			
		||||
var state = State.IDLE
 | 
			
		||||
var follower : KinematicBody2D
 | 
			
		||||
var leader := self
 | 
			
		||||
 | 
			
		||||
onready var sprite := $AnimatedSprite
 | 
			
		||||
onready var chevron_sprite := $ChevronSprite
 | 
			
		||||
 | 
			
		||||
enum State {
 | 
			
		||||
	MOVE,
 | 
			
		||||
@ -21,11 +23,14 @@ enum State {
 | 
			
		||||
func _physics_process(delta: float) -> void:
 | 
			
		||||
	match state:
 | 
			
		||||
		State.MOVE:
 | 
			
		||||
			move_state(delta)
 | 
			
		||||
			_move_state(delta)
 | 
			
		||||
		State.IDLE:
 | 
			
		||||
			idle_state(delta)
 | 
			
		||||
	
 | 
			
		||||
func move_state(delta: float) -> void:
 | 
			
		||||
			_idle_state(delta)
 | 
			
		||||
	chevron_sprite.visible = follower != null
 | 
			
		||||
	if follower != null:
 | 
			
		||||
		chevron_sprite.rotation_degrees = rad2deg((follower.house_position - global_position).angle()) - 90
 | 
			
		||||
 | 
			
		||||
func _move_state(delta: float) -> void:
 | 
			
		||||
	var input_vector := Vector2.ZERO
 | 
			
		||||
	input_vector.x = Input.get_action_strength("ui_right") - Input.get_action_strength("ui_left")
 | 
			
		||||
	input_vector.y = Input.get_action_strength("ui_down") - Input.get_action_strength("ui_up")
 | 
			
		||||
@ -47,7 +52,7 @@ func move_state(delta: float) -> void:
 | 
			
		||||
	if player_velocity == Vector2.ZERO:
 | 
			
		||||
		state = State.IDLE
 | 
			
		||||
 | 
			
		||||
func idle_state(delta: float) -> void:
 | 
			
		||||
func _idle_state(delta: float) -> void:
 | 
			
		||||
	if Input.is_action_just_pressed("ui_up") or Input.is_action_just_pressed("ui_down") or Input.is_action_just_pressed("ui_left") or Input.is_action_just_pressed("ui_right"):
 | 
			
		||||
		sprite.set_animation("run")
 | 
			
		||||
		state = State.MOVE
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										7
									
								
								scripts/pop.gd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								scripts/pop.gd
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,7 @@
 | 
			
		||||
extends AnimatedSprite
 | 
			
		||||
 | 
			
		||||
func _ready() -> void:
 | 
			
		||||
	play()
 | 
			
		||||
 | 
			
		||||
func _on_Pop_animation_finished() -> void:
 | 
			
		||||
	queue_free()
 | 
			
		||||
@ -1,2 +1,25 @@
 | 
			
		||||
extends Node2D
 | 
			
		||||
 | 
			
		||||
var helped_neighbors := []
 | 
			
		||||
var total_neighbors := 0
 | 
			
		||||
 | 
			
		||||
onready var trolley = $YSort/Trolley as Trolley
 | 
			
		||||
 | 
			
		||||
func _ready() -> void:
 | 
			
		||||
	trolley.connect("rogers_left_trolley", self, "_on_rogers_left_trolley")
 | 
			
		||||
	for node in get_node("YSort").get_children():
 | 
			
		||||
		if 'Neighbor' in node.name:
 | 
			
		||||
			var err = node.connect("found_home", self, "_on_neighbor_found_home")
 | 
			
		||||
			total_neighbors += 1
 | 
			
		||||
			
 | 
			
		||||
 | 
			
		||||
func _on_rogers_left_trolley() -> void:
 | 
			
		||||
	pass
 | 
			
		||||
 | 
			
		||||
func _on_neighbor_found_home(id: int) -> void:
 | 
			
		||||
	print('You helped a neighbor')
 | 
			
		||||
	helped_neighbors.append(id)
 | 
			
		||||
	if len(helped_neighbors) == total_neighbors:
 | 
			
		||||
		trolley.set_trolley_open(true)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -2,6 +2,8 @@ extends KinematicBody2D
 | 
			
		||||
 | 
			
		||||
class_name Trolley
 | 
			
		||||
 | 
			
		||||
signal rogers_left_trolley()
 | 
			
		||||
 | 
			
		||||
export var TIME = 60
 | 
			
		||||
onready var trolley_closed_shape = $TrolleyClosedShape
 | 
			
		||||
export var MAX_VELOCITY = .3
 | 
			
		||||
@ -10,7 +12,7 @@ var velocity := Vector2.ZERO
 | 
			
		||||
var has_roger := false
 | 
			
		||||
 | 
			
		||||
func _ready() -> void:
 | 
			
		||||
	trolley_closed_shape.set_deferred("disabled", true)
 | 
			
		||||
	set_trolley_open(true)
 | 
			
		||||
	
 | 
			
		||||
func _physics_process(delta: float) -> void:
 | 
			
		||||
	velocity.x = move_toward(velocity.x, MAX_VELOCITY, delta if not has_roger else delta * 10)
 | 
			
		||||
@ -22,8 +24,8 @@ func _physics_process(delta: float) -> void:
 | 
			
		||||
				MAX_VELOCITY = 10
 | 
			
		||||
			collider.move_and_collide(velocity * 3)
 | 
			
		||||
 | 
			
		||||
				
 | 
			
		||||
 | 
			
		||||
func set_trolley_open(trolley_open: bool) -> void:
 | 
			
		||||
	trolley_closed_shape.set_deferred("disabled", trolley_open)
 | 
			
		||||
 | 
			
		||||
func _on_TrolleySeatArea_body_entered(body: Node) -> void:
 | 
			
		||||
	if body is Player:
 | 
			
		||||
@ -31,3 +33,8 @@ func _on_TrolleySeatArea_body_entered(body: Node) -> void:
 | 
			
		||||
		print('closing trolley')
 | 
			
		||||
		trolley_closed_shape.set_deferred("disabled", false)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
func _on_TrolleySeatArea_body_exited(body: Node) -> void:
 | 
			
		||||
	if body is Player:
 | 
			
		||||
		emit_signal("rogers_left_trolley")
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user