浏览代码

:tada: Add seated vehicles prompts

DricomDragon 9 月之前
父节点
当前提交
94fc7396bd

+ 2 - 2
godot/component/entity/walker/walker.gd

@@ -3,7 +3,7 @@ extends CharacterBody3D
 
 
 signal focus_required(me: Node3D)
-signal got_in
+signal got_in(vehicle: SeatedVehicle)
 signal got_out
 signal can_get_in(possible: bool)
 signal chocolate_collected
@@ -154,7 +154,7 @@ func _get_in_vehicle(commander: LocalInput) -> void:
 	add_collision_exception_with(_vehicle)
 	_vehicle.drive_with(commander)
 	_seat = _find_seat_on(_vehicle)
-	got_in.emit()
+	got_in.emit(_vehicle)
 
 
 ## Get out of the current vehicle

+ 4 - 4
godot/component/ui/input_prompts/get_in/get_in_container.tscn

@@ -3,15 +3,15 @@
 [ext_resource type="Texture2D" uid="uid://clcwaemf3uawa" path="res://addons/input_prompts/icons/xbox/y.png" id="1_l00e1"]
 [ext_resource type="Script" path="res://addons/input_prompts/action_prompt/action_prompt.gd" id="2_gfb15"]
 
-[sub_resource type="InputEventKey" id="InputEventKey_o4h0q"]
+[sub_resource type="InputEventKey" id="InputEventKey_0r04g"]
 device = -1
 physical_keycode = 4194309
 
-[sub_resource type="InputEventJoypadButton" id="InputEventJoypadButton_8de4e"]
+[sub_resource type="InputEventJoypadButton" id="InputEventJoypadButton_mlr2x"]
 device = -1
 button_index = 3
 
-[node name="GetInPromptContainer" type="HBoxContainer"]
+[node name="GetInPrompt" type="HBoxContainer"]
 
 [node name="GetInLabel" type="Label" parent="."]
 layout_mode = 2
@@ -26,4 +26,4 @@ stretch_mode = 5
 script = ExtResource("2_gfb15")
 action = "get_in"
 icon = 0
-events = Array[InputEvent]([SubResource("InputEventKey_o4h0q"), SubResource("InputEventJoypadButton_8de4e")])
+events = Array[InputEvent]([SubResource("InputEventKey_0r04g"), SubResource("InputEventJoypadButton_mlr2x")])

+ 29 - 0
godot/component/ui/input_prompts/get_out/get_out_prompt.tscn

@@ -0,0 +1,29 @@
+[gd_scene load_steps=5 format=3 uid="uid://bdtsbgujnsdkt"]
+
+[ext_resource type="Texture2D" uid="uid://clcwaemf3uawa" path="res://addons/input_prompts/icons/xbox/y.png" id="1_rh45f"]
+[ext_resource type="Script" path="res://addons/input_prompts/action_prompt/action_prompt.gd" id="2_u1er6"]
+
+[sub_resource type="InputEventKey" id="InputEventKey_0r04g"]
+device = -1
+physical_keycode = 4194309
+
+[sub_resource type="InputEventJoypadButton" id="InputEventJoypadButton_mlr2x"]
+device = -1
+button_index = 3
+
+[node name="GetOutPrompt" type="HBoxContainer"]
+
+[node name="GetOutLabel" type="Label" parent="."]
+layout_mode = 2
+theme_override_font_sizes/font_size = 34
+text = "Get out vehicle"
+
+[node name="GetOutActionPrompt" type="TextureRect" parent="."]
+custom_minimum_size = Vector2(100, 100)
+layout_mode = 2
+texture = ExtResource("1_rh45f")
+stretch_mode = 5
+script = ExtResource("2_u1er6")
+action = "get_in"
+icon = 0
+events = Array[InputEvent]([SubResource("InputEventKey_0r04g"), SubResource("InputEventJoypadButton_mlr2x")])

+ 23 - 4
godot/component/ui/input_prompts/input_prompts_center.gd

@@ -3,14 +3,33 @@ extends CenterContainer
 ## Manage the display of several inputs prompts
 
 
+@onready var WalkPrompts: Control = $InputPromptsCollection/WalkPrompts
+@onready var VehiclePrompts: Control = $InputPromptsCollection/VehiclePrompts
+
+
 func _on_title_screen_start_game() -> void:
-	_enable()
+	_enable(WalkPrompts)
 
 
 func _on_victory_menu_visibility_changed() -> void:
 	queue_free()
 
 
