Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| fabafbb35b | |||
| 0b0163a0ac | |||
| 5b3d6c9f19 | |||
| ac14352e7f |
@@ -6,6 +6,9 @@ extends Control
|
|||||||
@export var options_packed_scene : PackedScene
|
@export var options_packed_scene : PackedScene
|
||||||
@export var credits_packed_scene : PackedScene
|
@export var credits_packed_scene : PackedScene
|
||||||
|
|
||||||
|
@export var menu_context : GUIDEMappingContext
|
||||||
|
@export var back_action : GUIDEAction
|
||||||
|
|
||||||
var options_scene
|
var options_scene
|
||||||
var credits_scene
|
var credits_scene
|
||||||
var sub_menu
|
var sub_menu
|
||||||
@@ -73,7 +76,12 @@ func _ready() -> void:
|
|||||||
_add_or_hide_options()
|
_add_or_hide_options()
|
||||||
_add_or_hide_credits()
|
_add_or_hide_credits()
|
||||||
_hide_new_game_if_unset()
|
_hide_new_game_if_unset()
|
||||||
|
_setup_inputs()
|
||||||
|
|
||||||
|
func _setup_inputs() -> void:
|
||||||
|
GUIDE.enable_mapping_context(menu_context)
|
||||||
|
back_action.triggered.connect(_on_back_button_pressed)
|
||||||
|
|
||||||
func _on_new_game_button_pressed() -> void:
|
func _on_new_game_button_pressed() -> void:
|
||||||
new_game()
|
new_game()
|
||||||
|
|
||||||
|
|||||||
@@ -9,16 +9,19 @@ extends OverlaidMenu
|
|||||||
var popup_open : Node
|
var popup_open : Node
|
||||||
var previous_mapping_contexts : Array
|
var previous_mapping_contexts : Array
|
||||||
|
|
||||||
func on_enter_tree() -> void:
|
var is_listening_to_inputs = true
|
||||||
pass
|
|
||||||
#previous_mapping_contexts = GUIDE.get_enabled_mapping_contexts()
|
func _enter_tree() -> void:
|
||||||
#GUIDE.enable_mapping_context(menu_context)
|
super._enter_tree()
|
||||||
|
previous_mapping_contexts = GUIDE.get_enabled_mapping_contexts()
|
||||||
|
for previous_context in previous_mapping_contexts:
|
||||||
|
GUIDE.disable_mapping_context(previous_context)
|
||||||
|
GUIDE.enable_mapping_context(menu_context)
|
||||||
|
|
||||||
func on_exit_tree() -> void:
|
func _exit_tree() -> void:
|
||||||
pass
|
GUIDE.disable_mapping_context(menu_context)
|
||||||
#GUIDE.disable_mapping_context(menu_context)
|
for previous_context in previous_mapping_contexts:
|
||||||
#for previous_context in previous_mapping_contexts:
|
GUIDE.enable_mapping_context(previous_context)
|
||||||
#GUIDE.enable_mapping_context(previous_context)
|
|
||||||
|
|
||||||
func close_popup() -> void:
|
func close_popup() -> void:
|
||||||
if popup_open != null:
|
if popup_open != null:
|
||||||
@@ -43,10 +46,15 @@ func open_options_menu() -> void:
|
|||||||
var options_scene := options_packed_scene.instantiate()
|
var options_scene := options_packed_scene.instantiate()
|
||||||
add_child(options_scene)
|
add_child(options_scene)
|
||||||
_disable_focus.call_deferred()
|
_disable_focus.call_deferred()
|
||||||
|
is_listening_to_inputs = false
|
||||||
await options_scene.tree_exiting
|
await options_scene.tree_exiting
|
||||||
|
is_listening_to_inputs = true
|
||||||
_enable_focus.call_deferred()
|
_enable_focus.call_deferred()
|
||||||
|
|
||||||
func _handle_cancel_input() -> void:
|
func _handle_cancel_input() -> void:
|
||||||
|
if not is_listening_to_inputs:
|
||||||
|
return
|
||||||
|
|
||||||
if popup_open != null:
|
if popup_open != null:
|
||||||
close_popup()
|
close_popup()
|
||||||
else:
|
else:
|
||||||
@@ -68,6 +76,8 @@ func _ready() -> void:
|
|||||||
_hide_exit_for_web()
|
_hide_exit_for_web()
|
||||||
_hide_options_if_unset()
|
_hide_options_if_unset()
|
||||||
_hide_main_menu_if_unset()
|
_hide_main_menu_if_unset()
|
||||||
|
|
||||||
|
back_action.triggered.connect(_handle_cancel_input)
|
||||||
|
|
||||||
func _on_restart_button_pressed() -> void:
|
func _on_restart_button_pressed() -> void:
|
||||||
%ConfirmRestart.popup_centered()
|
%ConfirmRestart.popup_centered()
|
||||||
@@ -93,3 +103,5 @@ func _on_confirm_main_menu_confirmed() -> void:
|
|||||||
|
|
||||||
func _on_confirm_exit_confirmed() -> void:
|
func _on_confirm_exit_confirmed() -> void:
|
||||||
get_tree().quit()
|
get_tree().quit()
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -11,6 +11,8 @@ extends Control
|
|||||||
process_mode = PROCESS_MODE_INHERIT
|
process_mode = PROCESS_MODE_INHERIT
|
||||||
@export var makes_mouse_visible : bool = true
|
@export var makes_mouse_visible : bool = true
|
||||||
|
|
||||||
|
@export var back_action : GUIDEAction
|
||||||
|
|
||||||
signal menu_closing
|
signal menu_closing
|
||||||
|
|
||||||
var _initial_pause_state : bool = false
|
var _initial_pause_state : bool = false
|
||||||
@@ -32,13 +34,14 @@ func _handle_cancel_input() -> void:
|
|||||||
close()
|
close()
|
||||||
|
|
||||||
func _unhandled_input(event : InputEvent) -> void:
|
func _unhandled_input(event : InputEvent) -> void:
|
||||||
|
return
|
||||||
if event.is_action_pressed("ui_cancel"):
|
if event.is_action_pressed("ui_cancel"):
|
||||||
_handle_cancel_input()
|
_handle_cancel_input()
|
||||||
get_viewport().set_input_as_handled()
|
get_viewport().set_input_as_handled()
|
||||||
|
|
||||||
func _on_close_button_pressed() -> void:
|
func _on_close_button_pressed() -> void:
|
||||||
close()
|
close()
|
||||||
|
|
||||||
func _enter_tree() -> void:
|
func _enter_tree() -> void:
|
||||||
_scene_tree = get_tree()
|
_scene_tree = get_tree()
|
||||||
_initial_pause_state = _scene_tree.paused
|
_initial_pause_state = _scene_tree.paused
|
||||||
|
|||||||
@@ -12,3 +12,11 @@ extends OverlaidMenu
|
|||||||
if menu_scene:
|
if menu_scene:
|
||||||
var _instance = menu_scene.instantiate()
|
var _instance = menu_scene.instantiate()
|
||||||
%MenuContainer.add_child(_instance)
|
%MenuContainer.add_child(_instance)
|
||||||
|
|
||||||
|
func blocking_close() -> void:
|
||||||
|
get_viewport().set_input_as_handled()
|
||||||
|
super.close()
|
||||||
|
|
||||||
|
func _ready() -> void:
|
||||||
|
back_action.triggered.connect(blocking_close)
|
||||||
|
|
||||||
|
|||||||
@@ -7,15 +7,18 @@ extends Node
|
|||||||
@export var player : CharacterBody3D
|
@export var player : CharacterBody3D
|
||||||
|
|
||||||
@export_group("Inputs")
|
@export_group("Inputs")
|
||||||
@export var base_mode:GUIDEMappingContext
|
|
||||||
@export var pause:GUIDEAction
|
@export var pause:GUIDEAction
|
||||||
|
|
||||||
|
var menu_already_open = false
|
||||||
|
|
||||||
func _ready() -> void:
|
func _ready() -> void:
|
||||||
# GUIDE.enable_mapping_context(base_mode)
|
|
||||||
|
|
||||||
pause.triggered.connect(on_input_pause)
|
pause.triggered.connect(on_input_pause)
|
||||||
|
|
||||||
func on_input_pause():
|
func on_input_pause():
|
||||||
|
if menu_already_open:
|
||||||
|
return
|
||||||
|
|
||||||
|
menu_already_open = true
|
||||||
if not focused_viewport:
|
if not focused_viewport:
|
||||||
focused_viewport = get_viewport()
|
focused_viewport = get_viewport()
|
||||||
var _initial_focus_control = focused_viewport.gui_get_focus_owner()
|
var _initial_focus_control = focused_viewport.gui_get_focus_owner()
|
||||||
@@ -25,9 +28,6 @@ func on_input_pause():
|
|||||||
|
|
||||||
get_tree().current_scene.call_deferred("add_child", current_menu)
|
get_tree().current_scene.call_deferred("add_child", current_menu)
|
||||||
await current_menu.tree_exited
|
await current_menu.tree_exited
|
||||||
|
menu_already_open = false
|
||||||
if is_inside_tree() and _initial_focus_control:
|
if is_inside_tree() and _initial_focus_control:
|
||||||
_initial_focus_control.grab_focus()
|
_initial_focus_control.grab_focus()
|
||||||
|
|
||||||
func _unhandled_input(event : InputEvent) -> void:
|
|
||||||
if event.is_action_pressed("ui_cancel"):
|
|
||||||
pass
|
|
||||||
|
|||||||
@@ -30,6 +30,7 @@ glow_enabled = true
|
|||||||
|
|
||||||
[node name="Player" parent="." instance=ExtResource("1_1s2y7")]
|
[node name="Player" parent="." instance=ExtResource("1_1s2y7")]
|
||||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1.5)
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 1, 1.5)
|
||||||
|
TutorialDone = true
|
||||||
|
|
||||||
[node name="WorldEnvironment" type="WorldEnvironment" parent="."]
|
[node name="WorldEnvironment" type="WorldEnvironment" parent="."]
|
||||||
environment = SubResource("Environment_1bvp3")
|
environment = SubResource("Environment_1bvp3")
|
||||||
|
|||||||
385
maps/city.tscn
385
maps/city.tscn
@@ -1,12 +1,11 @@
|
|||||||
[gd_scene load_steps=41 format=3 uid="uid://dmkw8cmalm5k"]
|
[gd_scene load_steps=40 format=3 uid="uid://dmkw8cmalm5k"]
|
||||||
|
|
||||||
[ext_resource type="PackedScene" uid="uid://bei4nhkf8lwdo" path="res://player_controller/PlayerController.tscn" id="1_2vsi6"]
|
[ext_resource type="PackedScene" uid="uid://bei4nhkf8lwdo" path="res://player_controller/PlayerController.tscn" id="1_2vsi6"]
|
||||||
|
[ext_resource type="Script" uid="uid://blenis2y55fmg" path="res://tools/city_helpers.gd" id="1_qwuk2"]
|
||||||
[ext_resource type="Texture2D" uid="uid://ca4kkq3w8cd4n" path="res://assets/sky/sky_15_2k.png" id="2_ruo5i"]
|
[ext_resource type="Texture2D" uid="uid://ca4kkq3w8cd4n" path="res://assets/sky/sky_15_2k.png" id="2_ruo5i"]
|
||||||
[ext_resource type="PackedScene" uid="uid://dkr80d2pi0d41" path="res://addons/guide/debugger/guide_debugger.tscn" id="2_uet8a"]
|
[ext_resource type="PackedScene" uid="uid://dkr80d2pi0d41" path="res://addons/guide/debugger/guide_debugger.tscn" id="2_uet8a"]
|
||||||
[ext_resource type="Texture2D" uid="uid://7kcmi16gedd0" path="res://assets/LD-0001.png" id="3_ruo5i"]
|
|
||||||
[ext_resource type="Script" uid="uid://cyh0d64pfygbl" path="res://addons/maaacks_game_template/base/scripts/pause_menu_controller.gd" id="7_ukfuy"]
|
[ext_resource type="Script" uid="uid://cyh0d64pfygbl" path="res://addons/maaacks_game_template/base/scripts/pause_menu_controller.gd" id="7_ukfuy"]
|
||||||
[ext_resource type="PackedScene" uid="uid://ccqajqchiw4xu" path="res://menus/scenes/overlaid_menus/pause_menu.tscn" id="8_wctvs"]
|
[ext_resource type="PackedScene" uid="uid://ccqajqchiw4xu" path="res://menus/scenes/overlaid_menus/pause_menu.tscn" id="8_wctvs"]
|
||||||
[ext_resource type="Resource" uid="uid://bl5crtu1gkrtr" path="res://systems/inputs/base_mode/base_mode.tres" id="9_eca4n"]
|
|
||||||
[ext_resource type="PackedScene" uid="uid://bkcsjsk2ciff" path="res://addons/maaacks_game_template/base/scenes/music_players/background_music_player.tscn" id="9_i2xii"]
|
[ext_resource type="PackedScene" uid="uid://bkcsjsk2ciff" path="res://addons/maaacks_game_template/base/scenes/music_players/background_music_player.tscn" id="9_i2xii"]
|
||||||
[ext_resource type="Resource" uid="uid://dgluj0ql5vth7" path="res://systems/inputs/base_mode/pause.tres" id="10_0ari0"]
|
[ext_resource type="Resource" uid="uid://dgluj0ql5vth7" path="res://systems/inputs/base_mode/pause.tres" id="10_0ari0"]
|
||||||
[ext_resource type="AudioStream" uid="uid://f8cvr5s041ej" path="res://assets/audio/ambiance/637083__nox_sound__ambiance_nature_night_cricket_calm_loop_stereo.wav" id="10_eca4n"]
|
[ext_resource type="AudioStream" uid="uid://f8cvr5s041ej" path="res://assets/audio/ambiance/637083__nox_sound__ambiance_nature_night_cricket_calm_loop_stereo.wav" id="10_eca4n"]
|
||||||
@@ -25,32 +24,8 @@
|
|||||||
[ext_resource type="Texture2D" uid="uid://nrhxjdpuje3f" path="res://assets/ui/input-prompts/Xbox Series/Vector/xbox_lt_outline.svg" id="20_crf87"]
|
[ext_resource type="Texture2D" uid="uid://nrhxjdpuje3f" path="res://assets/ui/input-prompts/Xbox Series/Vector/xbox_lt_outline.svg" id="20_crf87"]
|
||||||
[ext_resource type="Texture2D" uid="uid://dyjvbsvbriii4" path="res://assets/ui/input-prompts/Xbox Series/Vector/xbox_rb_outline.svg" id="23_p287n"]
|
[ext_resource type="Texture2D" uid="uid://dyjvbsvbriii4" path="res://assets/ui/input-prompts/Xbox Series/Vector/xbox_rb_outline.svg" id="23_p287n"]
|
||||||
|
|
||||||
[sub_resource type="PanoramaSkyMaterial" id="PanoramaSkyMaterial_feb1n"]
|
[sub_resource type="LabelSettings" id="LabelSettings_2k3fr"]
|
||||||
panorama = ExtResource("2_ruo5i")
|
font_size = 30
|
||||||
|
|
||||||
[sub_resource type="Sky" id="Sky_h2yge"]
|
|
||||||
sky_material = SubResource("PanoramaSkyMaterial_feb1n")
|
|
||||||
|
|
||||||
[sub_resource type="Environment" id="Environment_1bvp3"]
|
|
||||||
background_mode = 2
|
|
||||||
sky = SubResource("Sky_h2yge")
|
|
||||||
ambient_light_source = 3
|
|
||||||
reflected_light_source = 2
|
|
||||||
tonemap_mode = 4
|
|
||||||
ssao_enabled = true
|
|
||||||
ssil_enabled = true
|
|
||||||
sdfgi_enabled = true
|
|
||||||
sdfgi_use_occlusion = true
|
|
||||||
glow_enabled = true
|
|
||||||
fog_enabled = true
|
|
||||||
fog_light_color = Color(0.9955967, 0.83634025, 0.69151855, 1)
|
|
||||||
fog_sun_scatter = 0.5
|
|
||||||
fog_density = 0.002
|
|
||||||
fog_sky_affect = 0.184
|
|
||||||
volumetric_fog_density = 0.004
|
|
||||||
volumetric_fog_emission = Color(1, 1, 1, 1)
|
|
||||||
volumetric_fog_anisotropy = 0.6
|
|
||||||
adjustment_enabled = true
|
|
||||||
|
|
||||||
[sub_resource type="BoxShape3D" id="BoxShape3D_t0d86"]
|
[sub_resource type="BoxShape3D" id="BoxShape3D_t0d86"]
|
||||||
size = Vector3(14, 15.5, 26)
|
size = Vector3(14, 15.5, 26)
|
||||||
@@ -85,187 +60,56 @@ size = Vector3(11.5, 9, 4.5)
|
|||||||
[sub_resource type="BoxShape3D" id="BoxShape3D_pxspk"]
|
[sub_resource type="BoxShape3D" id="BoxShape3D_pxspk"]
|
||||||
size = Vector3(11.5, 9, 4.5)
|
size = Vector3(11.5, 9, 4.5)
|
||||||
|
|
||||||
[sub_resource type="LabelSettings" id="LabelSettings_2k3fr"]
|
[sub_resource type="PanoramaSkyMaterial" id="PanoramaSkyMaterial_feb1n"]
|
||||||
font_size = 30
|
panorama = ExtResource("2_ruo5i")
|
||||||
|
|
||||||
|
[sub_resource type="Sky" id="Sky_h2yge"]
|
||||||
|
sky_material = SubResource("PanoramaSkyMaterial_feb1n")
|
||||||
|
|
||||||
|
[sub_resource type="Environment" id="Environment_1bvp3"]
|
||||||
|
background_mode = 2
|
||||||
|
sky = SubResource("Sky_h2yge")
|
||||||
|
ambient_light_source = 3
|
||||||
|
reflected_light_source = 2
|
||||||
|
tonemap_mode = 4
|
||||||
|
ssao_enabled = true
|
||||||
|
ssil_enabled = true
|
||||||
|
sdfgi_enabled = true
|
||||||
|
sdfgi_use_occlusion = true
|
||||||
|
glow_enabled = true
|
||||||
|
fog_enabled = true
|
||||||
|
fog_light_color = Color(0.9955967, 0.83634025, 0.69151855, 1)
|
||||||
|
fog_sun_scatter = 0.5
|
||||||
|
fog_density = 0.002
|
||||||
|
fog_sky_affect = 0.184
|
||||||
|
volumetric_fog_density = 0.004
|
||||||
|
volumetric_fog_emission = Color(1, 1, 1, 1)
|
||||||
|
volumetric_fog_anisotropy = 0.6
|
||||||
|
adjustment_enabled = true
|
||||||
|
|
||||||
[sub_resource type="BoxMesh" id="BoxMesh_p287n"]
|
[sub_resource type="BoxMesh" id="BoxMesh_p287n"]
|
||||||
|
|
||||||
[node name="Main" type="Node3D"]
|
[node name="Main" type="Node3D"]
|
||||||
|
script = ExtResource("1_qwuk2")
|
||||||
|
|
||||||
[node name="Player" parent="." node_paths=PackedStringArray("TutorialWeaponTarget") instance=ExtResource("1_2vsi6")]
|
[node name="BackgroundMusicPlayer" parent="." instance=ExtResource("9_i2xii")]
|
||||||
transform = Transform3D(0.054514527, 0, -0.9985129, 0, 1, 0, 0.9985129, 0, 0.054514527, -0.17818737, -132.74933, 118.101845)
|
stream = ExtResource("10_eca4n")
|
||||||
collision_layer = 17
|
|
||||||
TutorialWeaponTarget = NodePath("../PlacedTutorialWeapon/WeaponLocationTarget")
|
|
||||||
AccelerationAir = 1.5
|
|
||||||
|
|
||||||
[node name="WorldEnvironment" type="WorldEnvironment" parent="."]
|
|
||||||
environment = SubResource("Environment_1bvp3")
|
|
||||||
|
|
||||||
[node name="DirectionalLight3D" type="DirectionalLight3D" parent="."]
|
|
||||||
transform = Transform3D(-0.78043425, 0.15240018, 0.60637933, 0.17673612, -0.8765135, 0.44775894, 0.5997381, 0.4566158, 0.6571267, 0, 0, 0)
|
|
||||||
light_color = Color(0.99999934, 0.76777613, 0.6549227, 1)
|
|
||||||
light_energy = 2.0
|
|
||||||
light_volumetric_fog_energy = 2.0
|
|
||||||
shadow_enabled = true
|
|
||||||
shadow_opacity = 0.95
|
|
||||||
shadow_blur = 2.435
|
|
||||||
|
|
||||||
[node name="DebugLayer" type="CanvasLayer" parent="."]
|
|
||||||
|
|
||||||
[node name="GuideDebugger" parent="DebugLayer" instance=ExtResource("2_uet8a")]
|
|
||||||
visible = false
|
|
||||||
|
|
||||||
[node name="Map" type="Sprite3D" parent="."]
|
|
||||||
transform = Transform3D(-3.278354e-07, -7.5, -3.278354e-08, 0, -3.278354e-07, 0.75, -7.5, 3.278354e-07, 1.4330142e-15, 7.1878185, 8.602432, -175.5159)
|
|
||||||
visible = false
|
|
||||||
texture = ExtResource("3_ruo5i")
|
|
||||||
|
|
||||||
[node name="Guard tower" parent="." instance=ExtResource("11_wctvs")]
|
|
||||||
transform = Transform3D(0.09033705, 0, 0.99591124, 0, 1, 0, -0.99591124, 0, 0.09033705, -4.6100636, 1.5, 0.5658741)
|
|
||||||
|
|
||||||
[node name="Water" parent="." instance=ExtResource("12_i2xii")]
|
|
||||||
transform = Transform3D(10000, 0, 0, 0, 1, 0, 0, 0, 10000, 0, 4.03932, -186.25941)
|
|
||||||
|
|
||||||
[node name="PauseMenuController" type="Node" parent="." node_paths=PackedStringArray("player")]
|
[node name="PauseMenuController" type="Node" parent="." node_paths=PackedStringArray("player")]
|
||||||
script = ExtResource("7_ukfuy")
|
script = ExtResource("7_ukfuy")
|
||||||
pause_menu_packed = ExtResource("8_wctvs")
|
pause_menu_packed = ExtResource("8_wctvs")
|
||||||
player = NodePath("../Player")
|
player = NodePath("../Player")
|
||||||
base_mode = ExtResource("9_eca4n")
|
|
||||||
pause = ExtResource("10_0ari0")
|
pause = ExtResource("10_0ari0")
|
||||||
|
|
||||||
[node name="BackgroundMusicPlayer" parent="." instance=ExtResource("9_i2xii")]
|
|
||||||
stream = ExtResource("10_eca4n")
|
|
||||||
|
|
||||||
[node name="Lift" parent="." instance=ExtResource("13_eca4n")]
|
|
||||||
transform = Transform3D(0.9961947, 0, -0.08715573, 0, 1, 0, 0.08715573, 0, 0.9961947, -4.593, 1.618, 0.583)
|
|
||||||
end_location = Vector3(-4.593, 116.11, 0.583)
|
|
||||||
lift_time = 8.0
|
|
||||||
|
|
||||||
[node name="PlacedTutorialWeapon" type="MeshInstance3D" parent="."]
|
|
||||||
transform = Transform3D(-2, 3.019916e-07, 0, -3.019916e-07, -2, 0, 0, 0, 2, -17.904, -79.265, 145.317)
|
|
||||||
mesh = ExtResource("14_0ari0")
|
|
||||||
script = ExtResource("15_165wb")
|
|
||||||
|
|
||||||
[node name="SpotLight3D" type="SpotLight3D" parent="PlacedTutorialWeapon"]
|
|
||||||
transform = Transform3D(1, -1.509958e-07, 6.600236e-15, 0, -4.371139e-08, -1, 1.509958e-07, 1, -4.371139e-08, 0, -2.3931274, 0)
|
|
||||||
spot_range = 9.85
|
|
||||||
spot_attenuation = 0.46
|
|
||||||
spot_angle = 15.0
|
|
||||||
|
|
||||||
[node name="WeaponLocationTarget" type="Marker3D" parent="PlacedTutorialWeapon"]
|
|
||||||
|
|
||||||
[node name="TutoTriggers" type="Node3D" parent="."]
|
|
||||||
transform = Transform3D(0.054514527, 0, -0.9985129, 0, 1, 0, 0.9985129, 0, 0.054514527, -0.78573227, -132.74933, 116.65933)
|
|
||||||
|
|
||||||
[node name="TriggerTutoMove" type="Area3D" parent="TutoTriggers"]
|
|
||||||
collision_layer = 0
|
|
||||||
collision_mask = 16
|
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TriggerTutoMove"]
|
|
||||||
transform = Transform3D(0.9961947, 0, -0.087155946, 0, 1, 0, 0.087155946, 0, 0.9961947, 1.1144943, 6.5, 1.6032357)
|
|
||||||
shape = SubResource("BoxShape3D_t0d86")
|
|
||||||
|
|
||||||
[node name="TriggerTutoMantle" type="Area3D" parent="TutoTriggers"]
|
|
||||||
transform = Transform3D(0.9961947, 0, -0.087155744, 0, 1, 0, 0.087155744, 0, 0.9961947, -10.4557495, 0, -28.61254)
|
|
||||||
collision_layer = 0
|
|
||||||
collision_mask = 16
|
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TriggerTutoMantle"]
|
|
||||||
transform = Transform3D(0.9961947, 0, -0.08715595, 0, 1, 0, 0.08715595, 0, 0.9961947, 0.19611359, 7, -2.241436)
|
|
||||||
shape = SubResource("BoxShape3D_p287n")
|
|
||||||
|
|
||||||
[node name="TutoJump" parent="TutoTriggers" instance=ExtResource("16_qwuk2")]
|
|
||||||
transform = Transform3D(0.14133328, 0, 0.98996216, 0, 1, 0, -0.98996216, 0, 0.14133328, -0.32653046, 1.2493286, -50.374645)
|
|
||||||
first_input_texture = ExtResource("16_2k3fr")
|
|
||||||
second_input_texture = ExtResource("16_2k3fr")
|
|
||||||
tuto_text = "Double jump"
|
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TutoJump"]
|
|
||||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0.49998856, 6.25, 3.499977)
|
|
||||||
shape = SubResource("BoxShape3D_5hbxb")
|
|
||||||
|
|
||||||
[node name="TutoDash" parent="TutoTriggers" instance=ExtResource("16_qwuk2")]
|
|
||||||
transform = Transform3D(0.14133328, 0, 0.98996216, 0, 1, 0, -0.98996216, 0, 0.14133328, 19.967693, 1.2493286, -47.47731)
|
|
||||||
first_input_texture = ExtResource("16_crf87")
|
|
||||||
second_input_texture = ExtResource("19_efsse")
|
|
||||||
tuto_text = "Dash"
|
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TutoDash"]
|
|
||||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0.49999237, 6.25, 4.2500153)
|
|
||||||
shape = SubResource("BoxShape3D_6gj1x")
|
|
||||||
|
|
||||||
[node name="TriggerTutoWallJump" type="Area3D" parent="TutoTriggers"]
|
|
||||||
transform = Transform3D(0.9961947, 0, -0.087155744, 0, 1, 0, 0.087155744, 0, 0.9961947, 38.60766, 0, -28.437609)
|
|
||||||
collision_layer = 0
|
|
||||||
collision_mask = 16
|
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TriggerTutoWallJump"]
|
|
||||||
transform = Transform3D(0.9961947, 0, -0.08715595, 0, 1, 0, 0.08715595, 0, 0.9961947, -1.9546509, 20.75, 10.8709755)
|
|
||||||
shape = SubResource("BoxShape3D_x7fl1")
|
|
||||||
|
|
||||||
[node name="TriggerTutoWallJump2" type="Area3D" parent="TutoTriggers"]
|
|
||||||
transform = Transform3D(0.9961947, 0, -0.087155744, 0, 1, 0, 0.087155744, 0, 0.9961947, 15.983452, 0, 37.426994)
|
|
||||||
collision_layer = 0
|
|
||||||
collision_mask = 16
|
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TriggerTutoWallJump2"]
|
|
||||||
transform = Transform3D(0.9961947, 0, -0.08715595, 0, 1, 0, 0.08715595, 0, 0.9961947, 2.3256226, 21.75, 4.9715767)
|
|
||||||
shape = SubResource("BoxShape3D_3wccx")
|
|
||||||
|
|
||||||
[node name="TutoDash2" parent="TutoTriggers" instance=ExtResource("16_qwuk2")]
|
|
||||||
transform = Transform3D(0.14133325, 0, 0.98996216, 0, 1, 0, -0.98996216, 0, 0.14133325, 28.885735, 27.749329, 25.360323)
|
|
||||||
first_input_texture = ExtResource("16_crf87")
|
|
||||||
second_input_texture = ExtResource("19_efsse")
|
|
||||||
complex_input_text = "in air"
|
|
||||||
tuto_text = "Dash"
|
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TutoDash2"]
|
|
||||||
transform = Transform3D(1.0000031, 0, -4.917383e-07, 0, 1, 0, 4.917383e-07, 0, 1.0000031, 5.500023, 5, 0)
|
|
||||||
shape = SubResource("BoxShape3D_hmdts")
|
|
||||||
|
|
||||||
[node name="TriggerTutoWeaponThrow" type="Area3D" parent="TutoTriggers"]
|
|
||||||
transform = Transform3D(0.9961947, 0, -0.087155744, 0, 1, 0, 0.087155744, 0, 0.9961947, 4.428787, 58, 19.770819)
|
|
||||||
collision_layer = 0
|
|
||||||
collision_mask = 16
|
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TriggerTutoWeaponThrow"]
|
|
||||||
transform = Transform3D(0.9961947, 0, -0.08715595, 0, 1, 0, 0.08715595, 0, 0.9961947, 4.4208603, 7, -4.632329)
|
|
||||||
shape = SubResource("BoxShape3D_lnjrw")
|
|
||||||
|
|
||||||
[node name="TriggerTutoEnjoy" type="Area3D" parent="TutoTriggers"]
|
|
||||||
transform = Transform3D(0.9961947, 0, -0.087155744, 0, 1, 0, 0.087155744, 0, 0.9961947, -120.81145, 214.5, 2.417603)
|
|
||||||
collision_layer = 0
|
|
||||||
collision_mask = 16
|
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TriggerTutoEnjoy"]
|
|
||||||
transform = Transform3D(0.9961947, 0, -0.08715595, 0, 1, 0, 0.08715595, 0, 0.9961947, 3.9663503, 5.5, -5.174009)
|
|
||||||
shape = SubResource("BoxShape3D_3w3wd")
|
|
||||||
|
|
||||||
[node name="TutorialDoneArea" type="Area3D" parent="TutoTriggers"]
|
|
||||||
transform = Transform3D(0.14133324, 0, 0.98996216, 0, 1, 0, -0.98996216, 0, 0.14133324, 7.9436035, 53.74933, 16.672102)
|
|
||||||
collision_layer = 0
|
|
||||||
collision_mask = 16
|
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TutorialDoneArea"]
|
|
||||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0.7500105, 4, 0.7499695)
|
|
||||||
shape = SubResource("BoxShape3D_lu3yt")
|
|
||||||
|
|
||||||
[node name="WeaponRetrieved" type="Area3D" parent="TutoTriggers"]
|
|
||||||
transform = Transform3D(0.14133324, 0, 0.98996216, 0, 1, 0, -0.98996216, 0, 0.14133324, 27.3601, 53.74933, 18.733648)
|
|
||||||
collision_layer = 0
|
|
||||||
collision_mask = 16
|
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/WeaponRetrieved"]
|
|
||||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0.7500105, 4, 0.7499695)
|
|
||||||
shape = SubResource("BoxShape3D_pxspk")
|
|
||||||
|
|
||||||
[node name="TutorialController" type="Control" parent="."]
|
[node name="TutorialController" type="Control" parent="."]
|
||||||
|
visible = false
|
||||||
layout_mode = 3
|
layout_mode = 3
|
||||||
anchors_preset = 15
|
anchors_preset = 15
|
||||||
anchor_right = 1.0
|
anchor_right = 1.0
|
||||||
anchor_bottom = 1.0
|
anchor_bottom = 1.0
|
||||||
grow_horizontal = 2
|
grow_horizontal = 2
|
||||||
grow_vertical = 2
|
grow_vertical = 2
|
||||||
|
mouse_filter = 1
|
||||||
script = ExtResource("16_efsse")
|
script = ExtResource("16_efsse")
|
||||||
tuto_got_sword_packed = ExtResource("17_t0d86")
|
tuto_got_sword_packed = ExtResource("17_t0d86")
|
||||||
|
|
||||||
@@ -414,6 +258,159 @@ layout_mode = 2
|
|||||||
text = "Enjoy this little playground!"
|
text = "Enjoy this little playground!"
|
||||||
label_settings = SubResource("LabelSettings_2k3fr")
|
label_settings = SubResource("LabelSettings_2k3fr")
|
||||||
|
|
||||||
|
[node name="TutoTriggers" type="Node3D" parent="."]
|
||||||
|
transform = Transform3D(0.054514527, 0, -0.9985129, 0, 1, 0, 0.9985129, 0, 0.054514527, -0.78573227, -132.74933, 116.65933)
|
||||||
|
|
||||||
|
[node name="TriggerTutoMove" type="Area3D" parent="TutoTriggers"]
|
||||||
|
collision_layer = 0
|
||||||
|
collision_mask = 16
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TriggerTutoMove"]
|
||||||
|
transform = Transform3D(0.9961947, 0, -0.087155946, 0, 1, 0, 0.087155946, 0, 0.9961947, 1.1144943, 6.5, 1.6032357)
|
||||||
|
shape = SubResource("BoxShape3D_t0d86")
|
||||||
|
|
||||||
|
[node name="TriggerTutoMantle" type="Area3D" parent="TutoTriggers"]
|
||||||
|
transform = Transform3D(0.9961947, 0, -0.087155744, 0, 1, 0, 0.087155744, 0, 0.9961947, -10.4557495, 0, -28.61254)
|
||||||
|
collision_layer = 0
|
||||||
|
collision_mask = 16
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TriggerTutoMantle"]
|
||||||
|
transform = Transform3D(0.9961947, 0, -0.08715595, 0, 1, 0, 0.08715595, 0, 0.9961947, 0.19611359, 7, -2.241436)
|
||||||
|
shape = SubResource("BoxShape3D_p287n")
|
||||||
|
|
||||||
|
[node name="TutoJump" parent="TutoTriggers" instance=ExtResource("16_qwuk2")]
|
||||||
|
transform = Transform3D(0.14133328, 0, 0.98996216, 0, 1, 0, -0.98996216, 0, 0.14133328, -0.32653046, 1.2493286, -50.374645)
|
||||||
|
first_input_texture = ExtResource("16_2k3fr")
|
||||||
|
second_input_texture = ExtResource("16_2k3fr")
|
||||||
|
tuto_text = "Double jump"
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TutoJump"]
|
||||||
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0.49998856, 6.25, 3.499977)
|
||||||
|
shape = SubResource("BoxShape3D_5hbxb")
|
||||||
|
|
||||||
|
[node name="TutoDash" parent="TutoTriggers" instance=ExtResource("16_qwuk2")]
|
||||||
|
transform = Transform3D(0.14133328, 0, 0.98996216, 0, 1, 0, -0.98996216, 0, 0.14133328, 19.967693, 1.2493286, -47.47731)
|
||||||
|
first_input_texture = ExtResource("16_crf87")
|
||||||
|
second_input_texture = ExtResource("19_efsse")
|
||||||
|
tuto_text = "Dash"
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TutoDash"]
|
||||||
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0.49999237, 6.25, 4.2500153)
|
||||||
|
shape = SubResource("BoxShape3D_6gj1x")
|
||||||
|
|
||||||
|
[node name="TriggerTutoWallJump" type="Area3D" parent="TutoTriggers"]
|
||||||
|
transform = Transform3D(0.9961947, 0, -0.087155744, 0, 1, 0, 0.087155744, 0, 0.9961947, 38.60766, 0, -28.437609)
|
||||||
|
collision_layer = 0
|
||||||
|
collision_mask = 16
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TriggerTutoWallJump"]
|
||||||
|
transform = Transform3D(0.9961947, 0, -0.08715595, 0, 1, 0, 0.08715595, 0, 0.9961947, -1.9546509, 20.75, 10.8709755)
|
||||||
|
shape = SubResource("BoxShape3D_x7fl1")
|
||||||
|
|
||||||
|
[node name="TriggerTutoWallJump2" type="Area3D" parent="TutoTriggers"]
|
||||||
|
transform = Transform3D(0.9961947, 0, -0.087155744, 0, 1, 0, 0.087155744, 0, 0.9961947, 15.983452, 0, 37.426994)
|
||||||
|
collision_layer = 0
|
||||||
|
collision_mask = 16
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TriggerTutoWallJump2"]
|
||||||
|
transform = Transform3D(0.9961947, 0, -0.08715595, 0, 1, 0, 0.08715595, 0, 0.9961947, 2.3256226, 21.75, 4.9715767)
|
||||||
|
shape = SubResource("BoxShape3D_3wccx")
|
||||||
|
|
||||||
|
[node name="TutoDash2" parent="TutoTriggers" instance=ExtResource("16_qwuk2")]
|
||||||
|
transform = Transform3D(0.14133325, 0, 0.98996216, 0, 1, 0, -0.98996216, 0, 0.14133325, 28.885735, 27.749329, 25.360323)
|
||||||
|
first_input_texture = ExtResource("16_crf87")
|
||||||
|
second_input_texture = ExtResource("19_efsse")
|
||||||
|
complex_input_text = "in air"
|
||||||
|
tuto_text = "Dash"
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TutoDash2"]
|
||||||
|
transform = Transform3D(1.0000031, 0, -4.917383e-07, 0, 1, 0, 4.917383e-07, 0, 1.0000031, 5.500023, 5, 0)
|
||||||
|
shape = SubResource("BoxShape3D_hmdts")
|
||||||
|
|
||||||
|
[node name="TriggerTutoWeaponThrow" type="Area3D" parent="TutoTriggers"]
|
||||||
|
transform = Transform3D(0.9961947, 0, -0.087155744, 0, 1, 0, 0.087155744, 0, 0.9961947, 4.428787, 58, 19.770819)
|
||||||
|
collision_layer = 0
|
||||||
|
collision_mask = 16
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TriggerTutoWeaponThrow"]
|
||||||
|
transform = Transform3D(0.9961947, 0, -0.08715595, 0, 1, 0, 0.08715595, 0, 0.9961947, 4.4208603, 7, -4.632329)
|
||||||
|
shape = SubResource("BoxShape3D_lnjrw")
|
||||||
|
|
||||||
|
[node name="TriggerTutoEnjoy" type="Area3D" parent="TutoTriggers"]
|
||||||
|
transform = Transform3D(0.9961947, 0, -0.087155744, 0, 1, 0, 0.087155744, 0, 0.9961947, -120.81145, 214.5, 2.417603)
|
||||||
|
collision_layer = 0
|
||||||
|
collision_mask = 16
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TriggerTutoEnjoy"]
|
||||||
|
transform = Transform3D(0.9961947, 0, -0.08715595, 0, 1, 0, 0.08715595, 0, 0.9961947, 3.9663503, 5.5, -5.174009)
|
||||||
|
shape = SubResource("BoxShape3D_3w3wd")
|
||||||
|
|
||||||
|
[node name="TutorialDoneArea" type="Area3D" parent="TutoTriggers"]
|
||||||
|
transform = Transform3D(0.14133324, 0, 0.98996216, 0, 1, 0, -0.98996216, 0, 0.14133324, 7.9436035, 53.74933, 16.672102)
|
||||||
|
collision_layer = 0
|
||||||
|
collision_mask = 16
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/TutorialDoneArea"]
|
||||||
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0.7500105, 4, 0.7499695)
|
||||||
|
shape = SubResource("BoxShape3D_lu3yt")
|
||||||
|
|
||||||
|
[node name="WeaponRetrieved" type="Area3D" parent="TutoTriggers"]
|
||||||
|
transform = Transform3D(0.14133324, 0, 0.98996216, 0, 1, 0, -0.98996216, 0, 0.14133324, 27.3601, 53.74933, 18.733648)
|
||||||
|
collision_layer = 0
|
||||||
|
collision_mask = 16
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="TutoTriggers/WeaponRetrieved"]
|
||||||
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0.7500105, 4, 0.7499695)
|
||||||
|
shape = SubResource("BoxShape3D_pxspk")
|
||||||
|
|
||||||
|
[node name="WorldEnvironment" type="WorldEnvironment" parent="."]
|
||||||
|
environment = SubResource("Environment_1bvp3")
|
||||||
|
|
||||||
|
[node name="DirectionalLight3D" type="DirectionalLight3D" parent="."]
|
||||||
|
transform = Transform3D(-0.7804346, 0.15240021, 0.60637945, 0.1767362, -0.87651366, 0.4477591, 0.5997384, 0.4566159, 0.6571269, 0, 0, 0)
|
||||||
|
light_color = Color(0.99999934, 0.76777613, 0.6549227, 1)
|
||||||
|
light_energy = 2.0
|
||||||
|
light_volumetric_fog_energy = 2.0
|
||||||
|
shadow_enabled = true
|
||||||
|
shadow_opacity = 0.95
|
||||||
|
shadow_blur = 2.435
|
||||||
|
|
||||||
|
[node name="Player" parent="." node_paths=PackedStringArray("TutorialWeaponTarget") instance=ExtResource("1_2vsi6")]
|
||||||
|
transform = Transform3D(0.054514527, 0, -0.9985129, 0, 1, 0, 0.9985129, 0, 0.054514527, -6, 75.5, -13.5)
|
||||||
|
collision_layer = 17
|
||||||
|
TutorialWeaponTarget = NodePath("../PlacedTutorialWeapon/WeaponLocationTarget")
|
||||||
|
TutorialDone = true
|
||||||
|
AccelerationAir = 1.5
|
||||||
|
|
||||||
|
[node name="DebugLayer" type="CanvasLayer" parent="."]
|
||||||
|
|
||||||
|
[node name="GuideDebugger" parent="DebugLayer" instance=ExtResource("2_uet8a")]
|
||||||
|
visible = false
|
||||||
|
|
||||||
|
[node name="Guard tower" parent="." instance=ExtResource("11_wctvs")]
|
||||||
|
transform = Transform3D(0.09033705, 0, 0.99591124, 0, 1, 0, -0.99591124, 0, 0.09033705, -4.6100636, 1.5, 0.5658741)
|
||||||
|
|
||||||
|
[node name="Water" parent="." instance=ExtResource("12_i2xii")]
|
||||||
|
transform = Transform3D(10000, 0, 0, 0, 1, 0, 0, 0, 10000, 0, 4.03932, -186.25941)
|
||||||
|
|
||||||
|
[node name="Lift" parent="." instance=ExtResource("13_eca4n")]
|
||||||
|
transform = Transform3D(0.9961947, 0, -0.08715573, 0, 1, 0, 0.08715573, 0, 0.9961947, -4.593, 1.618, 0.583)
|
||||||
|
end_location = Vector3(-4.593, 116.11, 0.583)
|
||||||
|
lift_time = 8.0
|
||||||
|
|
||||||
|
[node name="PlacedTutorialWeapon" type="MeshInstance3D" parent="."]
|
||||||
|
transform = Transform3D(-2, 3.019916e-07, 0, -3.019916e-07, -2, 0, 0, 0, 2, -17.904, -79.265, 145.317)
|
||||||
|
mesh = ExtResource("14_0ari0")
|
||||||
|
script = ExtResource("15_165wb")
|
||||||
|
|
||||||
|
[node name="SpotLight3D" type="SpotLight3D" parent="PlacedTutorialWeapon"]
|
||||||
|
transform = Transform3D(1, -1.509958e-07, 6.600236e-15, 0, -4.371139e-08, -1, 1.509958e-07, 1, -4.371139e-08, 0, -2.3931274, 0)
|
||||||
|
spot_range = 9.85
|
||||||
|
spot_attenuation = 0.46
|
||||||
|
spot_angle = 15.0
|
||||||
|
|
||||||
|
[node name="WeaponLocationTarget" type="Marker3D" parent="PlacedTutorialWeapon"]
|
||||||
|
|
||||||
[node name="LightLeakBlockers" type="Node3D" parent="."]
|
[node name="LightLeakBlockers" type="Node3D" parent="."]
|
||||||
|
|
||||||
[node name="MeshInstance3D" type="MeshInstance3D" parent="LightLeakBlockers"]
|
[node name="MeshInstance3D" type="MeshInstance3D" parent="LightLeakBlockers"]
|
||||||
@@ -440,6 +437,7 @@ spot_range = 47.233
|
|||||||
spot_angle = 18.85
|
spot_angle = 18.85
|
||||||
spot_angle_attenuation = 10.556052
|
spot_angle_attenuation = 10.556052
|
||||||
|
|
||||||
|
[connection signal="timeout" from="TutorialController/WaitToShowBlockingTuto" to="TutorialController" method="_show_weapon_tutorial"]
|
||||||
[connection signal="body_exited" from="TutoTriggers/TriggerTutoMove" to="TutorialController" method="hide_tutorials"]
|
[connection signal="body_exited" from="TutoTriggers/TriggerTutoMove" to="TutorialController" method="hide_tutorials"]
|
||||||
[connection signal="body_entered" from="TutoTriggers/TriggerTutoMantle" to="TutorialController" method="_on_tuto_mantle_body_entered"]
|
[connection signal="body_entered" from="TutoTriggers/TriggerTutoMantle" to="TutorialController" method="_on_tuto_mantle_body_entered"]
|
||||||
[connection signal="body_exited" from="TutoTriggers/TriggerTutoMantle" to="TutorialController" method="hide_tutorials"]
|
[connection signal="body_exited" from="TutoTriggers/TriggerTutoMantle" to="TutorialController" method="hide_tutorials"]
|
||||||
@@ -451,9 +449,8 @@ spot_angle_attenuation = 10.556052
|
|||||||
[connection signal="body_exited" from="TutoTriggers/TriggerTutoWeaponThrow" to="TutorialController" method="hide_tutorials"]
|
[connection signal="body_exited" from="TutoTriggers/TriggerTutoWeaponThrow" to="TutorialController" method="hide_tutorials"]
|
||||||
[connection signal="body_entered" from="TutoTriggers/TriggerTutoEnjoy" to="TutorialController" method="_on_tuto_enjoy_body_entered"]
|
[connection signal="body_entered" from="TutoTriggers/TriggerTutoEnjoy" to="TutorialController" method="_on_tuto_enjoy_body_entered"]
|
||||||
[connection signal="body_exited" from="TutoTriggers/TriggerTutoEnjoy" to="TutorialController" method="hide_tutorials"]
|
[connection signal="body_exited" from="TutoTriggers/TriggerTutoEnjoy" to="TutorialController" method="hide_tutorials"]
|
||||||
[connection signal="body_entered" from="TutoTriggers/TutorialDoneArea" to="Player" method="OnTutorialDone"]
|
|
||||||
[connection signal="body_entered" from="TutoTriggers/TutorialDoneArea" to="TutorialController" method="_on_tuto_done_area_body_entered"]
|
[connection signal="body_entered" from="TutoTriggers/TutorialDoneArea" to="TutorialController" method="_on_tuto_done_area_body_entered"]
|
||||||
|
[connection signal="body_entered" from="TutoTriggers/TutorialDoneArea" to="Player" method="OnTutorialDone"]
|
||||||
[connection signal="body_exited" from="TutoTriggers/TutorialDoneArea" to="TutorialController" method="hide_tutorials"]
|
[connection signal="body_exited" from="TutoTriggers/TutorialDoneArea" to="TutorialController" method="hide_tutorials"]
|
||||||
[connection signal="body_entered" from="TutoTriggers/WeaponRetrieved" to="PlacedTutorialWeapon" method="_on_weapon_retrieved_body_entered"]
|
|
||||||
[connection signal="body_entered" from="TutoTriggers/WeaponRetrieved" to="TutorialController" method="_on_weapon_retrieved_body_entered"]
|
[connection signal="body_entered" from="TutoTriggers/WeaponRetrieved" to="TutorialController" method="_on_weapon_retrieved_body_entered"]
|
||||||
[connection signal="timeout" from="TutorialController/WaitToShowBlockingTuto" to="TutorialController" method="_show_weapon_tutorial"]
|
[connection signal="body_entered" from="TutoTriggers/WeaponRetrieved" to="PlacedTutorialWeapon" method="_on_weapon_retrieved_body_entered"]
|
||||||
|
|||||||
@@ -1,8 +1,10 @@
|
|||||||
[gd_scene load_steps=17 format=3 uid="uid://vm22i5sv3p3s"]
|
[gd_scene load_steps=19 format=3 uid="uid://vm22i5sv3p3s"]
|
||||||
|
|
||||||
[ext_resource type="PackedScene" uid="uid://c6k5nnpbypshi" path="res://addons/maaacks_game_template/base/scenes/menus/main_menu/main_menu.tscn" id="1_my8ii"]
|
[ext_resource type="PackedScene" uid="uid://c6k5nnpbypshi" path="res://addons/maaacks_game_template/base/scenes/menus/main_menu/main_menu.tscn" id="1_my8ii"]
|
||||||
[ext_resource type="Script" uid="uid://c0ntfmiuw4ttg" path="res://menus/scenes/menus/main_menu/main_menu_with_animations.gd" id="2_nyjay"]
|
[ext_resource type="Script" uid="uid://c0ntfmiuw4ttg" path="res://menus/scenes/menus/main_menu/main_menu_with_animations.gd" id="2_nyjay"]
|
||||||
[ext_resource type="AudioStream" uid="uid://f8cvr5s041ej" path="res://assets/audio/ambiance/637083__nox_sound__ambiance_nature_night_cricket_calm_loop_stereo.wav" id="3_tvvjd"]
|
[ext_resource type="AudioStream" uid="uid://f8cvr5s041ej" path="res://assets/audio/ambiance/637083__nox_sound__ambiance_nature_night_cricket_calm_loop_stereo.wav" id="3_tvvjd"]
|
||||||
|
[ext_resource type="Resource" uid="uid://c2hpxkcujyc13" path="res://systems/inputs/menu_mode/menu_mode.tres" id="3_ytpwg"]
|
||||||
|
[ext_resource type="Resource" uid="uid://ck43v3q5ype3f" path="res://systems/inputs/menu_mode/back.tres" id="4_8i6b8"]
|
||||||
|
|
||||||
[sub_resource type="Animation" id="1"]
|
[sub_resource type="Animation" id="1"]
|
||||||
resource_name = "Intro"
|
resource_name = "Intro"
|
||||||
@@ -352,6 +354,8 @@ graph_offset = Vector2(-180.277, 49)
|
|||||||
script = ExtResource("2_nyjay")
|
script = ExtResource("2_nyjay")
|
||||||
level_select_packed_scene = null
|
level_select_packed_scene = null
|
||||||
game_scene_path = "uid://dmkw8cmalm5k"
|
game_scene_path = "uid://dmkw8cmalm5k"
|
||||||
|
menu_context = ExtResource("3_ytpwg")
|
||||||
|
back_action = ExtResource("4_8i6b8")
|
||||||
|
|
||||||
[node name="MenuAnimationPlayer" type="AnimationPlayer" parent="." index="1"]
|
[node name="MenuAnimationPlayer" type="AnimationPlayer" parent="." index="1"]
|
||||||
libraries = {
|
libraries = {
|
||||||
|
|||||||
@@ -33,20 +33,38 @@ alignment = 1
|
|||||||
|
|
||||||
[node name="LookSensitivityControl" parent="VBoxContainer/MarginContainer/VBoxContainer" instance=ExtResource("2_iyvrj")]
|
[node name="LookSensitivityControl" parent="VBoxContainer/MarginContainer/VBoxContainer" instance=ExtResource("2_iyvrj")]
|
||||||
layout_mode = 2
|
layout_mode = 2
|
||||||
option_name = "Look Sensitivity"
|
option_name = "Joystick Sensitivity"
|
||||||
option_section = 1
|
option_section = 1
|
||||||
key = "LookSensitivity"
|
key = "LookSensitivity"
|
||||||
section = "InputSettings"
|
section = "InputSettings"
|
||||||
|
|
||||||
[node name="OptionLabel" parent="VBoxContainer/MarginContainer/VBoxContainer/LookSensitivityControl" index="0"]
|
[node name="OptionLabel" parent="VBoxContainer/MarginContainer/VBoxContainer/LookSensitivityControl" index="0"]
|
||||||
text = "Look Sensitivity :"
|
text = "Joystick Sensitivity :"
|
||||||
|
|
||||||
[node name="HSlider" parent="VBoxContainer/MarginContainer/VBoxContainer/LookSensitivityControl" index="1"]
|
[node name="HSlider" parent="VBoxContainer/MarginContainer/VBoxContainer/LookSensitivityControl" index="1"]
|
||||||
min_value = 0.2
|
min_value = 0.2
|
||||||
max_value = 2.0
|
max_value = 2.0
|
||||||
step = 0.2
|
step = 0.2
|
||||||
|
value = 2.0
|
||||||
tick_count = 10
|
tick_count = 10
|
||||||
|
|
||||||
|
[node name="MouseSensitivityControl" parent="VBoxContainer/MarginContainer/VBoxContainer" instance=ExtResource("2_iyvrj")]
|
||||||
|
layout_mode = 2
|
||||||
|
option_name = "Mouse Sensitivity"
|
||||||
|
option_section = 1
|
||||||
|
key = "MouseSensitivity"
|
||||||
|
section = "InputSettings"
|
||||||
|
|
||||||
|
[node name="OptionLabel" parent="VBoxContainer/MarginContainer/VBoxContainer/MouseSensitivityControl" index="0"]
|
||||||
|
text = "Mouse Sensitivity :"
|
||||||
|
|
||||||
|
[node name="HSlider" parent="VBoxContainer/MarginContainer/VBoxContainer/MouseSensitivityControl" index="1"]
|
||||||
|
min_value = 1.0
|
||||||
|
max_value = 20.0
|
||||||
|
step = 1.0
|
||||||
|
value = 5.0
|
||||||
|
tick_count = 20
|
||||||
|
|
||||||
[node name="HeadBobbingControl" parent="VBoxContainer/MarginContainer/VBoxContainer" instance=ExtResource("2_iyvrj")]
|
[node name="HeadBobbingControl" parent="VBoxContainer/MarginContainer/VBoxContainer" instance=ExtResource("2_iyvrj")]
|
||||||
layout_mode = 2
|
layout_mode = 2
|
||||||
option_name = "Head Bobbing while walking"
|
option_name = "Head Bobbing while walking"
|
||||||
@@ -76,5 +94,6 @@ step = 0.1
|
|||||||
tick_count = 10
|
tick_count = 10
|
||||||
|
|
||||||
[editable path="VBoxContainer/MarginContainer/VBoxContainer/LookSensitivityControl"]
|
[editable path="VBoxContainer/MarginContainer/VBoxContainer/LookSensitivityControl"]
|
||||||
|
[editable path="VBoxContainer/MarginContainer/VBoxContainer/MouseSensitivityControl"]
|
||||||
[editable path="VBoxContainer/MarginContainer/VBoxContainer/HeadBobbingControl"]
|
[editable path="VBoxContainer/MarginContainer/VBoxContainer/HeadBobbingControl"]
|
||||||
[editable path="VBoxContainer/MarginContainer/VBoxContainer/FOVChangeControl"]
|
[editable path="VBoxContainer/MarginContainer/VBoxContainer/FOVChangeControl"]
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
[gd_scene load_steps=3 format=3 uid="uid://dim045la3mijk"]
|
[gd_scene load_steps=4 format=3 uid="uid://dim045la3mijk"]
|
||||||
|
|
||||||
[ext_resource type="PackedScene" uid="uid://cikf3o5omnunl" path="res://addons/maaacks_game_template/base/scenes/overlaid_menu/menus/mini_options_overlaid_menu.tscn" id="1_5piya"]
|
[ext_resource type="PackedScene" uid="uid://cikf3o5omnunl" path="res://addons/maaacks_game_template/base/scenes/overlaid_menu/menus/mini_options_overlaid_menu.tscn" id="1_5piya"]
|
||||||
[ext_resource type="PackedScene" uid="uid://foajscu2dqkk" path="res://menus/scenes/menus/options_menu/mini_options_menu_with_reset.tscn" id="2_3u5po"]
|
[ext_resource type="PackedScene" uid="uid://foajscu2dqkk" path="res://menus/scenes/menus/options_menu/mini_options_menu_with_reset.tscn" id="2_3u5po"]
|
||||||
|
[ext_resource type="Resource" uid="uid://ck43v3q5ype3f" path="res://systems/inputs/menu_mode/back.tres" id="3_i7tty"]
|
||||||
|
|
||||||
[node name="MiniOptionsOverlaidMenu" instance=ExtResource("1_5piya")]
|
[node name="MiniOptionsOverlaidMenu" instance=ExtResource("1_5piya")]
|
||||||
menu_scene = ExtResource("2_3u5po")
|
menu_scene = ExtResource("2_3u5po")
|
||||||
|
back_action = ExtResource("3_i7tty")
|
||||||
|
|||||||
@@ -1,15 +1,18 @@
|
|||||||
[gd_scene load_steps=5 format=3 uid="uid://ccqajqchiw4xu"]
|
[gd_scene load_steps=6 format=3 uid="uid://ccqajqchiw4xu"]
|
||||||
|
|
||||||
[ext_resource type="PackedScene" uid="uid://b5cd6sa8qq4vc" path="res://addons/maaacks_game_template/base/scenes/overlaid_menu/menus/pause_menu.tscn" id="1_0paax"]
|
[ext_resource type="PackedScene" uid="uid://b5cd6sa8qq4vc" path="res://addons/maaacks_game_template/base/scenes/overlaid_menu/menus/pause_menu.tscn" id="1_0paax"]
|
||||||
[ext_resource type="Script" uid="uid://bwvomv4eww4fg" path="res://menus/scenes/overlaid_menus/pause_menu.gd" id="2_ek1hy"]
|
[ext_resource type="Script" uid="uid://bwvomv4eww4fg" path="res://menus/scenes/overlaid_menus/pause_menu.gd" id="2_ek1hy"]
|
||||||
[ext_resource type="PackedScene" uid="uid://dim045la3mijk" path="res://menus/scenes/overlaid_menus/mini_options_overlaid_menu.tscn" id="3_e0t2r"]
|
[ext_resource type="PackedScene" uid="uid://dim045la3mijk" path="res://menus/scenes/overlaid_menus/mini_options_overlaid_menu.tscn" id="3_e0t2r"]
|
||||||
[ext_resource type="Resource" uid="uid://c2hpxkcujyc13" path="res://systems/inputs/menu_mode/menu_mode.tres" id="4_nfx08"]
|
[ext_resource type="Resource" uid="uid://c2hpxkcujyc13" path="res://systems/inputs/menu_mode/menu_mode.tres" id="4_nfx08"]
|
||||||
|
[ext_resource type="Resource" uid="uid://ck43v3q5ype3f" path="res://systems/inputs/menu_mode/back.tres" id="5_su1bt"]
|
||||||
|
|
||||||
[node name="PauseMenu" instance=ExtResource("1_0paax")]
|
[node name="PauseMenu" instance=ExtResource("1_0paax")]
|
||||||
|
top_level = true
|
||||||
script = ExtResource("2_ek1hy")
|
script = ExtResource("2_ek1hy")
|
||||||
options_packed_scene = ExtResource("3_e0t2r")
|
options_packed_scene = ExtResource("3_e0t2r")
|
||||||
main_menu_scene = "res://menus/scenes/menus/main_menu/main_menu_with_animations.tscn"
|
main_menu_scene = "res://menus/scenes/menus/main_menu/main_menu_with_animations.tscn"
|
||||||
menu_context = ExtResource("4_nfx08")
|
menu_context = ExtResource("4_nfx08")
|
||||||
|
back_action = ExtResource("5_su1bt")
|
||||||
|
|
||||||
[connection signal="tree_entered" from="." to="." method="on_enter_tree"]
|
[connection signal="tree_entered" from="." to="." method="on_enter_tree"]
|
||||||
[connection signal="tree_exited" from="." to="." method="on_exit_tree"]
|
[connection signal="tree_exited" from="." to="." method="on_exit_tree"]
|
||||||
|
|||||||
@@ -20,7 +20,6 @@ static func get_level_state(level_state_key : String) -> LevelState:
|
|||||||
return new_level_state
|
return new_level_state
|
||||||
|
|
||||||
static func has_game_state() -> bool:
|
static func has_game_state() -> bool:
|
||||||
return false
|
|
||||||
return GlobalState.has_state(STATE_NAME)
|
return GlobalState.has_state(STATE_NAME)
|
||||||
|
|
||||||
static func get_game_state() -> GameState:
|
static func get_game_state() -> GameState:
|
||||||
|
|||||||
@@ -1,12 +1,14 @@
|
|||||||
[gd_scene load_steps=45 format=3 uid="uid://bei4nhkf8lwdo"]
|
[gd_scene load_steps=47 format=3 uid="uid://bei4nhkf8lwdo"]
|
||||||
|
|
||||||
[ext_resource type="Script" uid="uid://bbbrf5ckydfna" path="res://player_controller/Scripts/PlayerController.cs" id="1_poq2x"]
|
[ext_resource type="Script" uid="uid://bbbrf5ckydfna" path="res://player_controller/Scripts/PlayerController.cs" id="1_poq2x"]
|
||||||
[ext_resource type="Resource" uid="uid://bl5crtu1gkrtr" path="res://systems/inputs/base_mode/base_mode.tres" id="3_cresl"]
|
[ext_resource type="Resource" uid="uid://bl5crtu1gkrtr" path="res://systems/inputs/base_mode/base_mode.tres" id="3_cresl"]
|
||||||
[ext_resource type="Resource" uid="uid://cpdaw41ah5gic" path="res://systems/inputs/base_mode/rotate_y.tres" id="4_rxwoh"]
|
[ext_resource type="Resource" uid="uid://cpdaw41ah5gic" path="res://systems/inputs/base_mode/rotate_y.tres" id="4_rxwoh"]
|
||||||
[ext_resource type="Resource" uid="uid://ccrb5xsnphc8" path="res://systems/inputs/base_mode/rotate_floorplane.tres" id="5_4u7i3"]
|
[ext_resource type="Resource" uid="uid://ccrb5xsnphc8" path="res://systems/inputs/base_mode/rotate_floorplane.tres" id="5_4u7i3"]
|
||||||
[ext_resource type="Script" uid="uid://dv7v1ywmbvvcd" path="res://player_controller/Scripts/HealthSystem.cs" id="5_umw0l"]
|
[ext_resource type="Resource" uid="uid://f3vs6l4m623s" path="res://systems/inputs/base_mode/move_left.tres" id="5_q14ux"]
|
||||||
[ext_resource type="Script" uid="uid://vuq8rjq3vegn" path="res://player_controller/Scripts/Stamina.cs" id="6_lxtc4"]
|
[ext_resource type="Resource" uid="uid://t612lts1wi1s" path="res://systems/inputs/base_mode/move_right.tres" id="6_q7bng"]
|
||||||
[ext_resource type="Script" uid="uid://cwbvxlfvmocc1" path="res://player_controller/Scripts/StairsSystem.cs" id="7_bmt5a"]
|
[ext_resource type="Script" uid="uid://cwbvxlfvmocc1" path="res://player_controller/Scripts/StairsSystem.cs" id="7_bmt5a"]
|
||||||
|
[ext_resource type="Resource" uid="uid://brswsknpgwal2" path="res://systems/inputs/base_mode/move_front.tres" id="7_m8gvy"]
|
||||||
|
[ext_resource type="Resource" uid="uid://s1l0n1iitc6m" path="res://systems/inputs/base_mode/move_back.tres" id="8_jb43f"]
|
||||||
[ext_resource type="Resource" uid="uid://j1o5ud0plk4" path="res://systems/inputs/base_mode/aim_release.tres" id="8_lhb11"]
|
[ext_resource type="Resource" uid="uid://j1o5ud0plk4" path="res://systems/inputs/base_mode/aim_release.tres" id="8_lhb11"]
|
||||||
[ext_resource type="Script" uid="uid://dd1yrt7eiiyf4" path="res://player_controller/Scripts/CapsuleCollider.cs" id="8_lmtjd"]
|
[ext_resource type="Script" uid="uid://dd1yrt7eiiyf4" path="res://player_controller/Scripts/CapsuleCollider.cs" id="8_lmtjd"]
|
||||||
[ext_resource type="Resource" uid="uid://c3e0ivgaxrsyb" path="res://systems/inputs/base_mode/aim_down.tres" id="8_obsfv"]
|
[ext_resource type="Resource" uid="uid://c3e0ivgaxrsyb" path="res://systems/inputs/base_mode/aim_down.tres" id="8_obsfv"]
|
||||||
@@ -82,11 +84,23 @@ PostDashSpeed = 30.0
|
|||||||
WallHugGravityLesseningFactor = 15.0
|
WallHugGravityLesseningFactor = 15.0
|
||||||
WallHugDownwardMaxSpeed = 8.0
|
WallHugDownwardMaxSpeed = 8.0
|
||||||
WallHugHorizontalDeceleration = 0.5
|
WallHugHorizontalDeceleration = 0.5
|
||||||
|
WallRunAltitudeLossSpeed = 12.0
|
||||||
|
WallRunSpeedThreshold = 5.0
|
||||||
|
|
||||||
|
[node name="WallRunSnapper" type="RayCast3D" parent="."]
|
||||||
|
unique_name_in_owner = true
|
||||||
|
transform = Transform3D(0.99999994, 0, 0, 0, 1, 0, 0, 0, 0.99999994, 0, 0, 0)
|
||||||
|
target_position = Vector3(0, 0, -5)
|
||||||
|
collision_mask = 2
|
||||||
|
|
||||||
[node name="InputController" type="Node3D" parent="."]
|
[node name="InputController" type="Node3D" parent="."]
|
||||||
script = ExtResource("16_v31n3")
|
script = ExtResource("16_v31n3")
|
||||||
base_mode = ExtResource("3_cresl")
|
base_mode = ExtResource("3_cresl")
|
||||||
move = ExtResource("17_h6vvl")
|
move = ExtResource("17_h6vvl")
|
||||||
|
move_left = ExtResource("5_q14ux")
|
||||||
|
move_right = ExtResource("6_q7bng")
|
||||||
|
move_front = ExtResource("7_m8gvy")
|
||||||
|
move_back = ExtResource("8_jb43f")
|
||||||
rotate_y = ExtResource("4_rxwoh")
|
rotate_y = ExtResource("4_rxwoh")
|
||||||
rotate_floorplane = ExtResource("5_4u7i3")
|
rotate_floorplane = ExtResource("5_4u7i3")
|
||||||
aim_down = ExtResource("8_obsfv")
|
aim_down = ExtResource("8_obsfv")
|
||||||
@@ -116,12 +130,6 @@ CapsuleDefaultHeight = 1.7
|
|||||||
[node name="HeadSystem" parent="." instance=ExtResource("11_rxwoh")]
|
[node name="HeadSystem" parent="." instance=ExtResource("11_rxwoh")]
|
||||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1.6, 0)
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1.6, 0)
|
||||||
|
|
||||||
[node name="HealthSystem" type="Node3D" parent="."]
|
|
||||||
script = ExtResource("5_umw0l")
|
|
||||||
|
|
||||||
[node name="Stamina" type="Node3D" parent="."]
|
|
||||||
script = ExtResource("6_lxtc4")
|
|
||||||
|
|
||||||
[node name="StairsSystem" type="Node3D" parent="."]
|
[node name="StairsSystem" type="Node3D" parent="."]
|
||||||
script = ExtResource("7_bmt5a")
|
script = ExtResource("7_bmt5a")
|
||||||
|
|
||||||
@@ -163,25 +171,44 @@ target_position = Vector3(0, 1, 0)
|
|||||||
[node name="TweenQueueSystem" parent="." instance=ExtResource("22_rpwev")]
|
[node name="TweenQueueSystem" parent="." instance=ExtResource("22_rpwev")]
|
||||||
|
|
||||||
[node name="WallHugSystem" type="Node3D" parent="."]
|
[node name="WallHugSystem" type="Node3D" parent="."]
|
||||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0)
|
|
||||||
script = ExtResource("27_n7qhm")
|
script = ExtResource("27_n7qhm")
|
||||||
|
|
||||||
[node name="back" type="RayCast3D" parent="WallHugSystem"]
|
[node name="back" type="RayCast3D" parent="WallHugSystem"]
|
||||||
target_position = Vector3(0, 0, 1)
|
target_position = Vector3(0, 0, 1)
|
||||||
collision_mask = 2
|
collision_mask = 2
|
||||||
|
|
||||||
|
[node name="back2" type="RayCast3D" parent="WallHugSystem"]
|
||||||
|
transform = Transform3D(0.70710677, 0, 0.70710677, 0, 1, 0, -0.70710677, 0, 0.70710677, 0, 0, 0)
|
||||||
|
target_position = Vector3(0, 0, 1)
|
||||||
|
collision_mask = 2
|
||||||
|
|
||||||
[node name="front" type="RayCast3D" parent="WallHugSystem"]
|
[node name="front" type="RayCast3D" parent="WallHugSystem"]
|
||||||
target_position = Vector3(0, 0, -1)
|
target_position = Vector3(0, 0, -1)
|
||||||
collision_mask = 2
|
collision_mask = 2
|
||||||
|
|
||||||
|
[node name="front2" type="RayCast3D" parent="WallHugSystem"]
|
||||||
|
transform = Transform3D(0.70710677, 0, 0.70710677, 0, 1, 0, -0.70710677, 0, 0.70710677, 0, 0, 0)
|
||||||
|
target_position = Vector3(0, 0, -1)
|
||||||
|
collision_mask = 2
|
||||||
|
|
||||||
[node name="right" type="RayCast3D" parent="WallHugSystem"]
|
[node name="right" type="RayCast3D" parent="WallHugSystem"]
|
||||||
target_position = Vector3(1, 0, 0)
|
target_position = Vector3(1, 0, 0)
|
||||||
collision_mask = 2
|
collision_mask = 2
|
||||||
|
|
||||||
|
[node name="right2" type="RayCast3D" parent="WallHugSystem"]
|
||||||
|
transform = Transform3D(0.70710677, 0, 0.70710677, 0, 1, 0, -0.70710677, 0, 0.70710677, 0, 0, 0)
|
||||||
|
target_position = Vector3(1, 0, 0)
|
||||||
|
collision_mask = 2
|
||||||
|
|
||||||
[node name="left" type="RayCast3D" parent="WallHugSystem"]
|
[node name="left" type="RayCast3D" parent="WallHugSystem"]
|
||||||
target_position = Vector3(-1, 0, 0)
|
target_position = Vector3(-1, 0, 0)
|
||||||
collision_mask = 2
|
collision_mask = 2
|
||||||
|
|
||||||
|
[node name="left2" type="RayCast3D" parent="WallHugSystem"]
|
||||||
|
transform = Transform3D(0.70710677, 0, 0.70710677, 0, 1, 0, -0.70710677, 0, 0.70710677, 0, 0, 0)
|
||||||
|
target_position = Vector3(-1, 0, 0)
|
||||||
|
collision_mask = 2
|
||||||
|
|
||||||
[node name="DashSystem" parent="." instance=ExtResource("18_q5h8a")]
|
[node name="DashSystem" parent="." instance=ExtResource("18_q5h8a")]
|
||||||
DashSpeed = 0.2
|
DashSpeed = 0.2
|
||||||
PostDashSpeed = 30.0
|
PostDashSpeed = 30.0
|
||||||
@@ -221,15 +248,24 @@ offset_bottom = 1.0
|
|||||||
enabled = false
|
enabled = false
|
||||||
initial_node_to_watch = NodePath("../StateChart")
|
initial_node_to_watch = NodePath("../StateChart")
|
||||||
|
|
||||||
[node name="UI" type="CanvasLayer" parent="."]
|
[node name="UI" type="Control" parent="."]
|
||||||
script = ExtResource("30_2ghaa")
|
layout_mode = 3
|
||||||
|
|
||||||
[node name="MarginContainer" type="MarginContainer" parent="UI"]
|
|
||||||
anchors_preset = 15
|
anchors_preset = 15
|
||||||
anchor_right = 1.0
|
anchor_right = 1.0
|
||||||
anchor_bottom = 1.0
|
anchor_bottom = 1.0
|
||||||
grow_horizontal = 2
|
grow_horizontal = 2
|
||||||
grow_vertical = 2
|
grow_vertical = 2
|
||||||
|
mouse_filter = 1
|
||||||
|
script = ExtResource("30_2ghaa")
|
||||||
|
|
||||||
|
[node name="MarginContainer" type="MarginContainer" parent="UI"]
|
||||||
|
layout_mode = 1
|
||||||
|
anchors_preset = 15
|
||||||
|
anchor_right = 1.0
|
||||||
|
anchor_bottom = 1.0
|
||||||
|
grow_horizontal = 2
|
||||||
|
grow_vertical = 2
|
||||||
|
mouse_filter = 2
|
||||||
theme_override_constants/margin_left = 50
|
theme_override_constants/margin_left = 50
|
||||||
theme_override_constants/margin_top = 50
|
theme_override_constants/margin_top = 50
|
||||||
theme_override_constants/margin_right = 50
|
theme_override_constants/margin_right = 50
|
||||||
@@ -268,12 +304,14 @@ expand_mode = 2
|
|||||||
|
|
||||||
[node name="CenterContainer" type="CenterContainer" parent="UI"]
|
[node name="CenterContainer" type="CenterContainer" parent="UI"]
|
||||||
custom_minimum_size = Vector2(1920, 1080)
|
custom_minimum_size = Vector2(1920, 1080)
|
||||||
|
layout_mode = 1
|
||||||
anchors_preset = 15
|
anchors_preset = 15
|
||||||
anchor_right = 1.0
|
anchor_right = 1.0
|
||||||
anchor_bottom = 1.0
|
anchor_bottom = 1.0
|
||||||
offset_right = -1.0
|
offset_right = -1.0
|
||||||
grow_horizontal = 2
|
grow_horizontal = 2
|
||||||
grow_vertical = 2
|
grow_vertical = 2
|
||||||
|
mouse_filter = 2
|
||||||
|
|
||||||
[node name="CenterIcon" type="TextureRect" parent="UI/CenterContainer"]
|
[node name="CenterIcon" type="TextureRect" parent="UI/CenterContainer"]
|
||||||
material = SubResource("CanvasItemMaterial_2q0ik")
|
material = SubResource("CanvasItemMaterial_2q0ik")
|
||||||
@@ -283,11 +321,13 @@ texture = ExtResource("32_lgpc8")
|
|||||||
expand_mode = 1
|
expand_mode = 1
|
||||||
|
|
||||||
[node name="CenterContainer2" type="CenterContainer" parent="UI"]
|
[node name="CenterContainer2" type="CenterContainer" parent="UI"]
|
||||||
|
layout_mode = 1
|
||||||
anchors_preset = 15
|
anchors_preset = 15
|
||||||
anchor_right = 1.0
|
anchor_right = 1.0
|
||||||
anchor_bottom = 1.0
|
anchor_bottom = 1.0
|
||||||
grow_horizontal = 2
|
grow_horizontal = 2
|
||||||
grow_vertical = 2
|
grow_vertical = 2
|
||||||
|
mouse_filter = 2
|
||||||
|
|
||||||
[node name="MarginContainer" type="MarginContainer" parent="UI/CenterContainer2"]
|
[node name="MarginContainer" type="MarginContainer" parent="UI/CenterContainer2"]
|
||||||
layout_mode = 2
|
layout_mode = 2
|
||||||
@@ -566,6 +606,12 @@ to = NodePath("../../OnWall/Hugging")
|
|||||||
event = &"wall_hug"
|
event = &"wall_hug"
|
||||||
delay_in_seconds = "0.0"
|
delay_in_seconds = "0.0"
|
||||||
|
|
||||||
|
[node name="OnWallRun" type="Node" parent="StateChart/Root/Movement/Airborne"]
|
||||||
|
script = ExtResource("28_n7qhm")
|
||||||
|
to = NodePath("../../OnWall/Running")
|
||||||
|
event = &"wall_run"
|
||||||
|
delay_in_seconds = "0.0"
|
||||||
|
|
||||||
[node name="OnDash" type="Node" parent="StateChart/Root/Movement/Airborne"]
|
[node name="OnDash" type="Node" parent="StateChart/Root/Movement/Airborne"]
|
||||||
script = ExtResource("28_n7qhm")
|
script = ExtResource("28_n7qhm")
|
||||||
to = NodePath("../../Dashing/Dash")
|
to = NodePath("../../Dashing/Dash")
|
||||||
@@ -651,50 +697,27 @@ to = NodePath("../../Jump/MegaJump")
|
|||||||
event = &"megajump"
|
event = &"megajump"
|
||||||
delay_in_seconds = "0.0"
|
delay_in_seconds = "0.0"
|
||||||
|
|
||||||
[node name="HugCanceled" type="Node" parent="StateChart/Root/Movement/OnWall"]
|
[node name="OnLeaveWall" type="Node" parent="StateChart/Root/Movement/OnWall"]
|
||||||
script = ExtResource("27_34snm")
|
|
||||||
|
|
||||||
[node name="ToHanging" type="Node" parent="StateChart/Root/Movement/OnWall/HugCanceled"]
|
|
||||||
script = ExtResource("28_n7qhm")
|
script = ExtResource("28_n7qhm")
|
||||||
to = NodePath("../../Hanging")
|
to = NodePath("../../Airborne/Reset")
|
||||||
event = &"oh_hit_wall"
|
event = &"start_falling"
|
||||||
delay_in_seconds = "0.0"
|
delay_in_seconds = "0.0"
|
||||||
|
|
||||||
[node name="Hugging" type="Node" parent="StateChart/Root/Movement/OnWall"]
|
[node name="Hugging" type="Node" parent="StateChart/Root/Movement/OnWall"]
|
||||||
script = ExtResource("27_34snm")
|
script = ExtResource("27_34snm")
|
||||||
|
|
||||||
[node name="OnGrounded" type="Node" parent="StateChart/Root/Movement/OnWall/Hugging"]
|
|
||||||
script = ExtResource("28_n7qhm")
|
|
||||||
to = NodePath("../../../Grounded")
|
|
||||||
event = &"grounded"
|
|
||||||
delay_in_seconds = "0.0"
|
|
||||||
|
|
||||||
[node name="OnLeaveWall" type="Node" parent="StateChart/Root/Movement/OnWall/Hugging"]
|
|
||||||
script = ExtResource("28_n7qhm")
|
|
||||||
to = NodePath("../../../Airborne/CoyoteEnabled")
|
|
||||||
event = &"start_falling"
|
|
||||||
delay_in_seconds = "0.0"
|
|
||||||
|
|
||||||
[node name="OnDrop" type="Node" parent="StateChart/Root/Movement/OnWall/Hugging"]
|
|
||||||
script = ExtResource("28_n7qhm")
|
|
||||||
to = NodePath("../../HugCanceled")
|
|
||||||
event = &"__unused_dash"
|
|
||||||
delay_in_seconds = "0.0"
|
|
||||||
|
|
||||||
[node name="Hanging" type="Node" parent="StateChart/Root/Movement/OnWall"]
|
[node name="Hanging" type="Node" parent="StateChart/Root/Movement/OnWall"]
|
||||||
script = ExtResource("27_34snm")
|
script = ExtResource("27_34snm")
|
||||||
|
|
||||||
[node name="OnDrop" type="Node" parent="StateChart/Root/Movement/OnWall/Hanging"]
|
[node name="Running" type="Node" parent="StateChart/Root/Movement/OnWall"]
|
||||||
script = ExtResource("28_n7qhm")
|
script = ExtResource("27_34snm")
|
||||||
to = NodePath("../../Hugging")
|
|
||||||
event = &"dash"
|
|
||||||
delay_in_seconds = "0.0"
|
|
||||||
|
|
||||||
[connection signal="input_aim_canceled" from="InputController" to="." method="OnInputAimCanceled"]
|
[connection signal="input_aim_canceled" from="InputController" to="." method="OnInputAimCanceled"]
|
||||||
[connection signal="input_aim_down" from="InputController" to="." method="OnInputAimDown"]
|
[connection signal="input_aim_down" from="InputController" to="." method="OnInputAimDown"]
|
||||||
[connection signal="input_aim_pressed" from="InputController" to="." method="OnInputAimPressed"]
|
[connection signal="input_aim_pressed" from="InputController" to="." method="OnInputAimPressed"]
|
||||||
[connection signal="input_aim_released" from="InputController" to="." method="OnInputAimReleased"]
|
[connection signal="input_aim_released" from="InputController" to="." method="OnInputAimReleased"]
|
||||||
[connection signal="input_dash" from="InputController" to="." method="OnInputDashPressed"]
|
[connection signal="input_dash" from="InputController" to="." method="OnInputDashPressed"]
|
||||||
|
[connection signal="input_device_changed" from="InputController" to="." method="InputDeviceChanged"]
|
||||||
[connection signal="input_empower_down" from="InputController" to="." method="OnInputEmpowerDown"]
|
[connection signal="input_empower_down" from="InputController" to="." method="OnInputEmpowerDown"]
|
||||||
[connection signal="input_empower_released" from="InputController" to="." method="OnInputEmpowerReleased"]
|
[connection signal="input_empower_released" from="InputController" to="." method="OnInputEmpowerReleased"]
|
||||||
[connection signal="input_hit" from="InputController" to="." method="OnInputHitPressed"]
|
[connection signal="input_hit" from="InputController" to="." method="OnInputHitPressed"]
|
||||||
@@ -702,6 +725,7 @@ delay_in_seconds = "0.0"
|
|||||||
[connection signal="input_jump_ongoing" from="InputController" to="." method="OnInputJumpOngoing"]
|
[connection signal="input_jump_ongoing" from="InputController" to="." method="OnInputJumpOngoing"]
|
||||||
[connection signal="input_jump_started" from="InputController" to="." method="OnInputJumpStarted"]
|
[connection signal="input_jump_started" from="InputController" to="." method="OnInputJumpStarted"]
|
||||||
[connection signal="input_move" from="InputController" to="." method="OnInputMove"]
|
[connection signal="input_move" from="InputController" to="." method="OnInputMove"]
|
||||||
|
[connection signal="input_move_keyboard" from="InputController" to="." method="OnInputMoveKeyboard"]
|
||||||
[connection signal="input_rotate_floorplane" from="InputController" to="." method="OnInputRotateFloorplane"]
|
[connection signal="input_rotate_floorplane" from="InputController" to="." method="OnInputRotateFloorplane"]
|
||||||
[connection signal="input_rotate_y" from="InputController" to="." method="OnInputRotateY"]
|
[connection signal="input_rotate_y" from="InputController" to="." method="OnInputRotateY"]
|
||||||
[connection signal="input_throw" from="InputController" to="." method="OnInputThrowPressed"]
|
[connection signal="input_throw" from="InputController" to="." method="OnInputThrowPressed"]
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
using Godot;
|
using Godot;
|
||||||
using System;
|
using System;
|
||||||
|
|
||||||
public partial class PlayerUi : CanvasLayer
|
public partial class PlayerUi : Control
|
||||||
{
|
{
|
||||||
private TextureRect[] _dashIcons = new TextureRect[3];
|
private TextureRect[] _dashIcons = new TextureRect[3];
|
||||||
|
|
||||||
|
|||||||
@@ -146,9 +146,6 @@ public partial class HealthSystem : Node3D
|
|||||||
public CharacterBody3D Parent;
|
public CharacterBody3D Parent;
|
||||||
public Camera3D Camera;
|
public Camera3D Camera;
|
||||||
public Node3D Head;
|
public Node3D Head;
|
||||||
public ColorRect VignetteRect;
|
|
||||||
public ColorRect DistortionRect;
|
|
||||||
public ColorRect BlurRect;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Init(HealthSystemInitParams initParams)
|
public void Init(HealthSystemInitParams initParams)
|
||||||
@@ -162,10 +159,6 @@ public partial class HealthSystem : Node3D
|
|||||||
_camera = initParams.Camera;
|
_camera = initParams.Camera;
|
||||||
|
|
||||||
_head = initParams.Head;
|
_head = initParams.Head;
|
||||||
|
|
||||||
_vignetteMaterial = initParams.VignetteRect.Material as ShaderMaterial;
|
|
||||||
_distortionMaterial = initParams.DistortionRect.Material as ShaderMaterial;
|
|
||||||
_blurMaterial = initParams.BlurRect.Material as ShaderMaterial;
|
|
||||||
|
|
||||||
// Resetting shaders' parameters
|
// Resetting shaders' parameters
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
using System;
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
using Godot;
|
using Godot;
|
||||||
using GodotStateCharts;
|
using GodotStateCharts;
|
||||||
using Movementtests.addons.godot_state_charts.csharp;
|
using Movementtests.addons.godot_state_charts.csharp;
|
||||||
@@ -14,17 +15,16 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
MoveCamera,
|
MoveCamera,
|
||||||
None,
|
None,
|
||||||
}
|
}
|
||||||
|
private bool _isUsingGamepad = false;
|
||||||
|
|
||||||
// User API to important child nodes.
|
// User API to important child nodes.
|
||||||
public HeadSystem HeadSystem;
|
public HeadSystem HeadSystem;
|
||||||
public Bobbing Bobbing;
|
public Bobbing Bobbing;
|
||||||
public FieldOfView FieldOfView;
|
public FieldOfView FieldOfView;
|
||||||
public Stamina Stamina;
|
|
||||||
public StairsSystem StairsSystem;
|
public StairsSystem StairsSystem;
|
||||||
public MantleSystem MantleSystem;
|
public MantleSystem MantleSystem;
|
||||||
public DashSystem DashSystem;
|
public DashSystem DashSystem;
|
||||||
public CapsuleCollider CapsuleCollider;
|
public CapsuleCollider CapsuleCollider;
|
||||||
public HealthSystem HealthSystem;
|
|
||||||
public TweenQueueSystem TweenQueueSystem;
|
public TweenQueueSystem TweenQueueSystem;
|
||||||
public Node3D WeaponRoot;
|
public Node3D WeaponRoot;
|
||||||
public WeaponSystem WeaponSystem;
|
public WeaponSystem WeaponSystem;
|
||||||
@@ -35,6 +35,7 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
public Node3D DashIndicatorNode;
|
public Node3D DashIndicatorNode;
|
||||||
public MeshInstance3D DashIndicatorMesh;
|
public MeshInstance3D DashIndicatorMesh;
|
||||||
public CylinderMesh DashIndicatorMeshCylinder;
|
public CylinderMesh DashIndicatorMeshCylinder;
|
||||||
|
public RayCast3D WallRunSnapper;
|
||||||
|
|
||||||
private bool _movementEnabled = true;
|
private bool _movementEnabled = true;
|
||||||
|
|
||||||
@@ -48,6 +49,7 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
private RayCast3D[] _headCollisionDetectors;
|
private RayCast3D[] _headCollisionDetectors;
|
||||||
|
|
||||||
private Vector3 _inputMove = Vector3.Zero;
|
private Vector3 _inputMove = Vector3.Zero;
|
||||||
|
private Vector3 _inputMoveKeyboard = Vector3.Zero;
|
||||||
private float _inputRotateY;
|
private float _inputRotateY;
|
||||||
private float _inputRotateFloorplane;
|
private float _inputRotateFloorplane;
|
||||||
|
|
||||||
@@ -59,6 +61,7 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
private Timer _powerCooldownTimer;
|
private Timer _powerCooldownTimer;
|
||||||
|
|
||||||
[Export] public Marker3D TutorialWeaponTarget;
|
[Export] public Marker3D TutorialWeaponTarget;
|
||||||
|
[Export] public bool TutorialDone { get; set; }
|
||||||
|
|
||||||
[ExportCategory("Movement")]
|
[ExportCategory("Movement")]
|
||||||
[ExportGroup("Ground")]
|
[ExportGroup("Ground")]
|
||||||
@@ -152,6 +155,16 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
[Export(PropertyHint.Range, "0.1,10,0.1,or_greater")]
|
[Export(PropertyHint.Range, "0.1,10,0.1,or_greater")]
|
||||||
public float WallHugHorizontalDeceleration { get; set; } = 5f;
|
public float WallHugHorizontalDeceleration { get; set; } = 5f;
|
||||||
|
|
||||||
|
// Wall run
|
||||||
|
[ExportGroup("Wall run")]
|
||||||
|
[Export(PropertyHint.Range, "1,20,0.1,or_greater")]
|
||||||
|
public float WallRunUpwardVelocity { get; set; } = 10f;
|
||||||
|
[Export(PropertyHint.Range, "1,20,0.1,or_greater")]
|
||||||
|
public float WallRunAltitudeLossSpeed { get; set; } = 10f;
|
||||||
|
|
||||||
|
[Export(PropertyHint.Range, "1,20,0.1,or_greater")]
|
||||||
|
public float WallRunSpeedThreshold { get; set; } = 8f;
|
||||||
|
|
||||||
private float _targetSpeed;
|
private float _targetSpeed;
|
||||||
private float _gravity;
|
private float _gravity;
|
||||||
|
|
||||||
@@ -165,7 +178,6 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
PlayerUi.SetNumberOfDashesLeft(value);
|
PlayerUi.SetNumberOfDashesLeft(value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
public bool TutorialDone { get; set; }
|
|
||||||
|
|
||||||
public AllowedInputs CurrentlyAllowedInputs { get; set; } = AllowedInputs.All;
|
public AllowedInputs CurrentlyAllowedInputs { get; set; } = AllowedInputs.All;
|
||||||
|
|
||||||
@@ -191,9 +203,10 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
private StateChartState _simpleDash;
|
private StateChartState _simpleDash;
|
||||||
private StateChartState _poweredDash;
|
private StateChartState _poweredDash;
|
||||||
private StateChartState _aimedDash;
|
private StateChartState _aimedDash;
|
||||||
private StateChartState _onWallHugCanceled;
|
private StateChartState _onWall;
|
||||||
private StateChartState _onWallHugging;
|
private StateChartState _onWallHugging;
|
||||||
private StateChartState _onWallHanging;
|
private StateChartState _onWallHanging;
|
||||||
|
private StateChartState _onWallRunning;
|
||||||
|
|
||||||
private Transition _onJumpFromWall;
|
private Transition _onJumpFromWall;
|
||||||
private Transition _onMegajumpFromWall;
|
private Transition _onMegajumpFromWall;
|
||||||
@@ -202,6 +215,7 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
private float _playerRadius;
|
private float _playerRadius;
|
||||||
|
|
||||||
private float _lookSensitivityMultiplier = 1.0f;
|
private float _lookSensitivityMultiplier = 1.0f;
|
||||||
|
private float _mouseSensitivityMultiplier = 1.0f;
|
||||||
private float _headBobbingMultiplier = 1.0f;
|
private float _headBobbingMultiplier = 1.0f;
|
||||||
private float _fovChangeMultiplier = 1.0f;
|
private float _fovChangeMultiplier = 1.0f;
|
||||||
|
|
||||||
@@ -234,11 +248,6 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
FieldOfView = GetNode<FieldOfView>("FieldOfView");
|
FieldOfView = GetNode<FieldOfView>("FieldOfView");
|
||||||
Camera3D camera = GetNode<Camera3D>("HeadSystem/CameraSmooth/Camera3D");
|
Camera3D camera = GetNode<Camera3D>("HeadSystem/CameraSmooth/Camera3D");
|
||||||
Node3D cameraSmooth = GetNode<Node3D>("HeadSystem/CameraSmooth");
|
Node3D cameraSmooth = GetNode<Node3D>("HeadSystem/CameraSmooth");
|
||||||
ColorRect vignetteRect = GetNode<ColorRect>(
|
|
||||||
"HeadSystem/CameraSmooth/Camera3D/CLVignette(Layer_1)/HealthVignetteRect");
|
|
||||||
ColorRect distortionRect = GetNode<ColorRect>(
|
|
||||||
"HeadSystem/CameraSmooth/Camera3D/CLDistortion(Layer_2)/HealthDistortionRect");
|
|
||||||
ColorRect blurRect = GetNode<ColorRect>("HeadSystem/CameraSmooth/Camera3D/CLBlur(Layer_2)/BlurRect");
|
|
||||||
|
|
||||||
// Movement stuff
|
// Movement stuff
|
||||||
WeaponRoot = GetNode<Node3D>("WeaponRoot");
|
WeaponRoot = GetNode<Node3D>("WeaponRoot");
|
||||||
@@ -248,6 +257,7 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
DashSystem = GetNode<DashSystem>("DashSystem");
|
DashSystem = GetNode<DashSystem>("DashSystem");
|
||||||
StairsSystem = GetNode<StairsSystem>("StairsSystem");
|
StairsSystem = GetNode<StairsSystem>("StairsSystem");
|
||||||
WallHugSystem = GetNode<WallHugSystem>("WallHugSystem");
|
WallHugSystem = GetNode<WallHugSystem>("WallHugSystem");
|
||||||
|
WallRunSnapper = GetNode<RayCast3D>("%WallRunSnapper");
|
||||||
RayCast3D stairsBelowRayCast3D = GetNode<RayCast3D>("StairsBelowRayCast3D");
|
RayCast3D stairsBelowRayCast3D = GetNode<RayCast3D>("StairsBelowRayCast3D");
|
||||||
RayCast3D stairsAheadRayCast3D = GetNode<RayCast3D>("StairsAheadRayCast3D");
|
RayCast3D stairsAheadRayCast3D = GetNode<RayCast3D>("StairsAheadRayCast3D");
|
||||||
_headCollisionDetectors = new RayCast3D[NUM_OF_HEAD_COLLISION_DETECTORS];
|
_headCollisionDetectors = new RayCast3D[NUM_OF_HEAD_COLLISION_DETECTORS];
|
||||||
@@ -261,11 +271,7 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
_playerHeight = playerShape!.Height;
|
_playerHeight = playerShape!.Height;
|
||||||
_playerRadius = playerShape.Radius;
|
_playerRadius = playerShape.Radius;
|
||||||
|
|
||||||
// RPG Stuff
|
// State managementb
|
||||||
Stamina = GetNode<Stamina>("Stamina");
|
|
||||||
HealthSystem = GetNode<HealthSystem>("HealthSystem");
|
|
||||||
|
|
||||||
// State management
|
|
||||||
_playerState = StateChart.Of(GetNode("StateChart"));
|
_playerState = StateChart.Of(GetNode("StateChart"));
|
||||||
|
|
||||||
_aiming = StateChartState.Of(GetNode("StateChart/Root/Aim/On"));
|
_aiming = StateChartState.Of(GetNode("StateChart/Root/Aim/On"));
|
||||||
@@ -286,9 +292,10 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
_megaJump = StateChartState.Of(GetNode("StateChart/Root/Movement/Jump/MegaJump"));
|
_megaJump = StateChartState.Of(GetNode("StateChart/Root/Movement/Jump/MegaJump"));
|
||||||
_onJumpFromWall = Transition.Of(GetNode("StateChart/Root/Movement/OnWall/OnJump"));
|
_onJumpFromWall = Transition.Of(GetNode("StateChart/Root/Movement/OnWall/OnJump"));
|
||||||
_onMegajumpFromWall = Transition.Of(GetNode("StateChart/Root/Movement/OnWall/OnMegajump"));
|
_onMegajumpFromWall = Transition.Of(GetNode("StateChart/Root/Movement/OnWall/OnMegajump"));
|
||||||
|
_onWall = StateChartState.Of(GetNode("StateChart/Root/Movement/OnWall"));
|
||||||
_onWallHugging = StateChartState.Of(GetNode("StateChart/Root/Movement/OnWall/Hugging"));
|
_onWallHugging = StateChartState.Of(GetNode("StateChart/Root/Movement/OnWall/Hugging"));
|
||||||
_onWallHugCanceled = StateChartState.Of(GetNode("StateChart/Root/Movement/OnWall/HugCanceled"));
|
|
||||||
_onWallHanging = StateChartState.Of(GetNode("StateChart/Root/Movement/OnWall/Hanging"));
|
_onWallHanging = StateChartState.Of(GetNode("StateChart/Root/Movement/OnWall/Hanging"));
|
||||||
|
_onWallRunning = StateChartState.Of(GetNode("StateChart/Root/Movement/OnWall/Running"));
|
||||||
// State timers
|
// State timers
|
||||||
_powerCooldownTimer = GetNode<Timer>("PowerCooldown");
|
_powerCooldownTimer = GetNode<Timer>("PowerCooldown");
|
||||||
_timeScaleAimInAirTimer = GetNode<Timer>("TimeScaleAimInAir");
|
_timeScaleAimInAirTimer = GetNode<Timer>("TimeScaleAimInAir");
|
||||||
@@ -316,20 +323,10 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
WallHugSystem.Init();
|
WallHugSystem.Init();
|
||||||
|
|
||||||
// RPG Stuff
|
// RPG Stuff
|
||||||
HealthSystem.HealthSystemInitParams healthSystemParams = new HealthSystem.HealthSystemInitParams()
|
|
||||||
{
|
|
||||||
Parent = this,
|
|
||||||
Camera = camera,
|
|
||||||
Head = HeadSystem,
|
|
||||||
VignetteRect = vignetteRect,
|
|
||||||
DistortionRect = distortionRect,
|
|
||||||
BlurRect = blurRect,
|
|
||||||
};
|
|
||||||
HealthSystem.Init(healthSystemParams);
|
|
||||||
Stamina.SetSpeeds(WalkSpeed, WalkSpeed);
|
|
||||||
|
|
||||||
EmpoweredActionsLeft = MaxNumberOfEmpoweredActions;
|
EmpoweredActionsLeft = MaxNumberOfEmpoweredActions;
|
||||||
PlaceWeaponForTutorial();
|
|
||||||
|
if (!TutorialDone)
|
||||||
|
PlaceWeaponForTutorial();
|
||||||
|
|
||||||
///////////////////////////
|
///////////////////////////
|
||||||
// Signal setup ///////////
|
// Signal setup ///////////
|
||||||
@@ -374,9 +371,11 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
|
|
||||||
_simpleDashCooldownTimer.Timeout += DashCooldownTimeout;
|
_simpleDashCooldownTimer.Timeout += DashCooldownTimeout;
|
||||||
|
|
||||||
_onWallHugCanceled.StatePhysicsProcessing += HandleAirborne;
|
_onWall.StateEntered += OnWallStarted;
|
||||||
|
_onWall.StateExited += OnWallStopped;
|
||||||
_onWallHugging.StatePhysicsProcessing += HandleWallHugging;
|
_onWallHugging.StatePhysicsProcessing += HandleWallHugging;
|
||||||
_onWallHanging.StatePhysicsProcessing += HandleWallHanging;
|
_onWallHanging.StatePhysicsProcessing += HandleWallHanging;
|
||||||
|
_onWallRunning.StatePhysicsProcessing += HandleWallRunning;
|
||||||
|
|
||||||
_onJumpFromWall.Taken += OnJumpFromWall;
|
_onJumpFromWall.Taken += OnJumpFromWall;
|
||||||
_onMegajumpFromWall.Taken += OnMegajumpFromWall;
|
_onMegajumpFromWall.Taken += OnMegajumpFromWall;
|
||||||
@@ -409,6 +408,7 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
}
|
}
|
||||||
|
|
||||||
_lookSensitivityMultiplier = (float) config.GetValue("InputSettings", "LookSensitivity", 1.0f);
|
_lookSensitivityMultiplier = (float) config.GetValue("InputSettings", "LookSensitivity", 1.0f);
|
||||||
|
_mouseSensitivityMultiplier = (float) config.GetValue("InputSettings", "MouseSensitivity", 1.0f);
|
||||||
_headBobbingMultiplier = (float) config.GetValue("InputSettings", "HeadBobbingWhileWalking", 1.0f);
|
_headBobbingMultiplier = (float) config.GetValue("InputSettings", "HeadBobbingWhileWalking", 1.0f);
|
||||||
_fovChangeMultiplier = (float) config.GetValue("InputSettings", "FovChangeWithSpeed", 1.0f);
|
_fovChangeMultiplier = (float) config.GetValue("InputSettings", "FovChangeWithSpeed", 1.0f);
|
||||||
}
|
}
|
||||||
@@ -418,11 +418,6 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
TutorialDone = true;
|
TutorialDone = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void OnWallDetected()
|
|
||||||
{
|
|
||||||
FinishPoweredDash();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void OnGrounded()
|
public void OnGrounded()
|
||||||
{
|
{
|
||||||
_isWallJumpAvailable = true;
|
_isWallJumpAvailable = true;
|
||||||
@@ -443,26 +438,121 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
if (!isOnFloorCustom())
|
if (!isOnFloorCustom())
|
||||||
_playerState.SendEvent("start_falling");
|
_playerState.SendEvent("start_falling");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void HandleAirborne(float delta)
|
public void HandleAirborne(float delta)
|
||||||
{
|
{
|
||||||
MoveInAir(delta);
|
MoveInAir(delta);
|
||||||
if (isOnFloorCustom())
|
if (isOnFloorCustom())
|
||||||
_playerState.SendEvent("grounded");
|
_playerState.SendEvent("grounded");
|
||||||
if (WallHugSystem.IsWallHugging() && Velocity.Y < 0)
|
|
||||||
|
if (!WallHugSystem.IsWallHugging())
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Going upwards, we stay simply airborne
|
||||||
|
if (Velocity.AngleTo(Vector3.Up) < Math.PI / 4)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Should we start a wall run
|
||||||
|
var wallNormal = WallHugSystem.WallHugNormal.UnwrapOr(Vector3.Zero);
|
||||||
|
var isIndeedWall = wallNormal.Y < 0.1;
|
||||||
|
var hvel = new Vector3(Velocity.X, 0, Velocity.Z);
|
||||||
|
var hvelProjected = hvel.Slide(_wallHugStartNormal);
|
||||||
|
var haveEnoughSpeed = hvelProjected.Length() > WallRunSpeedThreshold;
|
||||||
|
var isCoplanarEnough = Velocity.AngleTo(wallNormal) > Math.PI/4 && Velocity.AngleTo(wallNormal) < 3*Math.PI/4;
|
||||||
|
var isGoingDownwards = Velocity.AngleTo(Vector3.Down) < Math.PI/4;
|
||||||
|
if (haveEnoughSpeed && isCoplanarEnough && !isGoingDownwards && isIndeedWall && !_coyoteEnabled.Active)
|
||||||
|
{
|
||||||
|
SetVerticalVelocity(WallRunUpwardVelocity);
|
||||||
|
_playerState.SendEvent("wall_run");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// If all else fail and we go down, we hug
|
||||||
|
if (Velocity.Y < 0 && !_coyoteEnabled.Active)
|
||||||
_playerState.SendEvent("wall_hug");
|
_playerState.SendEvent("wall_hug");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Vector3 _wallHugStartLocation = Vector3.Zero;
|
||||||
|
private Vector3 _wallHugStartNormal = Vector3.Zero;
|
||||||
|
private Vector3 _wallHugStartProjectedVelocity = Vector3.Zero;
|
||||||
|
|
||||||
|
public void OnWallDetected()
|
||||||
|
{
|
||||||
|
FinishPoweredDash();
|
||||||
|
|
||||||
|
if (!_onWall.Active)
|
||||||
|
return;
|
||||||
|
|
||||||
|
var newWallNormal = WallHugSystem.WallHugNormal.UnwrapOr(Vector3.Up);
|
||||||
|
_wallHugStartNormal = newWallNormal;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void OnWallStarted()
|
||||||
|
{
|
||||||
|
_wallHugStartNormal = WallHugSystem.WallHugNormal.UnwrapOr(Vector3.Up);
|
||||||
|
_wallHugStartLocation = WallHugSystem.WallHugLocation.UnwrapOr(Vector3.Zero) + _wallHugStartNormal * _playerRadius;
|
||||||
|
_wallHugStartProjectedVelocity = Velocity.Slide(_wallHugStartNormal);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void OnWallStopped()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
public void HandleWallHugging(float delta)
|
public void HandleWallHugging(float delta)
|
||||||
{
|
{
|
||||||
WallHug(delta);
|
WallHug(delta);
|
||||||
if (isOnFloorCustom())
|
if (isOnFloorCustom())
|
||||||
_playerState.SendEvent("grounded");
|
_playerState.SendEvent("grounded");
|
||||||
if (!WallHugSystem.IsWallHugging())
|
if (!WallHugSystem.IsWallHugging())
|
||||||
|
{
|
||||||
_playerState.SendEvent("start_falling");
|
_playerState.SendEvent("start_falling");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
public void HandleWallHanging(float delta)
|
public void HandleWallHanging(float delta)
|
||||||
{
|
{
|
||||||
WallHang(delta);
|
WallHang(delta);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void HandleWallRunning(float delta)
|
||||||
|
{
|
||||||
|
// Find horizontal velocity projected on the current wall
|
||||||
|
var hvel = new Vector3(Velocity.X, 0, Velocity.Z);
|
||||||
|
var hvelProjected = hvel.Slide(_wallHugStartNormal);
|
||||||
|
|
||||||
|
// Reorient horizontal velocity so we keep it coplanar with the wall without losing speed
|
||||||
|
var finalHVel = hvelProjected.Normalized() * hvel.Length();
|
||||||
|
|
||||||
|
// Adapt vertical speed
|
||||||
|
var verticalSpeed = Velocity.Y - WallRunAltitudeLossSpeed * delta;
|
||||||
|
Velocity = finalHVel + Vector3.Up*verticalSpeed;
|
||||||
|
Velocity *= 0.995f;
|
||||||
|
|
||||||
|
if (WallRunSnapper.IsColliding())
|
||||||
|
{
|
||||||
|
GD.Print((WallRunSnapper.GetCollisionPoint() - WallRunSnapper.GlobalPosition).Length());
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!WallHugSystem.IsWallHugging() || Velocity.Length() < WallRunSpeedThreshold)
|
||||||
|
{
|
||||||
|
_playerState.SendEvent("start_falling");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void WallHug(float delta)
|
||||||
|
{
|
||||||
|
var hvel = ComputeHVelocity(delta, WallHugHorizontalDeceleration, WallHugHorizontalDeceleration);
|
||||||
|
var hvelProjected = hvel.Slide(_wallHugStartNormal);
|
||||||
|
var vvel = Velocity.Y - (CalculateGravityForce() * delta / WallHugGravityLesseningFactor);
|
||||||
|
vvel = Math.Abs(vvel) > WallHugDownwardMaxSpeed ? -WallHugDownwardMaxSpeed : vvel;
|
||||||
|
Velocity = hvelProjected + vvel*Vector3.Up;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void WallHang(float delta)
|
||||||
|
{
|
||||||
|
Velocity = Vector3.Zero;
|
||||||
|
GlobalPosition = _wallHugStartLocation;
|
||||||
|
}
|
||||||
|
|
||||||
private Option<Vector3> _plannedMantleLocation = Option<Vector3>.None;
|
private Option<Vector3> _plannedMantleLocation = Option<Vector3>.None;
|
||||||
|
|
||||||
@@ -471,7 +561,10 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
{
|
{
|
||||||
if (CanMantle())
|
if (CanMantle())
|
||||||
{
|
{
|
||||||
MantleToLocation(_plannedMantleLocation.Unwrap());
|
var location = _plannedMantleLocation.UnwrapOr(Vector3.Zero);
|
||||||
|
if (location == Vector3.Zero)
|
||||||
|
return; // For some reason CanMantle can return an invalid location so fuck off I guess
|
||||||
|
MantleToLocation(location);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -480,6 +573,7 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
_playerState.SendEvent("megajump");
|
_playerState.SendEvent("megajump");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
_playerState.SendEvent("jump");
|
_playerState.SendEvent("jump");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -504,6 +598,7 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
public void OnDoubleJumpStarted()
|
public void OnDoubleJumpStarted()
|
||||||
{
|
{
|
||||||
_canDash = true;
|
_canDash = true;
|
||||||
|
_canDashAirborne = true;
|
||||||
OnJumpStarted(DoubleJumpStartVelocity);
|
OnJumpStarted(DoubleJumpStartVelocity);
|
||||||
}
|
}
|
||||||
public void OnMegaJumpStarted()
|
public void OnMegaJumpStarted()
|
||||||
@@ -511,20 +606,6 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
PerformEmpoweredAction();
|
PerformEmpoweredAction();
|
||||||
OnJumpStarted(MegaJumpStartVelocity);
|
OnJumpStarted(MegaJumpStartVelocity);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void WallHug(float delta)
|
|
||||||
{
|
|
||||||
var hvel = ComputeHVelocity(delta, WallHugHorizontalDeceleration, WallHugHorizontalDeceleration);
|
|
||||||
var vvel = Velocity.Y - (CalculateGravityForce() * delta / WallHugGravityLesseningFactor);
|
|
||||||
vvel = Math.Abs(vvel) > WallHugDownwardMaxSpeed ? -WallHugDownwardMaxSpeed : vvel;
|
|
||||||
Velocity = hvel + vvel*Vector3.Up;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void WallHang(float delta)
|
|
||||||
{
|
|
||||||
Velocity = Vector3.Zero;
|
|
||||||
MoveAndSlide();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void ComputeJumpFromWallHSpeed(float jumpStrength)
|
public void ComputeJumpFromWallHSpeed(float jumpStrength)
|
||||||
{
|
{
|
||||||
@@ -533,7 +614,7 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
// _isWallJumpAvailable = false;
|
// _isWallJumpAvailable = false;
|
||||||
// var isLookingTowardsWall = HeadSystem.GetForwardHorizontalVector().Dot(wallNormal) > 0.5;
|
// var isLookingTowardsWall = HeadSystem.GetForwardHorizontalVector().Dot(wallNormal) > 0.5;
|
||||||
// var jumpDirection = isLookingTowardsWall ? Vector3.Up : wallNormal;
|
// var jumpDirection = isLookingTowardsWall ? Vector3.Up : wallNormal;
|
||||||
var wallNormal = WallHugSystem.GetWallNormal().UnwrapOr(Vector3.Up);
|
var wallNormal = WallHugSystem.WallHugNormal.UnwrapOr(Vector3.Up);
|
||||||
var jumpVector = wallNormal * jumpStrength;
|
var jumpVector = wallNormal * jumpStrength;
|
||||||
|
|
||||||
var currentHorizontalVelocity = new Vector2(Velocity.X, Velocity.Z);
|
var currentHorizontalVelocity = new Vector2(Velocity.X, Velocity.Z);
|
||||||
@@ -550,9 +631,21 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
ComputeJumpFromWallHSpeed(WallMegajumpStartVelocity);
|
ComputeJumpFromWallHSpeed(WallMegajumpStartVelocity);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void InputDeviceChanged(bool isUsingGamepad)
|
||||||
|
{
|
||||||
|
_isUsingGamepad = isUsingGamepad;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Vector3 GetMoveInput()
|
||||||
|
{
|
||||||
|
if (_isUsingGamepad)
|
||||||
|
return _inputMove;
|
||||||
|
return _inputMoveKeyboard;
|
||||||
|
}
|
||||||
|
|
||||||
public Vector3 ComputeHVelocity(float delta, float accelerationFactor, float decelerationFactor, Vector3? direction = null)
|
public Vector3 ComputeHVelocity(float delta, float accelerationFactor, float decelerationFactor, Vector3? direction = null)
|
||||||
{
|
{
|
||||||
var dir = direction ?? Transform.Basis * HeadSystem.Transform.Basis * _inputMove;
|
var dir = direction ?? Transform.Basis * HeadSystem.Transform.Basis * GetMoveInput();
|
||||||
|
|
||||||
var acceleration = dir.Length() > 0 ? accelerationFactor : decelerationFactor;
|
var acceleration = dir.Length() > 0 ? accelerationFactor : decelerationFactor;
|
||||||
|
|
||||||
@@ -654,6 +747,12 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
///////////////////////////
|
///////////////////////////
|
||||||
// Input Management ///////
|
// Input Management ///////
|
||||||
///////////////////////////
|
///////////////////////////
|
||||||
|
|
||||||
|
public void OnInputMoveKeyboard(Vector3 value)
|
||||||
|
{
|
||||||
|
_inputMoveKeyboard = value;
|
||||||
|
}
|
||||||
|
|
||||||
public void OnInputMove(Vector3 value)
|
public void OnInputMove(Vector3 value)
|
||||||
{
|
{
|
||||||
_inputMove = value;
|
_inputMove = value;
|
||||||
@@ -861,6 +960,9 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
|
|
||||||
public void PlaceWeaponForTutorial()
|
public void PlaceWeaponForTutorial()
|
||||||
{
|
{
|
||||||
|
if (TutorialDone)
|
||||||
|
return;
|
||||||
|
|
||||||
RemoveChild(WeaponRoot);
|
RemoveChild(WeaponRoot);
|
||||||
GetTree().GetRoot().CallDeferred(Node.MethodName.AddChild, WeaponRoot);
|
GetTree().GetRoot().CallDeferred(Node.MethodName.AddChild, WeaponRoot);
|
||||||
WeaponRoot.CallDeferred(Node3D.MethodName.SetGlobalPosition, TutorialWeaponTarget.GlobalPosition);
|
WeaponRoot.CallDeferred(Node3D.MethodName.SetGlobalPosition, TutorialWeaponTarget.GlobalPosition);
|
||||||
@@ -911,13 +1013,13 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
|
|
||||||
public Vector3 GetInputGlobalHDirection()
|
public Vector3 GetInputGlobalHDirection()
|
||||||
{
|
{
|
||||||
var direction = Transform.Basis * HeadSystem.Transform.Basis * _inputMove;
|
var direction = Transform.Basis * HeadSystem.Transform.Basis * GetMoveInput();
|
||||||
return new Vector3(direction.X, 0, direction.Z).Normalized();
|
return new Vector3(direction.X, 0, direction.Z).Normalized();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Vector3 GetInputLocalHDirection()
|
public Vector3 GetInputLocalHDirection()
|
||||||
{
|
{
|
||||||
var direction = _inputMove;
|
var direction = GetMoveInput();
|
||||||
return new Vector3(direction.X, 0, direction.Z).Normalized();
|
return new Vector3(direction.X, 0, direction.Z).Normalized();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -997,7 +1099,8 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
private void LookAround()
|
private void LookAround()
|
||||||
{
|
{
|
||||||
Vector2 inputLookDir = new Vector2(_inputRotateY, _inputRotateFloorplane);
|
Vector2 inputLookDir = new Vector2(_inputRotateY, _inputRotateFloorplane);
|
||||||
HeadSystem.LookAround(inputLookDir, _lookSensitivityMultiplier);
|
var lookSensitivity = _isUsingGamepad ? _lookSensitivityMultiplier : _mouseSensitivityMultiplier;
|
||||||
|
HeadSystem.LookAround(inputLookDir, lookSensitivity);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void MoveOnGround(double delta)
|
public void MoveOnGround(double delta)
|
||||||
@@ -1075,7 +1178,7 @@ public partial class PlayerController : CharacterBody3D
|
|||||||
Bobbing.CameraBobbingParams cameraBobbingParams = new Bobbing.CameraBobbingParams
|
Bobbing.CameraBobbingParams cameraBobbingParams = new Bobbing.CameraBobbingParams
|
||||||
{
|
{
|
||||||
Delta = delta,
|
Delta = delta,
|
||||||
IsOnFloorCustom = isOnFloorCustom(),
|
IsOnFloorCustom = isOnFloorCustom() || _onWallRunning.Active,
|
||||||
Velocity = Velocity,
|
Velocity = Velocity,
|
||||||
SettingsMultiplier = _headBobbingMultiplier
|
SettingsMultiplier = _headBobbingMultiplier
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,14 +1,31 @@
|
|||||||
[gd_scene load_steps=9 format=3 uid="uid://0ysqmqphq6mq"]
|
[gd_scene load_steps=5 format=3 uid="uid://0ysqmqphq6mq"]
|
||||||
|
|
||||||
[ext_resource type="Script" uid="uid://dtkdrnsmlwm67" path="res://systems/head/HeadSystem.cs" id="1_8abgy"]
|
[ext_resource type="Script" uid="uid://dtkdrnsmlwm67" path="res://systems/head/HeadSystem.cs" id="1_8abgy"]
|
||||||
[ext_resource type="Material" uid="uid://dtq8i1ka1f2pn" path="res://player_controller/Assets/Materials/Health/CameraVignette.tres" id="2_urko7"]
|
|
||||||
[ext_resource type="Material" uid="uid://nyh5tn1yoxeu" path="res://player_controller/Assets/Materials/Health/CameraDistortion.tres" id="3_0hyrq"]
|
|
||||||
[ext_resource type="Shader" uid="uid://btw6vsb6sa7sn" path="res://player_controller/Shaders/Blur.gdshader" id="4_ubhf8"]
|
|
||||||
|
|
||||||
[sub_resource type="ShaderMaterial" id="ShaderMaterial_o1np4"]
|
[sub_resource type="Animation" id="Animation_urko7"]
|
||||||
shader = ExtResource("4_ubhf8")
|
length = 0.001
|
||||||
shader_parameter/limit = 0.0
|
tracks/0/type = "bezier"
|
||||||
shader_parameter/blur = 0.0
|
tracks/0/imported = false
|
||||||
|
tracks/0/enabled = true
|
||||||
|
tracks/0/path = NodePath("..:rotation:x")
|
||||||
|
tracks/0/interp = 1
|
||||||
|
tracks/0/loop_wrap = true
|
||||||
|
tracks/0/keys = {
|
||||||
|
"handle_modes": PackedInt32Array(0),
|
||||||
|
"points": PackedFloat32Array(0, -0.15, 0, 0.15, 0),
|
||||||
|
"times": PackedFloat32Array(0)
|
||||||
|
}
|
||||||
|
tracks/1/type = "bezier"
|
||||||
|
tracks/1/imported = false
|
||||||
|
tracks/1/enabled = true
|
||||||
|
tracks/1/path = NodePath("..:rotation:z")
|
||||||
|
tracks/1/interp = 1
|
||||||
|
tracks/1/loop_wrap = true
|
||||||
|
tracks/1/keys = {
|
||||||
|
"handle_modes": PackedInt32Array(0),
|
||||||
|
"points": PackedFloat32Array(0, -0.15, 0, 0.15, 0),
|
||||||
|
"times": PackedFloat32Array(0)
|
||||||
|
}
|
||||||
|
|
||||||
[sub_resource type="Animation" id="Animation_8abgy"]
|
[sub_resource type="Animation" id="Animation_8abgy"]
|
||||||
resource_name = "mantle"
|
resource_name = "mantle"
|
||||||
@@ -36,31 +53,6 @@ tracks/1/keys = {
|
|||||||
"times": PackedFloat32Array(0, 0.1, 0.2, 0.3)
|
"times": PackedFloat32Array(0, 0.1, 0.2, 0.3)
|
||||||
}
|
}
|
||||||
|
|
||||||
[sub_resource type="Animation" id="Animation_urko7"]
|
|
||||||
length = 0.001
|
|
||||||
tracks/0/type = "bezier"
|
|
||||||
tracks/0/imported = false
|
|
||||||
tracks/0/enabled = true
|
|
||||||
tracks/0/path = NodePath("..:rotation:x")
|
|
||||||
tracks/0/interp = 1
|
|
||||||
tracks/0/loop_wrap = true
|
|
||||||
tracks/0/keys = {
|
|
||||||
"handle_modes": PackedInt32Array(0),
|
|
||||||
"points": PackedFloat32Array(0, -0.15, 0, 0.15, 0),
|
|
||||||
"times": PackedFloat32Array(0)
|
|
||||||
}
|
|
||||||
tracks/1/type = "bezier"
|
|
||||||
tracks/1/imported = false
|
|
||||||
tracks/1/enabled = true
|
|
||||||
tracks/1/path = NodePath("..:rotation:z")
|
|
||||||
tracks/1/interp = 1
|
|
||||||
tracks/1/loop_wrap = true
|
|
||||||
tracks/1/keys = {
|
|
||||||
"handle_modes": PackedInt32Array(0),
|
|
||||||
"points": PackedFloat32Array(0, -0.15, 0, 0.15, 0),
|
|
||||||
"times": PackedFloat32Array(0)
|
|
||||||
}
|
|
||||||
|
|
||||||
[sub_resource type="AnimationLibrary" id="AnimationLibrary_0hyrq"]
|
[sub_resource type="AnimationLibrary" id="AnimationLibrary_0hyrq"]
|
||||||
_data = {
|
_data = {
|
||||||
&"RESET": SubResource("Animation_urko7"),
|
&"RESET": SubResource("Animation_urko7"),
|
||||||
@@ -77,41 +69,6 @@ transform = Transform3D(1, 0, 0, 0, 0.99999994, 0, 0, 0, 0.99999994, 0, 0, 0)
|
|||||||
current = true
|
current = true
|
||||||
fov = 90.0
|
fov = 90.0
|
||||||
|
|
||||||
[node name="CLVignette(Layer_1)" type="CanvasLayer" parent="CameraSmooth/Camera3D"]
|
|
||||||
|
|
||||||
[node name="HealthVignetteRect" type="ColorRect" parent="CameraSmooth/Camera3D/CLVignette(Layer_1)"]
|
|
||||||
material = ExtResource("2_urko7")
|
|
||||||
anchors_preset = 15
|
|
||||||
anchor_right = 1.0
|
|
||||||
anchor_bottom = 1.0
|
|
||||||
grow_horizontal = 2
|
|
||||||
grow_vertical = 2
|
|
||||||
mouse_filter = 2
|
|
||||||
|
|
||||||
[node name="CLDistortion(Layer_2)" type="CanvasLayer" parent="CameraSmooth/Camera3D"]
|
|
||||||
layer = 2
|
|
||||||
|
|
||||||
[node name="HealthDistortionRect" type="ColorRect" parent="CameraSmooth/Camera3D/CLDistortion(Layer_2)"]
|
|
||||||
material = ExtResource("3_0hyrq")
|
|
||||||
anchors_preset = 15
|
|
||||||
anchor_right = 1.0
|
|
||||||
anchor_bottom = 1.0
|
|
||||||
grow_horizontal = 2
|
|
||||||
grow_vertical = 2
|
|
||||||
mouse_filter = 2
|
|
||||||
|
|
||||||
[node name="CLBlur(Layer_2)" type="CanvasLayer" parent="CameraSmooth/Camera3D"]
|
|
||||||
layer = 2
|
|
||||||
|
|
||||||
[node name="BlurRect" type="ColorRect" parent="CameraSmooth/Camera3D/CLBlur(Layer_2)"]
|
|
||||||
material = SubResource("ShaderMaterial_o1np4")
|
|
||||||
anchors_preset = 15
|
|
||||||
anchor_right = 1.0
|
|
||||||
anchor_bottom = 1.0
|
|
||||||
grow_horizontal = 2
|
|
||||||
grow_vertical = 2
|
|
||||||
mouse_filter = 2
|
|
||||||
|
|
||||||
[node name="RayCast3D" type="RayCast3D" parent="CameraSmooth/Camera3D"]
|
[node name="RayCast3D" type="RayCast3D" parent="CameraSmooth/Camera3D"]
|
||||||
transform = Transform3D(1, 0, 0, 0, -4.37114e-08, -1, 0, 1, -4.37114e-08, 0, 0, -0.64723)
|
transform = Transform3D(1, 0, 0, 0, -4.37114e-08, -1, 0, 1, -4.37114e-08, 0, 0, -0.64723)
|
||||||
visible = false
|
visible = false
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
[gd_resource type="Resource" script_class="GUIDEMappingContext" load_steps=102 format=3 uid="uid://bl5crtu1gkrtr"]
|
[gd_resource type="Resource" script_class="GUIDEMappingContext" load_steps=155 format=3 uid="uid://bl5crtu1gkrtr"]
|
||||||
|
|
||||||
[ext_resource type="Script" uid="uid://cpplm41b5bt6m" path="res://addons/guide/guide_action_mapping.gd" id="1_qmhk6"]
|
[ext_resource type="Script" uid="uid://cpplm41b5bt6m" path="res://addons/guide/guide_action_mapping.gd" id="1_qmhk6"]
|
||||||
[ext_resource type="Resource" uid="uid://htqvokm8mufq" path="res://systems/inputs/base_mode/move.tres" id="2_g6bbx"]
|
[ext_resource type="Resource" uid="uid://htqvokm8mufq" path="res://systems/inputs/base_mode/move.tres" id="2_g6bbx"]
|
||||||
@@ -12,13 +12,16 @@
|
|||||||
[ext_resource type="Script" uid="uid://bbhoxsiqwo07l" path="res://addons/guide/inputs/guide_input_joy_axis_1d.gd" id="10_cvxqo"]
|
[ext_resource type="Script" uid="uid://bbhoxsiqwo07l" path="res://addons/guide/inputs/guide_input_joy_axis_1d.gd" id="10_cvxqo"]
|
||||||
[ext_resource type="Script" uid="uid://bjm4myqxg4phm" path="res://addons/guide/modifiers/guide_modifier_scale.gd" id="11_j3axn"]
|
[ext_resource type="Script" uid="uid://bjm4myqxg4phm" path="res://addons/guide/modifiers/guide_modifier_scale.gd" id="11_j3axn"]
|
||||||
[ext_resource type="Script" uid="uid://ckggy40lm0vjc" path="res://addons/guide/modifiers/guide_modifier_negate.gd" id="12_kxb2c"]
|
[ext_resource type="Script" uid="uid://ckggy40lm0vjc" path="res://addons/guide/modifiers/guide_modifier_negate.gd" id="12_kxb2c"]
|
||||||
|
[ext_resource type="Script" uid="uid://b6bwb7ie85kl1" path="res://addons/guide/inputs/guide_input_mouse_axis_1d.gd" id="13_j3axn"]
|
||||||
[ext_resource type="Resource" uid="uid://ccrb5xsnphc8" path="res://systems/inputs/base_mode/rotate_floorplane.tres" id="13_v2ywt"]
|
[ext_resource type="Resource" uid="uid://ccrb5xsnphc8" path="res://systems/inputs/base_mode/rotate_floorplane.tres" id="13_v2ywt"]
|
||||||
[ext_resource type="Resource" uid="uid://c3e0ivgaxrsyb" path="res://systems/inputs/base_mode/aim_down.tres" id="14_yp12v"]
|
[ext_resource type="Resource" uid="uid://c3e0ivgaxrsyb" path="res://systems/inputs/base_mode/aim_down.tres" id="14_yp12v"]
|
||||||
[ext_resource type="Script" uid="uid://b52rqq28tuqpg" path="res://addons/guide/triggers/guide_trigger_pressed.gd" id="15_fykw6"]
|
[ext_resource type="Script" uid="uid://b52rqq28tuqpg" path="res://addons/guide/triggers/guide_trigger_pressed.gd" id="15_fykw6"]
|
||||||
[ext_resource type="Script" uid="uid://b4cdrn4paoj3i" path="res://addons/guide/triggers/guide_trigger_down.gd" id="15_g6bbx"]
|
[ext_resource type="Script" uid="uid://b4cdrn4paoj3i" path="res://addons/guide/triggers/guide_trigger_down.gd" id="15_g6bbx"]
|
||||||
|
[ext_resource type="Script" uid="uid://cgy4anjdob2tp" path="res://addons/guide/modifiers/guide_modifier_window_relative.gd" id="15_rvpjj"]
|
||||||
[ext_resource type="Resource" uid="uid://b334rau1yxmm7" path="res://systems/inputs/base_mode/empower_down.tres" id="16_0qat1"]
|
[ext_resource type="Resource" uid="uid://b334rau1yxmm7" path="res://systems/inputs/base_mode/empower_down.tres" id="16_0qat1"]
|
||||||
[ext_resource type="Resource" uid="uid://bebstkm608wxx" path="res://systems/inputs/base_mode/aim_pressed.tres" id="16_li5ak"]
|
[ext_resource type="Resource" uid="uid://bebstkm608wxx" path="res://systems/inputs/base_mode/aim_pressed.tres" id="16_li5ak"]
|
||||||
[ext_resource type="Resource" uid="uid://j1o5ud0plk4" path="res://systems/inputs/base_mode/aim_release.tres" id="16_rvpjj"]
|
[ext_resource type="Resource" uid="uid://j1o5ud0plk4" path="res://systems/inputs/base_mode/aim_release.tres" id="16_rvpjj"]
|
||||||
|
[ext_resource type="Script" uid="uid://vgjlx6p007lp" path="res://addons/guide/inputs/guide_input_mouse_button.gd" id="17_kxb2c"]
|
||||||
[ext_resource type="Script" uid="uid://biiggjw6tv4uq" path="res://addons/guide/triggers/guide_trigger_released.gd" id="17_s8kjn"]
|
[ext_resource type="Script" uid="uid://biiggjw6tv4uq" path="res://addons/guide/triggers/guide_trigger_released.gd" id="17_s8kjn"]
|
||||||
[ext_resource type="Resource" uid="uid://7wm8ywvujwf" path="res://systems/inputs/base_mode/aim_cancel.tres" id="18_vibkn"]
|
[ext_resource type="Resource" uid="uid://7wm8ywvujwf" path="res://systems/inputs/base_mode/aim_cancel.tres" id="18_vibkn"]
|
||||||
[ext_resource type="Resource" uid="uid://bbce5wfwxpns1" path="res://systems/inputs/base_mode/empower_release.tres" id="19_li5ak"]
|
[ext_resource type="Resource" uid="uid://bbce5wfwxpns1" path="res://systems/inputs/base_mode/empower_release.tres" id="19_li5ak"]
|
||||||
@@ -31,6 +34,10 @@
|
|||||||
[ext_resource type="Resource" uid="uid://55b0dsvioj08" path="res://systems/inputs/base_mode/jump_pressed.tres" id="25_si4d4"]
|
[ext_resource type="Resource" uid="uid://55b0dsvioj08" path="res://systems/inputs/base_mode/jump_pressed.tres" id="25_si4d4"]
|
||||||
[ext_resource type="Resource" uid="uid://dgluj0ql5vth7" path="res://systems/inputs/base_mode/pause.tres" id="29_q86qg"]
|
[ext_resource type="Resource" uid="uid://dgluj0ql5vth7" path="res://systems/inputs/base_mode/pause.tres" id="29_q86qg"]
|
||||||
[ext_resource type="Script" uid="uid://cw71o87tvdx3q" path="res://addons/guide/inputs/guide_input_key.gd" id="30_cvxqo"]
|
[ext_resource type="Script" uid="uid://cw71o87tvdx3q" path="res://addons/guide/inputs/guide_input_key.gd" id="30_cvxqo"]
|
||||||
|
[ext_resource type="Resource" uid="uid://s1l0n1iitc6m" path="res://systems/inputs/base_mode/move_back.tres" id="33_fykw6"]
|
||||||
|
[ext_resource type="Resource" uid="uid://brswsknpgwal2" path="res://systems/inputs/base_mode/move_front.tres" id="34_rvpjj"]
|
||||||
|
[ext_resource type="Resource" uid="uid://f3vs6l4m623s" path="res://systems/inputs/base_mode/move_left.tres" id="35_s8kjn"]
|
||||||
|
[ext_resource type="Resource" uid="uid://t612lts1wi1s" path="res://systems/inputs/base_mode/move_right.tres" id="36_vibkn"]
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_vkvga"]
|
[sub_resource type="Resource" id="Resource_vkvga"]
|
||||||
script = ExtResource("4_1rw8g")
|
script = ExtResource("4_1rw8g")
|
||||||
@@ -73,10 +80,24 @@ script = ExtResource("3_yp12v")
|
|||||||
input = SubResource("Resource_05q5j")
|
input = SubResource("Resource_05q5j")
|
||||||
modifiers = Array[ExtResource("5_0qat1")]([SubResource("Resource_tn8ci"), SubResource("Resource_1koh7"), SubResource("Resource_eep0a")])
|
modifiers = Array[ExtResource("5_0qat1")]([SubResource("Resource_tn8ci"), SubResource("Resource_1koh7"), SubResource("Resource_eep0a")])
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_mfl87"]
|
||||||
|
script = ExtResource("13_j3axn")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_1n4k0"]
|
||||||
|
script = ExtResource("15_rvpjj")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_ukc1w"]
|
||||||
|
script = ExtResource("12_kxb2c")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_4pf65"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_mfl87")
|
||||||
|
modifiers = Array[ExtResource("5_0qat1")]([SubResource("Resource_1n4k0"), SubResource("Resource_ukc1w")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_tgr2g"]
|
[sub_resource type="Resource" id="Resource_tgr2g"]
|
||||||
script = ExtResource("1_qmhk6")
|
script = ExtResource("1_qmhk6")
|
||||||
action = ExtResource("9_q86qg")
|
action = ExtResource("9_q86qg")
|
||||||
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_dew8i")])
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_dew8i"), SubResource("Resource_4pf65")])
|
||||||
metadata/_guide_input_mappings_collapsed = false
|
metadata/_guide_input_mappings_collapsed = false
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_pf0ii"]
|
[sub_resource type="Resource" id="Resource_pf0ii"]
|
||||||
@@ -98,10 +119,25 @@ script = ExtResource("3_yp12v")
|
|||||||
input = SubResource("Resource_pf0ii")
|
input = SubResource("Resource_pf0ii")
|
||||||
modifiers = Array[ExtResource("5_0qat1")]([SubResource("Resource_nh7x4"), SubResource("Resource_04n84"), SubResource("Resource_m3aj7")])
|
modifiers = Array[ExtResource("5_0qat1")]([SubResource("Resource_nh7x4"), SubResource("Resource_04n84"), SubResource("Resource_m3aj7")])
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_2ioub"]
|
||||||
|
script = ExtResource("13_j3axn")
|
||||||
|
axis = 1
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_fvpbi"]
|
||||||
|
script = ExtResource("12_kxb2c")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_7l3h2"]
|
||||||
|
script = ExtResource("15_rvpjj")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_fyd0i"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_2ioub")
|
||||||
|
modifiers = Array[ExtResource("5_0qat1")]([SubResource("Resource_fvpbi"), SubResource("Resource_7l3h2")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_iarn8"]
|
[sub_resource type="Resource" id="Resource_iarn8"]
|
||||||
script = ExtResource("1_qmhk6")
|
script = ExtResource("1_qmhk6")
|
||||||
action = ExtResource("13_v2ywt")
|
action = ExtResource("13_v2ywt")
|
||||||
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_qu2wi")])
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_qu2wi"), SubResource("Resource_fyd0i")])
|
||||||
metadata/_guide_input_mappings_collapsed = false
|
metadata/_guide_input_mappings_collapsed = false
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_si4d4"]
|
[sub_resource type="Resource" id="Resource_si4d4"]
|
||||||
@@ -116,10 +152,22 @@ script = ExtResource("3_yp12v")
|
|||||||
input = SubResource("Resource_si4d4")
|
input = SubResource("Resource_si4d4")
|
||||||
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_2tfaw")])
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_2tfaw")])
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_o031f"]
|
||||||
|
script = ExtResource("17_kxb2c")
|
||||||
|
button = 2
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_3s858"]
|
||||||
|
script = ExtResource("15_g6bbx")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_wh232"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_o031f")
|
||||||
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_3s858")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_cvxqo"]
|
[sub_resource type="Resource" id="Resource_cvxqo"]
|
||||||
script = ExtResource("1_qmhk6")
|
script = ExtResource("1_qmhk6")
|
||||||
action = ExtResource("14_yp12v")
|
action = ExtResource("14_yp12v")
|
||||||
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_q86qg")])
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_q86qg"), SubResource("Resource_wh232")])
|
||||||
metadata/_guide_input_mappings_collapsed = false
|
metadata/_guide_input_mappings_collapsed = false
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_llfhp"]
|
[sub_resource type="Resource" id="Resource_llfhp"]
|
||||||
@@ -134,10 +182,22 @@ script = ExtResource("3_yp12v")
|
|||||||
input = SubResource("Resource_llfhp")
|
input = SubResource("Resource_llfhp")
|
||||||
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_ib0yi")])
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_ib0yi")])
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_xh105"]
|
||||||
|
script = ExtResource("17_kxb2c")
|
||||||
|
button = 2
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_30oue"]
|
||||||
|
script = ExtResource("15_fykw6")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_2supu"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_xh105")
|
||||||
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_30oue")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_tb8ii"]
|
[sub_resource type="Resource" id="Resource_tb8ii"]
|
||||||
script = ExtResource("1_qmhk6")
|
script = ExtResource("1_qmhk6")
|
||||||
action = ExtResource("16_li5ak")
|
action = ExtResource("16_li5ak")
|
||||||
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_r6kml")])
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_r6kml"), SubResource("Resource_2supu")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_cqc4k"]
|
[sub_resource type="Resource" id="Resource_cqc4k"]
|
||||||
script = ExtResource("10_cvxqo")
|
script = ExtResource("10_cvxqo")
|
||||||
@@ -151,10 +211,22 @@ script = ExtResource("3_yp12v")
|
|||||||
input = SubResource("Resource_cqc4k")
|
input = SubResource("Resource_cqc4k")
|
||||||
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_vanwy")])
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_vanwy")])
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_omo75"]
|
||||||
|
script = ExtResource("17_kxb2c")
|
||||||
|
button = 2
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_npyga"]
|
||||||
|
script = ExtResource("17_s8kjn")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_yxj6r"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_omo75")
|
||||||
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_npyga")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_iihs4"]
|
[sub_resource type="Resource" id="Resource_iihs4"]
|
||||||
script = ExtResource("1_qmhk6")
|
script = ExtResource("1_qmhk6")
|
||||||
action = ExtResource("16_rvpjj")
|
action = ExtResource("16_rvpjj")
|
||||||
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_bkx7d")])
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_bkx7d"), SubResource("Resource_yxj6r")])
|
||||||
metadata/_guide_input_mappings_collapsed = false
|
metadata/_guide_input_mappings_collapsed = false
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_fykw6"]
|
[sub_resource type="Resource" id="Resource_fykw6"]
|
||||||
@@ -221,10 +293,22 @@ input = SubResource("Resource_1fkas")
|
|||||||
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_6pxii")])
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_6pxii")])
|
||||||
metadata/_guide_triggers_collapsed = false
|
metadata/_guide_triggers_collapsed = false
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_pv160"]
|
||||||
|
script = ExtResource("30_cvxqo")
|
||||||
|
key = 32
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_ra6lx"]
|
||||||
|
script = ExtResource("15_fykw6")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_q44n6"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_pv160")
|
||||||
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_ra6lx")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_d2r0d"]
|
[sub_resource type="Resource" id="Resource_d2r0d"]
|
||||||
script = ExtResource("1_qmhk6")
|
script = ExtResource("1_qmhk6")
|
||||||
action = ExtResource("25_si4d4")
|
action = ExtResource("25_si4d4")
|
||||||
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_jy4f1")])
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_jy4f1"), SubResource("Resource_q44n6")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_oapce"]
|
[sub_resource type="Resource" id="Resource_oapce"]
|
||||||
script = ExtResource("19_qkgmj")
|
script = ExtResource("19_qkgmj")
|
||||||
@@ -234,10 +318,18 @@ script = ExtResource("3_yp12v")
|
|||||||
input = SubResource("Resource_oapce")
|
input = SubResource("Resource_oapce")
|
||||||
metadata/_guide_triggers_collapsed = false
|
metadata/_guide_triggers_collapsed = false
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_assli"]
|
||||||
|
script = ExtResource("30_cvxqo")
|
||||||
|
key = 32
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_x5v0d"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_assli")
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_xt1x5"]
|
[sub_resource type="Resource" id="Resource_xt1x5"]
|
||||||
script = ExtResource("1_qmhk6")
|
script = ExtResource("1_qmhk6")
|
||||||
action = ExtResource("21_818lq")
|
action = ExtResource("21_818lq")
|
||||||
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_8w5gu")])
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_8w5gu"), SubResource("Resource_x5v0d")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_li5ak"]
|
[sub_resource type="Resource" id="Resource_li5ak"]
|
||||||
script = ExtResource("19_qkgmj")
|
script = ExtResource("19_qkgmj")
|
||||||
@@ -251,10 +343,21 @@ script = ExtResource("3_yp12v")
|
|||||||
input = SubResource("Resource_li5ak")
|
input = SubResource("Resource_li5ak")
|
||||||
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_paxxe")])
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_paxxe")])
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_pdblu"]
|
||||||
|
script = ExtResource("17_kxb2c")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_q0e5d"]
|
||||||
|
script = ExtResource("15_fykw6")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_a8sqk"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_pdblu")
|
||||||
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_q0e5d")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_ew1hw"]
|
[sub_resource type="Resource" id="Resource_ew1hw"]
|
||||||
script = ExtResource("1_qmhk6")
|
script = ExtResource("1_qmhk6")
|
||||||
action = ExtResource("22_2hs2y")
|
action = ExtResource("22_2hs2y")
|
||||||
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_500v3")])
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_500v3"), SubResource("Resource_a8sqk")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_g6bbx"]
|
[sub_resource type="Resource" id="Resource_g6bbx"]
|
||||||
script = ExtResource("19_qkgmj")
|
script = ExtResource("19_qkgmj")
|
||||||
@@ -268,10 +371,46 @@ script = ExtResource("3_yp12v")
|
|||||||
input = SubResource("Resource_g6bbx")
|
input = SubResource("Resource_g6bbx")
|
||||||
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_yp12v")])
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_yp12v")])
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_xbeov"]
|
||||||
|
script = ExtResource("30_cvxqo")
|
||||||
|
key = 4194325
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_rt8uw"]
|
||||||
|
script = ExtResource("15_fykw6")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_hj46p"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_xbeov")
|
||||||
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_rt8uw")])
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_jk2g8"]
|
||||||
|
script = ExtResource("30_cvxqo")
|
||||||
|
key = 70
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_wcvib"]
|
||||||
|
script = ExtResource("15_fykw6")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_imjft"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_jk2g8")
|
||||||
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_wcvib")])
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_kx31q"]
|
||||||
|
script = ExtResource("30_cvxqo")
|
||||||
|
key = 4194326
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_oux88"]
|
||||||
|
script = ExtResource("15_fykw6")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_b7w5s"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_kx31q")
|
||||||
|
triggers = Array[ExtResource("8_2tfaw")]([SubResource("Resource_oux88")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_0qat1"]
|
[sub_resource type="Resource" id="Resource_0qat1"]
|
||||||
script = ExtResource("1_qmhk6")
|
script = ExtResource("1_qmhk6")
|
||||||
action = ExtResource("23_g6bbx")
|
action = ExtResource("23_g6bbx")
|
||||||
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_1rw8g")])
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_1rw8g"), SubResource("Resource_hj46p"), SubResource("Resource_imjft"), SubResource("Resource_b7w5s")])
|
||||||
metadata/_guide_input_mappings_collapsed = false
|
metadata/_guide_input_mappings_collapsed = false
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_j3axn"]
|
[sub_resource type="Resource" id="Resource_j3axn"]
|
||||||
@@ -333,7 +472,59 @@ action = ExtResource("29_q86qg")
|
|||||||
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_ai85f"), SubResource("Resource_1ycft"), SubResource("Resource_k8i2y")])
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_ai85f"), SubResource("Resource_1ycft"), SubResource("Resource_k8i2y")])
|
||||||
metadata/_guide_input_mappings_collapsed = false
|
metadata/_guide_input_mappings_collapsed = false
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_kcylj"]
|
||||||
|
script = ExtResource("30_cvxqo")
|
||||||
|
key = 83
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_yq6lj"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_kcylj")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_fjku4"]
|
||||||
|
script = ExtResource("1_qmhk6")
|
||||||
|
action = ExtResource("33_fykw6")
|
||||||
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_yq6lj")])
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_wt677"]
|
||||||
|
script = ExtResource("30_cvxqo")
|
||||||
|
key = 87
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_ly2iy"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_wt677")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_odnhd"]
|
||||||
|
script = ExtResource("1_qmhk6")
|
||||||
|
action = ExtResource("34_rvpjj")
|
||||||
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_ly2iy")])
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_i62p1"]
|
||||||
|
script = ExtResource("30_cvxqo")
|
||||||
|
key = 65
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_3d0gd"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_i62p1")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_0eff7"]
|
||||||
|
script = ExtResource("1_qmhk6")
|
||||||
|
action = ExtResource("35_s8kjn")
|
||||||
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_3d0gd")])
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_uqqnm"]
|
||||||
|
script = ExtResource("30_cvxqo")
|
||||||
|
key = 68
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_7io5e"]
|
||||||
|
script = ExtResource("3_yp12v")
|
||||||
|
input = SubResource("Resource_uqqnm")
|
||||||
|
|
||||||
|
[sub_resource type="Resource" id="Resource_gt77e"]
|
||||||
|
script = ExtResource("1_qmhk6")
|
||||||
|
action = ExtResource("36_vibkn")
|
||||||
|
input_mappings = Array[ExtResource("3_yp12v")]([SubResource("Resource_7io5e")])
|
||||||
|
|
||||||
[resource]
|
[resource]
|
||||||
script = ExtResource("23_llfhp")
|
script = ExtResource("23_llfhp")
|
||||||
mappings = Array[ExtResource("1_qmhk6")]([SubResource("Resource_88x08"), SubResource("Resource_tgr2g"), SubResource("Resource_iarn8"), SubResource("Resource_cvxqo"), SubResource("Resource_tb8ii"), SubResource("Resource_iihs4"), SubResource("Resource_vibkn"), SubResource("Resource_2hs2y"), SubResource("Resource_0s4kt"), SubResource("Resource_d2r0d"), SubResource("Resource_xt1x5"), SubResource("Resource_ew1hw"), SubResource("Resource_0qat1"), SubResource("Resource_vtk18"), SubResource("Resource_weyro")])
|
mappings = Array[ExtResource("1_qmhk6")]([SubResource("Resource_88x08"), SubResource("Resource_tgr2g"), SubResource("Resource_iarn8"), SubResource("Resource_cvxqo"), SubResource("Resource_tb8ii"), SubResource("Resource_iihs4"), SubResource("Resource_vibkn"), SubResource("Resource_2hs2y"), SubResource("Resource_0s4kt"), SubResource("Resource_d2r0d"), SubResource("Resource_xt1x5"), SubResource("Resource_ew1hw"), SubResource("Resource_0qat1"), SubResource("Resource_vtk18"), SubResource("Resource_weyro"), SubResource("Resource_fjku4"), SubResource("Resource_odnhd"), SubResource("Resource_0eff7"), SubResource("Resource_gt77e")])
|
||||||
metadata/_custom_type_script = "uid://dsa1dnifd6w32"
|
metadata/_custom_type_script = "uid://dsa1dnifd6w32"
|
||||||
|
|||||||
8
systems/inputs/base_mode/move_back.tres
Normal file
8
systems/inputs/base_mode/move_back.tres
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
[gd_resource type="Resource" script_class="GUIDEAction" load_steps=2 format=3 uid="uid://s1l0n1iitc6m"]
|
||||||
|
|
||||||
|
[ext_resource type="Script" uid="uid://cluhc11vixkf1" path="res://addons/guide/guide_action.gd" id="1_7ljxs"]
|
||||||
|
|
||||||
|
[resource]
|
||||||
|
script = ExtResource("1_7ljxs")
|
||||||
|
action_value_type = 1
|
||||||
|
metadata/_custom_type_script = "uid://cluhc11vixkf1"
|
||||||
8
systems/inputs/base_mode/move_front.tres
Normal file
8
systems/inputs/base_mode/move_front.tres
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
[gd_resource type="Resource" script_class="GUIDEAction" load_steps=2 format=3 uid="uid://brswsknpgwal2"]
|
||||||
|
|
||||||
|
[ext_resource type="Script" uid="uid://cluhc11vixkf1" path="res://addons/guide/guide_action.gd" id="1_6kcci"]
|
||||||
|
|
||||||
|
[resource]
|
||||||
|
script = ExtResource("1_6kcci")
|
||||||
|
action_value_type = 1
|
||||||
|
metadata/_custom_type_script = "uid://cluhc11vixkf1"
|
||||||
8
systems/inputs/base_mode/move_left.tres
Normal file
8
systems/inputs/base_mode/move_left.tres
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
[gd_resource type="Resource" script_class="GUIDEAction" load_steps=2 format=3 uid="uid://f3vs6l4m623s"]
|
||||||
|
|
||||||
|
[ext_resource type="Script" uid="uid://cluhc11vixkf1" path="res://addons/guide/guide_action.gd" id="1_u1qdq"]
|
||||||
|
|
||||||
|
[resource]
|
||||||
|
script = ExtResource("1_u1qdq")
|
||||||
|
action_value_type = 1
|
||||||
|
metadata/_custom_type_script = "uid://cluhc11vixkf1"
|
||||||
8
systems/inputs/base_mode/move_right.tres
Normal file
8
systems/inputs/base_mode/move_right.tres
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
[gd_resource type="Resource" script_class="GUIDEAction" load_steps=2 format=3 uid="uid://t612lts1wi1s"]
|
||||||
|
|
||||||
|
[ext_resource type="Script" uid="uid://cluhc11vixkf1" path="res://addons/guide/guide_action.gd" id="1_gd7dq"]
|
||||||
|
|
||||||
|
[resource]
|
||||||
|
script = ExtResource("1_gd7dq")
|
||||||
|
action_value_type = 1
|
||||||
|
metadata/_custom_type_script = "uid://cluhc11vixkf1"
|
||||||
@@ -6,6 +6,10 @@ class_name InputController
|
|||||||
|
|
||||||
@export_group("Move actions")
|
@export_group("Move actions")
|
||||||
@export var move:GUIDEAction
|
@export var move:GUIDEAction
|
||||||
|
@export var move_left:GUIDEAction
|
||||||
|
@export var move_right:GUIDEAction
|
||||||
|
@export var move_front:GUIDEAction
|
||||||
|
@export var move_back:GUIDEAction
|
||||||
@export var rotate_y:GUIDEAction
|
@export var rotate_y:GUIDEAction
|
||||||
@export var rotate_floorplane:GUIDEAction
|
@export var rotate_floorplane:GUIDEAction
|
||||||
|
|
||||||
@@ -25,9 +29,13 @@ class_name InputController
|
|||||||
@export var dash:GUIDEAction
|
@export var dash:GUIDEAction
|
||||||
@export var throw:GUIDEAction
|
@export var throw:GUIDEAction
|
||||||
|
|
||||||
|
signal input_device_changed(is_gamepad: bool)
|
||||||
|
var _using_gamepad = false
|
||||||
|
|
||||||
signal input_move(value: Vector3)
|
signal input_move(value: Vector3)
|
||||||
signal input_rotate_y(value: float)
|
signal input_rotate_y(value: float)
|
||||||
signal input_rotate_floorplane(value: float)
|
signal input_rotate_floorplane(value: float)
|
||||||
|
signal input_move_keyboard(value: Vector3)
|
||||||
|
|
||||||
# Jump
|
# Jump
|
||||||
signal input_jump_started
|
signal input_jump_started
|
||||||
@@ -100,7 +108,27 @@ func on_input_empower_released():
|
|||||||
func on_input_aim_canceled():
|
func on_input_aim_canceled():
|
||||||
input_aim_canceled.emit()
|
input_aim_canceled.emit()
|
||||||
|
|
||||||
|
func _input(event: InputEvent) -> void:
|
||||||
|
if event is InputEventKey:
|
||||||
|
if _using_gamepad:
|
||||||
|
_using_gamepad = false
|
||||||
|
input_device_changed.emit(_using_gamepad)
|
||||||
|
elif event is InputEventJoypadMotion:
|
||||||
|
if !_using_gamepad:
|
||||||
|
if abs(event.axis_value) > 0.5:
|
||||||
|
_using_gamepad = true
|
||||||
|
input_device_changed.emit(_using_gamepad)
|
||||||
|
elif event is InputEventJoypadButton:
|
||||||
|
if !_using_gamepad:
|
||||||
|
_using_gamepad = true
|
||||||
|
input_device_changed.emit(_using_gamepad)
|
||||||
|
|
||||||
func _process(_delta: float) -> void:
|
func _process(_delta: float) -> void:
|
||||||
|
var value_horizontal = -move_left.value_axis_1d + move_right.value_axis_1d
|
||||||
|
var value_vertical = -move_front.value_axis_1d + move_back.value_axis_1d
|
||||||
|
var keyboard_input_vector = Vector3(value_horizontal, 0, value_vertical)
|
||||||
|
|
||||||
|
input_move_keyboard.emit(keyboard_input_vector)
|
||||||
input_move.emit(move.value_axis_3d)
|
input_move.emit(move.value_axis_3d)
|
||||||
input_rotate_y.emit(rotate_y.value_axis_1d)
|
input_rotate_y.emit(rotate_y.value_axis_1d)
|
||||||
input_rotate_floorplane.emit(rotate_floorplane.value_axis_1d)
|
input_rotate_floorplane.emit(rotate_floorplane.value_axis_1d)
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
[gd_resource type="Resource" script_class="GUIDEMappingContext" load_steps=78 format=3 uid="uid://c2hpxkcujyc13"]
|
[gd_resource type="Resource" script_class="GUIDEMappingContext" load_steps=66 format=3 uid="uid://c2hpxkcujyc13"]
|
||||||
|
|
||||||
[ext_resource type="Script" uid="uid://cpplm41b5bt6m" path="res://addons/guide/guide_action_mapping.gd" id="1_xno0b"]
|
[ext_resource type="Script" uid="uid://cpplm41b5bt6m" path="res://addons/guide/guide_action_mapping.gd" id="1_xno0b"]
|
||||||
[ext_resource type="Resource" uid="uid://ck43v3q5ype3f" path="res://systems/inputs/menu_mode/back.tres" id="2_6sfub"]
|
[ext_resource type="Resource" uid="uid://ck43v3q5ype3f" path="res://systems/inputs/menu_mode/back.tres" id="2_6sfub"]
|
||||||
@@ -16,7 +16,6 @@
|
|||||||
[ext_resource type="Resource" uid="uid://by80bubgg0dpx" path="res://systems/inputs/menu_mode/left.tres" id="13_sy651"]
|
[ext_resource type="Resource" uid="uid://by80bubgg0dpx" path="res://systems/inputs/menu_mode/left.tres" id="13_sy651"]
|
||||||
[ext_resource type="Resource" uid="uid://bmef0jo6o41ic" path="res://systems/inputs/menu_mode/next.tres" id="14_2sr1w"]
|
[ext_resource type="Resource" uid="uid://bmef0jo6o41ic" path="res://systems/inputs/menu_mode/next.tres" id="14_2sr1w"]
|
||||||
[ext_resource type="Resource" uid="uid://c3n6ww58cmbbk" path="res://systems/inputs/menu_mode/previous.tres" id="15_2j2sf"]
|
[ext_resource type="Resource" uid="uid://c3n6ww58cmbbk" path="res://systems/inputs/menu_mode/previous.tres" id="15_2j2sf"]
|
||||||
[ext_resource type="Resource" uid="uid://dgluj0ql5vth7" path="res://systems/inputs/base_mode/pause.tres" id="16_scydb"]
|
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_tp5dr"]
|
[sub_resource type="Resource" id="Resource_tp5dr"]
|
||||||
script = ExtResource("4_q6ncx")
|
script = ExtResource("4_q6ncx")
|
||||||
@@ -30,16 +29,11 @@ script = ExtResource("3_scydb")
|
|||||||
input = SubResource("Resource_tp5dr")
|
input = SubResource("Resource_tp5dr")
|
||||||
triggers = Array[ExtResource("6_c647i")]([SubResource("Resource_lvbl0")])
|
triggers = Array[ExtResource("6_c647i")]([SubResource("Resource_lvbl0")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_h2f8g"]
|
|
||||||
script = ExtResource("8_yfqfy")
|
|
||||||
key = 4194305
|
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_17mt7"]
|
[sub_resource type="Resource" id="Resource_17mt7"]
|
||||||
script = ExtResource("7_m88dc")
|
script = ExtResource("7_m88dc")
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_23hmj"]
|
[sub_resource type="Resource" id="Resource_23hmj"]
|
||||||
script = ExtResource("3_scydb")
|
script = ExtResource("3_scydb")
|
||||||
input = SubResource("Resource_h2f8g")
|
|
||||||
triggers = Array[ExtResource("6_c647i")]([SubResource("Resource_17mt7")])
|
triggers = Array[ExtResource("6_c647i")]([SubResource("Resource_17mt7")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_len71"]
|
[sub_resource type="Resource" id="Resource_len71"]
|
||||||
@@ -225,48 +219,7 @@ script = ExtResource("1_xno0b")
|
|||||||
action = ExtResource("15_2j2sf")
|
action = ExtResource("15_2j2sf")
|
||||||
input_mappings = Array[ExtResource("3_scydb")]([SubResource("Resource_3owmx")])
|
input_mappings = Array[ExtResource("3_scydb")]([SubResource("Resource_3owmx")])
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_q6ncx"]
|
|
||||||
script = ExtResource("4_q6ncx")
|
|
||||||
button = 4
|
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_vnf02"]
|
|
||||||
script = ExtResource("7_m88dc")
|
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_c647i"]
|
|
||||||
script = ExtResource("3_scydb")
|
|
||||||
input = SubResource("Resource_q6ncx")
|
|
||||||
triggers = Array[ExtResource("6_c647i")]([SubResource("Resource_vnf02")])
|
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_m88dc"]
|
|
||||||
script = ExtResource("4_q6ncx")
|
|
||||||
button = 6
|
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_yfqfy"]
|
|
||||||
script = ExtResource("7_m88dc")
|
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_dsdj3"]
|
|
||||||
script = ExtResource("3_scydb")
|
|
||||||
input = SubResource("Resource_m88dc")
|
|
||||||
triggers = Array[ExtResource("6_c647i")]([SubResource("Resource_yfqfy")])
|
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_q44ew"]
|
|
||||||
script = ExtResource("8_yfqfy")
|
|
||||||
key = 4194305
|
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_as826"]
|
|
||||||
script = ExtResource("7_m88dc")
|
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_erftc"]
|
|
||||||
script = ExtResource("3_scydb")
|
|
||||||
input = SubResource("Resource_q44ew")
|
|
||||||
triggers = Array[ExtResource("6_c647i")]([SubResource("Resource_as826")])
|
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_sy651"]
|
|
||||||
script = ExtResource("1_xno0b")
|
|
||||||
action = ExtResource("16_scydb")
|
|
||||||
input_mappings = Array[ExtResource("3_scydb")]([SubResource("Resource_c647i"), SubResource("Resource_dsdj3"), SubResource("Resource_erftc")])
|
|
||||||
|
|
||||||
[resource]
|
[resource]
|
||||||
script = ExtResource("2_w5wm7")
|
script = ExtResource("2_w5wm7")
|
||||||
mappings = Array[ExtResource("1_xno0b")]([SubResource("Resource_len71"), SubResource("Resource_ruq4f"), SubResource("Resource_5hp22"), SubResource("Resource_7i3b3"), SubResource("Resource_6ptcp"), SubResource("Resource_xked7"), SubResource("Resource_qjv8h"), SubResource("Resource_p0ahg"), SubResource("Resource_sy651")])
|
mappings = Array[ExtResource("1_xno0b")]([SubResource("Resource_len71"), SubResource("Resource_ruq4f"), SubResource("Resource_5hp22"), SubResource("Resource_7i3b3"), SubResource("Resource_6ptcp"), SubResource("Resource_xked7"), SubResource("Resource_qjv8h"), SubResource("Resource_p0ahg")])
|
||||||
metadata/_custom_type_script = "uid://dsa1dnifd6w32"
|
metadata/_custom_type_script = "uid://dsa1dnifd6w32"
|
||||||
|
|||||||
@@ -12,44 +12,47 @@ public partial class WallHugSystem : Node3D
|
|||||||
public delegate void WallDetectedEventHandler();
|
public delegate void WallDetectedEventHandler();
|
||||||
|
|
||||||
private List<RayCast3D> _raycasts;
|
private List<RayCast3D> _raycasts;
|
||||||
|
public Option<Vector3> WallHugLocation { get; private set; } = Option<Vector3>.None;
|
||||||
|
public Option<Vector3> WallHugNormal { get; private set; } = Option<Vector3>.None;
|
||||||
|
|
||||||
public void Init()
|
public void Init()
|
||||||
{
|
{
|
||||||
_raycasts = new List<RayCast3D>();
|
_raycasts = new List<RayCast3D>();
|
||||||
_raycasts.Add(GetNode<RayCast3D>("front"));
|
_raycasts.Add(GetNode<RayCast3D>("front"));
|
||||||
|
_raycasts.Add(GetNode<RayCast3D>("front2"));
|
||||||
_raycasts.Add(GetNode<RayCast3D>("back"));
|
_raycasts.Add(GetNode<RayCast3D>("back"));
|
||||||
|
_raycasts.Add(GetNode<RayCast3D>("back2"));
|
||||||
_raycasts.Add(GetNode<RayCast3D>("left"));
|
_raycasts.Add(GetNode<RayCast3D>("left"));
|
||||||
|
_raycasts.Add(GetNode<RayCast3D>("left2"));
|
||||||
_raycasts.Add(GetNode<RayCast3D>("right"));
|
_raycasts.Add(GetNode<RayCast3D>("right"));
|
||||||
|
_raycasts.Add(GetNode<RayCast3D>("right2"));
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void _PhysicsProcess(double delta)
|
public override void _PhysicsProcess(double delta)
|
||||||
{
|
{
|
||||||
base._PhysicsProcess(delta);
|
base._PhysicsProcess(delta);
|
||||||
|
CheckWallHugging();
|
||||||
if (IsWallHugging())
|
if (IsWallHugging())
|
||||||
EmitSignal(SignalName.WallDetected);
|
EmitSignal(SignalName.WallDetected);
|
||||||
}
|
}
|
||||||
|
|
||||||
public bool IsWallHugging()
|
public void CheckWallHugging()
|
||||||
{
|
{
|
||||||
foreach (RayCast3D raycast in _raycasts)
|
foreach (RayCast3D raycast in _raycasts)
|
||||||
{
|
{
|
||||||
if (raycast.IsColliding())
|
if (raycast.IsColliding())
|
||||||
{
|
{
|
||||||
return true;
|
WallHugLocation = raycast.GetCollisionPoint().Some();
|
||||||
|
WallHugNormal = raycast.GetCollisionNormal().Some();
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false;
|
WallHugLocation = Option<Vector3>.None;
|
||||||
|
WallHugNormal = Option<Vector3>.None;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Option<Vector3> GetWallNormal()
|
public bool IsWallHugging()
|
||||||
{
|
{
|
||||||
foreach (RayCast3D raycast in _raycasts)
|
return !WallHugLocation.IsNone;
|
||||||
{
|
|
||||||
if (raycast.IsColliding())
|
|
||||||
{
|
|
||||||
return raycast.GetCollisionNormal().Some();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return Option<Vector3>.None;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
16
tools/city_helpers.gd
Normal file
16
tools/city_helpers.gd
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
@tool
|
||||||
|
extends Node3D
|
||||||
|
|
||||||
|
@export_group("Place player")
|
||||||
|
@export_tool_button("Tuto start", "Callable") var player_tuto_start = place_player_tuto_start
|
||||||
|
@export_tool_button("Playground", "Callable") var player_playground = place_player_playground
|
||||||
|
|
||||||
|
@onready var player: CharacterBody3D = $Player
|
||||||
|
|
||||||
|
|
||||||
|
func place_player_tuto_start():
|
||||||
|
player.position = Vector3(0, -132.75, 118)
|
||||||
|
|
||||||
|
func place_player_playground():
|
||||||
|
player.position = Vector3(-6.0, 75.5, -13.5)
|
||||||
|
|
||||||
1
tools/city_helpers.gd.uid
Normal file
1
tools/city_helpers.gd.uid
Normal file
@@ -0,0 +1 @@
|
|||||||
|
uid://blenis2y55fmg
|
||||||
Reference in New Issue
Block a user