-func _enable() -> void:
-	set_visible(true)
-	set_process_mode(Node.PROCESS_MODE_PAUSABLE)
+func _enable(prompts: Control) -> void:
+	prompts.set_visible(true)
+	prompts.set_process_mode(Node.PROCESS_MODE_PAUSABLE)
+
+
+func _disable(prompts: Control) -> void:
+	prompts.set_visible(false)
+	prompts.set_process_mode(Node.PROCESS_MODE_DISABLED)
+
+
+func _on_main_walker_got_in(vehicle: SeatedVehicle) -> void:
+	_disable(WalkPrompts)
+	_enable(VehiclePrompts)
+
+
+func _on_main_walker_got_out() -> void:
+	_enable(WalkPrompts)
+	_disable(VehiclePrompts)

+ 4 - 4
godot/component/ui/input_prompts/jump/jump_container.tscn

@@ -4,15 +4,15 @@
 [ext_resource type="Texture2D" uid="uid://b1e23gj3k1klg" path="res://addons/input_prompts/icons/xbox/a.png" id="2_ax62s"]
 [ext_resource type="Script" path="res://addons/input_prompts/action_prompt/action_prompt.gd" id="3_85i3m"]
 
-[sub_resource type="InputEventKey" id="InputEventKey_ucxno"]
+[sub_resource type="InputEventKey" id="InputEventKey_flpcd"]
 device = -1
 physical_keycode = 32
 unicode = 32
 
-[sub_resource type="InputEventJoypadButton" id="InputEventJoypadButton_amp3y"]
+[sub_resource type="InputEventJoypadButton" id="InputEventJoypadButton_5hyth"]
 device = -1
 
-[node name="JumpPromptContainer" type="HBoxContainer"]
+[node name="JumpPrompt" type="HBoxContainer"]
 script = ExtResource("1_vkqjn")
 
 [node name="JumpLabel" type="Label" parent="."]
@@ -28,4 +28,4 @@ stretch_mode = 5
 script = ExtResource("3_85i3m")
 action = "main"
 icon = 0
-events = Array[InputEvent]([SubResource("InputEventKey_ucxno"), SubResource("InputEventJoypadButton_amp3y")])
+events = Array[InputEvent]([SubResource("InputEventKey_flpcd"), SubResource("InputEventJoypadButton_5hyth")])

+ 13 - 13
godot/component/ui/input_prompts/move/move_container.tscn

@@ -7,45 +7,45 @@
 [ext_resource type="Texture2D" uid="uid://bntsrcd3hjcex" path="res://addons/input_prompts/icons/generic/left_stick_up.png" id="4_e345q"]
 [ext_resource type="Texture2D" uid="uid://dreirjfpqj40a" path="res://addons/input_prompts/icons/generic/left_stick_down.png" id="5_vrthb"]
 
-[sub_resource type="InputEventKey" id="InputEventKey_wfj4m"]
+[sub_resource type="InputEventKey" id="InputEventKey_umaof"]
 device = -1
 physical_keycode = 65
 unicode = 97
 
-[sub_resource type="InputEventJoypadMotion" id="InputEventJoypadMotion_vfyik"]
+[sub_resource type="InputEventJoypadMotion" id="InputEventJoypadMotion_xa7ss"]
 device = -1
 axis_value = -1.0
 
-[sub_resource type="InputEventKey" id="InputEventKey_iw6gn"]
+[sub_resource type="InputEventKey" id="InputEventKey_xosjh"]
 device = -1
 physical_keycode = 68
 unicode = 101
 
-[sub_resource type="InputEventJoypadMotion" id="InputEventJoypadMotion_2t3i8"]
+[sub_resource type="InputEventJoypadMotion" id="InputEventJoypadMotion_w8hx0"]
 device = -1
 axis_value = 1.0
 
-[sub_resource type="InputEventKey" id="InputEventKey_vkf1t"]
+[sub_resource type="InputEventKey" id="InputEventKey_ycsse"]
 device = -1
 physical_keycode = 87
 unicode = 44
 
-[sub_resource type="InputEventJoypadMotion" id="InputEventJoypadMotion_sxly5"]
+[sub_resource type="InputEventJoypadMotion" id="InputEventJoypadMotion_qrqs8"]
 device = -1
 axis = 1
 axis_value = -1.0
 
-[sub_resource type="InputEventKey" id="InputEventKey_rwo04"]
+[sub_resource type="InputEventKey" id="InputEventKey_osxxy"]
 device = -1
 physical_keycode = 83
 unicode = 111
 
-[sub_resource type="InputEventJoypadMotion" id="InputEventJoypadMotion_rjep4"]
+[sub_resource type="InputEventJoypadMotion" id="InputEventJoypadMotion_2rpce"]
 device = -1
 axis = 1
 axis_value = 1.0
 
-[node name="MovePromptContainer" type="HBoxContainer"]
+[node name="MovePrompts" type="HBoxContainer"]
 script = ExtResource("1_b1cf6")
 
 [node name="MoveLabel" type="Label" parent="."]
@@ -61,7 +61,7 @@ stretch_mode = 5
 script = ExtResource("2_hmylp")
 action = "move_left"
 icon = 0
-events = Array[InputEvent]([SubResource("InputEventKey_wfj4m"), SubResource("InputEventJoypadMotion_vfyik")])
+events = Array[InputEvent]([SubResource("InputEventKey_umaof"), SubResource("InputEventJoypadMotion_xa7ss")])
 
 [node name="MoveRightActionPrompt" type="TextureRect" parent="."]
 custom_minimum_size = Vector2(100, 100)
@@ -71,7 +71,7 @@ stretch_mode = 5
 script = ExtResource("2_hmylp")
 action = "move_right"
 icon = 0
-events = Array[InputEvent]([SubResource("InputEventKey_iw6gn"), SubResource("InputEventJoypadMotion_2t3i8")])
+events = Array[InputEvent]([SubResource("InputEventKey_xosjh"), SubResource("InputEventJoypadMotion_w8hx0")])
 
 [node name="MoveForwardActionPrompt" type="TextureRect" parent="."]
 custom_minimum_size = Vector2(100, 100)
@@ -81,7 +81,7 @@ stretch_mode = 5
 script = ExtResource("2_hmylp")
 action = "move_forward"
 icon = 0
-events = Array[InputEvent]([SubResource("InputEventKey_vkf1t"), SubResource("InputEventJoypadMotion_sxly5")])
+events = Array[InputEvent]([SubResource("InputEventKey_ycsse"), SubResource("InputEventJoypadMotion_qrqs8")])
 
 [node name="MoveBackActionPrompt" type="TextureRect" parent="."]
 custom_minimum_size = Vector2(100, 100)
@@ -91,4 +91,4 @@ stretch_mode = 5
 script = ExtResource("2_hmylp")
 action = "move_back"
 icon = 0
-events = Array[InputEvent]([SubResource("InputEventKey_rwo04"), SubResource("InputEventJoypadMotion_rjep4")])
+events = Array[InputEvent]([SubResource("InputEventKey_osxxy"), SubResource("InputEventJoypadMotion_2rpce")])

+ 1 - 3
godot/flow/music_player/music_player.gd

@@ -13,11 +13,9 @@ func pause() -> void:
 	stream_paused = true
 
 
-func _on_driver_got_in():
-	print("play")
+func _on_driver_got_in(_vehicle: SeatedVehicle) -> void:
 	resume()
 
 
 func _on_driver_got_out():
-	print("stop")
 	pause()

+ 21 - 8
godot/run/levels/infinite_level.tscn

@@ -1,4 +1,4 @@
-[gd_scene load_steps=34 format=3 uid="uid://7ivipmwaw24t"]
+[gd_scene load_steps=36 format=3 uid="uid://7ivipmwaw24t"]
 
 [ext_resource type="Texture2D" uid="uid://cgwafs6ukpm7y" path="res://component/entity/ground/ground051.jpg" id="1_3ytcp"]
 [ext_resource type="Script" path="res://run/levels/camera_tracker.gd" id="1_qdm47"]
@@ -23,8 +23,10 @@
 [ext_resource type="PackedScene" uid="uid://c68bdcjpdm1y2" path="res://component/ui/pause/pause_menu.tscn" id="16_orqqe"]
 [ext_resource type="PackedScene" uid="uid://bmgwhm6ejsden" path="res://component/ui/victory/victory_menu.tscn" id="17_1u7wg"]
 [ext_resource type="PackedScene" uid="uid://d6a3dml2i2qm" path="res://component/ui/input_prompts/jump/jump_container.tscn" id="17_6r3c0"]
-[ext_resource type="PackedScene" uid="uid://dl6fmkdlrcj53" path="res://component/ui/input_prompts/get_in/get_in_container.tscn" id="18_bejgn"]
+[ext_resource type="PackedScene" uid="uid://dl6fmkdlrcj53" path="res://component/ui/input_prompts/get_in/get_in_prompt.tscn" id="18_bejgn"]
 [ext_resource type="Script" path="res://flow/signal_wire/space_limit.gd" id="19_3qyrt"]
+[ext_resource type="PackedScene" uid="uid://bdtsbgujnsdkt" path="res://component/ui/input_prompts/get_out/get_out_prompt.tscn" id="21_nwcia"]
+[ext_resource type="Script" path="res://component/ui/input_prompts/prompt_container.gd" id="22_tmm3q"]
 [ext_resource type="PackedScene" uid="uid://cqkond8xwtdv5" path="res://component/ui/hud/chocolate_gauge/chocolate_gauge.tscn" id="23_wh0jf"]
 
 [sub_resource type="BoxShape3D" id="BoxShape3D_ctk0t"]
@@ -439,7 +441,6 @@ script = ExtResource("8_iulsm")
 
 [node name="InputPromptsCenter" type="CenterContainer" parent="UI"]
 process_mode = 4
-visible = false
 anchors_preset = 15
 anchor_right = 1.0
 anchor_bottom = 1.0
@@ -450,16 +451,27 @@ script = ExtResource("15_k0ijo")
 [node name="InputPromptsCollection" type="VBoxContainer" parent="UI/InputPromptsCenter"]
 layout_mode = 2
 
-[node name="MovePromptContainer" parent="UI/InputPromptsCenter/InputPromptsCollection" instance=ExtResource("15_wc547")]
+[node name="WalkPrompts" type="VBoxContainer" parent="UI/InputPromptsCenter/InputPromptsCollection"]
+layout_mode = 2
+
+[node name="MovePrompt" parent="UI/InputPromptsCenter/InputPromptsCollection/WalkPrompts" instance=ExtResource("15_wc547")]
+layout_mode = 2
+
+[node name="JumpPrompt" parent="UI/InputPromptsCenter/InputPromptsCollection/WalkPrompts" instance=ExtResource("17_6r3c0")]
 layout_mode = 2
 
-[node name="JumpPromptContainer" parent="UI/InputPromptsCenter/InputPromptsCollection" instance=ExtResource("17_6r3c0")]
+[node name="GetInPromptContainer" parent="UI/InputPromptsCenter/InputPromptsCollection/WalkPrompts" instance=ExtResource("18_bejgn")]
+visible = false
 layout_mode = 2
 
-[node name="GetInPromptContainer" parent="UI/InputPromptsCenter/InputPromptsCollection" instance=ExtResource("18_bejgn")]
+[node name="VehiclePrompts" type="VBoxContainer" parent="UI/InputPromptsCenter/InputPromptsCollection"]
 visible = false
 layout_mode = 2
 
+[node name="GetOutPrompt" parent="UI/InputPromptsCenter/InputPromptsCollection/VehiclePrompts" instance=ExtResource("21_nwcia")]
+layout_mode = 2
+script = ExtResource("22_tmm3q")
+
 [node name="TitleScreen" parent="UI" instance=ExtResource("13_2xijd")]
 
 [node name="PauseMenu" parent="UI" instance=ExtResource("16_orqqe")]
@@ -500,12 +512,13 @@ script = ExtResource("19_3qyrt")
 transform = Transform3D(-1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0)
 shape = SubResource("WorldBoundaryShape3D_cdiox")
 
-[connection signal="can_get_in" from="MainWalker" to="UI/InputPromptsCenter/InputPromptsCollection/GetInPromptContainer" method="set_visible"]
+[connection signal="can_get_in" from="MainWalker" to="UI/InputPromptsCenter/InputPromptsCollection/WalkPrompts/GetInPromptContainer" method="set_visible"]
 [connection signal="chocolate_collected" from="MainWalker" to="UI/ChocolateGauge" method="_on_main_walker_chocolate_collected"]
 [connection signal="focus_required" from="MainWalker" to="CameraTracker" method="_on_focus_required"]
 [connection signal="got_in" from="MainWalker" to="MusicPlayer" method="_on_driver_got_in"]
-[connection signal="got_in" from="MainWalker" to="UI/InputPromptsCenter/InputPromptsCollection/GetInPromptContainer" method="hide"]
+[connection signal="got_in" from="MainWalker" to="UI/InputPromptsCenter" method="_on_main_walker_got_in"]
 [connection signal="got_out" from="MainWalker" to="MusicPlayer" method="_on_driver_got_out"]
+[connection signal="got_out" from="MainWalker" to="UI/InputPromptsCenter" method="_on_main_walker_got_out"]
 [connection signal="dir_changed" from="MainWalker/Control" to="MainWalker" method="_on_dir_changed"]
 [connection signal="get_in_action" from="MainWalker/Control" to="MainWalker" method="_on_get_in_action"]
 [connection signal="main_action" from="MainWalker/Control" to="MainWalker" method="_on_main_action"]