generated from krampus/template-godot4
Compare commits
No commits in common. "7c9403273f54bf7e57784f56ea4c8f99f6d40edb" and "af31c3c431b791d500752c0146b2a7e40036d7c9" have entirely different histories.
7c9403273f
...
af31c3c431
Binary file not shown.
|
@ -6,5 +6,5 @@
|
||||||
resource_name = "Sailboat"
|
resource_name = "Sailboat"
|
||||||
cull_mode = 2
|
cull_mode = 2
|
||||||
albedo_texture = ExtResource("1_k68kk")
|
albedo_texture = ExtResource("1_k68kk")
|
||||||
roughness = 0.43
|
roughness = 0.5
|
||||||
texture_filter = 2
|
texture_filter = 2
|
||||||
|
|
BIN
assets/sprites/particles/plasma.png (Stored with Git LFS)
BIN
assets/sprites/particles/plasma.png (Stored with Git LFS)
Binary file not shown.
|
@ -1,35 +0,0 @@
|
||||||
[remap]
|
|
||||||
|
|
||||||
importer="texture"
|
|
||||||
type="CompressedTexture2D"
|
|
||||||
uid="uid://c47bkx508biqr"
|
|
||||||
path.s3tc="res://.godot/imported/plasma.png-0d62f2e4ae083d296fe25ccf3ab68e80.s3tc.ctex"
|
|
||||||
metadata={
|
|
||||||
"imported_formats": ["s3tc_bptc"],
|
|
||||||
"vram_texture": true
|
|
||||||
}
|
|
||||||
|
|
||||||
[deps]
|
|
||||||
|
|
||||||
source_file="res://assets/sprites/particles/plasma.png"
|
|
||||||
dest_files=["res://.godot/imported/plasma.png-0d62f2e4ae083d296fe25ccf3ab68e80.s3tc.ctex"]
|
|
||||||
|
|
||||||
[params]
|
|
||||||
|
|
||||||
compress/mode=2
|
|
||||||
compress/high_quality=false
|
|
||||||
compress/lossy_quality=0.7
|
|
||||||
compress/hdr_compression=1
|
|
||||||
compress/normal_map=0
|
|
||||||
compress/channel_pack=0
|
|
||||||
mipmaps/generate=true
|
|
||||||
mipmaps/limit=-1
|
|
||||||
roughness/mode=0
|
|
||||||
roughness/src_normal=""
|
|
||||||
process/fix_alpha_border=true
|
|
||||||
process/premult_alpha=false
|
|
||||||
process/normal_map_invert_y=false
|
|
||||||
process/hdr_as_srgb=false
|
|
||||||
process/hdr_clamp_exposure=false
|
|
||||||
process/size_limit=0
|
|
||||||
detect_3d/compress_to=0
|
|
|
@ -334,9 +334,6 @@ visibility_aabb = AABB(-128, -4, -128, 256, 8, 256)
|
||||||
process_material = SubResource("ParticleProcessMaterial_6nt4t")
|
process_material = SubResource("ParticleProcessMaterial_6nt4t")
|
||||||
draw_pass_1 = SubResource("QuadMesh_l4j8a")
|
draw_pass_1 = SubResource("QuadMesh_l4j8a")
|
||||||
|
|
||||||
[node name="DemoCamera" type="Camera3D" parent="Course" groups=["DemoCamera"]]
|
|
||||||
transform = Transform3D(-0.734269, 0.305072, -0.606448, 0, 0.893336, 0.44939, 0.678858, 0.329973, -0.655949, 143.463, 90.0707, 223.738)
|
|
||||||
|
|
||||||
[node name="CityBuildings" type="Node3D" parent="."]
|
[node name="CityBuildings" type="Node3D" parent="."]
|
||||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 129.404, -9.53674e-07, 309.4)
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 129.404, -9.53674e-07, 309.4)
|
||||||
|
|
||||||
|
@ -388,9 +385,6 @@ transform = Transform3D(0.57763, 0, -0.816299, 0, 1, 0, 0.816299, 0, 0.57763, 0.
|
||||||
[node name="PalmTree2" parent="MountainCurve" instance=ExtResource("12_sswxf")]
|
[node name="PalmTree2" parent="MountainCurve" instance=ExtResource("12_sswxf")]
|
||||||
transform = Transform3D(0.184826, 0, -0.982771, 0, 1, 0, 0.982771, 0, 0.184826, 1.55019, 0, -15.9243)
|
transform = Transform3D(0.184826, 0, -0.982771, 0, 1, 0, 0.982771, 0, 0.184826, 1.55019, 0, -15.9243)
|
||||||
|
|
||||||
[node name="DemoCamera" type="Camera3D" parent="MountainCurve" groups=["DemoCamera"]]
|
|
||||||
transform = Transform3D(-0.909976, -0.0858909, 0.405667, 0, 0.978312, 0.207136, -0.41466, 0.188489, -0.890241, 21.863, 16.4413, -111.296)
|
|
||||||
|
|
||||||
[node name="Lakeside" type="Node3D" parent="."]
|
[node name="Lakeside" type="Node3D" parent="."]
|
||||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 458.103, 1.52588e-05, 204.202)
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 458.103, 1.52588e-05, 204.202)
|
||||||
|
|
||||||
|
@ -425,8 +419,9 @@ transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 14.4011, 0.530239, -13.6932)
|
||||||
[node name="Umineko3" parent="Lakeside/Flock2" instance=ExtResource("21_ch6qk")]
|
[node name="Umineko3" parent="Lakeside/Flock2" instance=ExtResource("21_ch6qk")]
|
||||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, -9.56348, -0.274033, -7.70535)
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, -9.56348, -0.274033, -7.70535)
|
||||||
|
|
||||||
[node name="DemoCamera" type="Camera3D" parent="Lakeside" groups=["DemoCamera"]]
|
[node name="DemoCamera" type="Camera3D" parent="."]
|
||||||
transform = Transform3D(-0.942644, 0.108925, 0.315527, 0, 0.94526, -0.326318, -0.333799, -0.307602, -0.891044, -5.37366, 0.689307, -6.26129)
|
transform = Transform3D(-0.317113, 0.433573, -0.843477, 0, 0.88938, 0.457168, 0.948388, 0.144974, -0.282034, 461.268, 30.8271, 256.17)
|
||||||
|
visible = false
|
||||||
|
|
||||||
[node name="NorthSea" type="Node3D" parent="."]
|
[node name="NorthSea" type="Node3D" parent="."]
|
||||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, -179.859, -2, 1062.93)
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, -179.859, -2, 1062.93)
|
||||||
|
|
|
@ -63,8 +63,6 @@ config/accessibility/enable_hit_lag=true
|
||||||
|
|
||||||
WorldGroup="Singleton group for the active world instance, if any."
|
WorldGroup="Singleton group for the active world instance, if any."
|
||||||
GameGroup="Singleton group for the active game instance, if any."
|
GameGroup="Singleton group for the active game instance, if any."
|
||||||
DemoCamera=""
|
|
||||||
PlayerSpawn=""
|
|
||||||
|
|
||||||
[gui]
|
[gui]
|
||||||
|
|
||||||
|
@ -127,11 +125,6 @@ shot_accept={
|
||||||
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":32,"key_label":0,"unicode":32,"location":0,"echo":false,"script":null)
|
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":32,"key_label":0,"unicode":32,"location":0,"echo":false,"script":null)
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
shot_cancel={
|
|
||||||
"deadzone": 0.5,
|
|
||||||
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":81,"key_label":0,"unicode":113,"location":0,"echo":false,"script":null)
|
|
||||||
]
|
|
||||||
}
|
|
||||||
select_driver={
|
select_driver={
|
||||||
"deadzone": 0.5,
|
"deadzone": 0.5,
|
||||||
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":49,"key_label":0,"unicode":49,"location":0,"echo":false,"script":null)
|
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":49,"key_label":0,"unicode":49,"location":0,"echo":false,"script":null)
|
||||||
|
@ -177,11 +170,6 @@ debug_4={
|
||||||
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":4194335,"key_label":0,"unicode":0,"location":0,"echo":false,"script":null)
|
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":4194335,"key_label":0,"unicode":0,"location":0,"echo":false,"script":null)
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
pause={
|
|
||||||
"deadzone": 0.5,
|
|
||||||
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":4194305,"key_label":0,"unicode":0,"location":0,"echo":false,"script":null)
|
|
||||||
]
|
|
||||||
}
|
|
||||||
|
|
||||||
[layer_names]
|
[layer_names]
|
||||||
|
|
||||||
|
|
|
@ -25,9 +25,6 @@ const IRON_DAMPING := 9999.0
|
||||||
## Base damage inflicted on impact with a player
|
## Base damage inflicted on impact with a player
|
||||||
@export var base_damage := 15.0
|
@export var base_damage := 15.0
|
||||||
|
|
||||||
var _last_contact_normal: Vector3 = Vector3.UP
|
|
||||||
var _position_on_last_wake: Vector3
|
|
||||||
var _awake := false
|
|
||||||
var _zones: Array[BallZone] = []
|
var _zones: Array[BallZone] = []
|
||||||
|
|
||||||
@onready var normal_physics: PhysicsMaterial = preload(
|
@onready var normal_physics: PhysicsMaterial = preload(
|
||||||
|
@ -37,8 +34,6 @@ var _zones: Array[BallZone] = []
|
||||||
"res://src/equipment/balls/physics_ball/iron_physics.tres"
|
"res://src/equipment/balls/physics_ball/iron_physics.tres"
|
||||||
)
|
)
|
||||||
|
|
||||||
@onready var _debug_draw: Control = %DebugDraw
|
|
||||||
|
|
||||||
|
|
||||||
## Called by a water area when this ball enters it
|
## Called by a water area when this ball enters it
|
||||||
func enter_water() -> void:
|
func enter_water() -> void:
|
||||||
|
@ -52,20 +47,13 @@ func _total_terrain_angular_damping() -> float:
|
||||||
|
|
||||||
|
|
||||||
func _integrate_forces(state: PhysicsDirectBodyState3D) -> void:
|
func _integrate_forces(state: PhysicsDirectBodyState3D) -> void:
|
||||||
if not _awake:
|
|
||||||
# Triggered on first frame after waking
|
|
||||||
_awake = true
|
|
||||||
_position_on_last_wake = global_position
|
|
||||||
_last_contact_normal = Vector3.UP
|
|
||||||
|
|
||||||
var damping := air_damping
|
var damping := air_damping
|
||||||
if state.get_contact_count():
|
if iron_ball:
|
||||||
_last_contact_normal = state.get_contact_local_normal(0)
|
damping = iron_damping
|
||||||
|
elif state.get_contact_count():
|
||||||
damping = _total_terrain_angular_damping()
|
damping = _total_terrain_angular_damping()
|
||||||
if damping <= TERRAIN_DAMPING_EPSILON:
|
if damping <= TERRAIN_DAMPING_EPSILON:
|
||||||
damping = rough_damping
|
damping = rough_damping
|
||||||
if iron_ball:
|
|
||||||
damping = iron_damping
|
|
||||||
angular_damp = damping
|
angular_damp = damping
|
||||||
|
|
||||||
|
|
||||||
|
@ -78,17 +66,3 @@ func enter_zone(zone: BallZone) -> void:
|
||||||
|
|
||||||
func exit_zone(zone: BallZone) -> void:
|
func exit_zone(zone: BallZone) -> void:
|
||||||
_zones.erase(zone)
|
_zones.erase(zone)
|
||||||
|
|
||||||
|
|
||||||
func get_reoriented_basis() -> Basis:
|
|
||||||
var up := _last_contact_normal.normalized()
|
|
||||||
var forward := (_position_on_last_wake - global_position).normalized()
|
|
||||||
var right := up.cross(forward).normalized()
|
|
||||||
forward = right.cross(up) # orthonormalize
|
|
||||||
return Basis(right, up, forward)
|
|
||||||
|
|
||||||
|
|
||||||
func _on_sleeping_state_changed() -> void:
|
|
||||||
if sleeping:
|
|
||||||
# Trigger to reassign on wake
|
|
||||||
_awake = false
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
[gd_scene load_steps=9 format=3 uid="uid://dfttci386ohip"]
|
[gd_scene load_steps=8 format=3 uid="uid://dfttci386ohip"]
|
||||||
|
|
||||||
[ext_resource type="Script" path="res://src/equipment/balls/physics_ball/game_ball.gd" id="1_iwh2u"]
|
[ext_resource type="Script" path="res://src/equipment/balls/physics_ball/game_ball.gd" id="1_iwh2u"]
|
||||||
[ext_resource type="PhysicsMaterial" uid="uid://3bih72l068ic" path="res://src/equipment/balls/physics_ball/normal_physics.tres" id="1_l23pw"]
|
[ext_resource type="PhysicsMaterial" uid="uid://3bih72l068ic" path="res://src/equipment/balls/physics_ball/normal_physics.tres" id="1_l23pw"]
|
||||||
|
@ -27,40 +27,9 @@ rings = 6
|
||||||
[sub_resource type="SphereShape3D" id="SphereShape3D_0hvq6"]
|
[sub_resource type="SphereShape3D" id="SphereShape3D_0hvq6"]
|
||||||
radius = 0.05
|
radius = 0.05
|
||||||
|
|
||||||
[sub_resource type="GDScript" id="GDScript_p4v7o"]
|
|
||||||
resource_name = "debug_draw"
|
|
||||||
script/source = "extends Control
|
|
||||||
|
|
||||||
const COLOR_X := Color(1, 0, 0)
|
|
||||||
const COLOR_Y := Color(0, 1, 0)
|
|
||||||
const COLOR_Z := Color(0, 0, 1)
|
|
||||||
const WIDTH := 4
|
|
||||||
|
|
||||||
@onready var physics_ball: GameBall = $\"..\"
|
|
||||||
|
|
||||||
|
|
||||||
func _process(_delta: float) -> void:
|
|
||||||
if visible:
|
|
||||||
queue_redraw()
|
|
||||||
|
|
||||||
|
|
||||||
func _draw() -> void:
|
|
||||||
if physics_ball._last_contact_normal != null:
|
|
||||||
var camera := get_viewport().get_camera_3d()
|
|
||||||
var start := camera.unproject_position(physics_ball.global_position)
|
|
||||||
var basis := physics_ball.get_reoriented_basis()
|
|
||||||
var end_x := camera.unproject_position(physics_ball.global_position + basis.x)
|
|
||||||
var end_y := camera.unproject_position(physics_ball.global_position + basis.y)
|
|
||||||
var end_z := camera.unproject_position(physics_ball.global_position + basis.z)
|
|
||||||
draw_line(start, end_x, COLOR_X, WIDTH)
|
|
||||||
draw_line(start, end_y, COLOR_Y, WIDTH)
|
|
||||||
draw_line(start, end_z, COLOR_Z, WIDTH)
|
|
||||||
"
|
|
||||||
|
|
||||||
[node name="PhysicsBall" type="RigidBody3D"]
|
[node name="PhysicsBall" type="RigidBody3D"]
|
||||||
mass = 0.05
|
mass = 0.05
|
||||||
physics_material_override = ExtResource("1_l23pw")
|
physics_material_override = ExtResource("1_l23pw")
|
||||||
freeze = true
|
|
||||||
continuous_cd = true
|
continuous_cd = true
|
||||||
contact_monitor = true
|
contact_monitor = true
|
||||||
max_contacts_reported = 1
|
max_contacts_reported = 1
|
||||||
|
@ -75,16 +44,3 @@ mesh = SubResource("SphereMesh_y0d13")
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="."]
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="."]
|
||||||
shape = SubResource("SphereShape3D_0hvq6")
|
shape = SubResource("SphereShape3D_0hvq6")
|
||||||
|
|
||||||
[node name="DebugDraw" type="Control" parent="."]
|
|
||||||
unique_name_in_owner = true
|
|
||||||
visible = false
|
|
||||||
layout_mode = 3
|
|
||||||
anchors_preset = 15
|
|
||||||
anchor_right = 1.0
|
|
||||||
anchor_bottom = 1.0
|
|
||||||
grow_horizontal = 2
|
|
||||||
grow_vertical = 2
|
|
||||||
script = SubResource("GDScript_p4v7o")
|
|
||||||
|
|
||||||
[connection signal="sleeping_state_changed" from="." to="." method="_on_sleeping_state_changed"]
|
|
||||||
|
|
|
@ -1,16 +0,0 @@
|
||||||
extends GameBall
|
|
||||||
## The plasma ball sticks to the first surface it hits
|
|
||||||
|
|
||||||
@onready var manual_sleep_timer: Timer = %ManualSleepTimer
|
|
||||||
|
|
||||||
|
|
||||||
func _on_body_entered(_body: Node) -> void:
|
|
||||||
print_debug("Plasma ball stuck to ", _body)
|
|
||||||
# Freeze physics as soon as we hit something
|
|
||||||
freeze = true
|
|
||||||
sleeping = true
|
|
||||||
manual_sleep_timer.start()
|
|
||||||
|
|
||||||
|
|
||||||
func _fire_sleep_signal() -> void:
|
|
||||||
sleeping_state_changed.emit()
|
|
|
@ -1,64 +0,0 @@
|
||||||
[gd_scene load_steps=11 format=3 uid="uid://dcqxlbsrubapk"]
|
|
||||||
|
|
||||||
[ext_resource type="PackedScene" uid="uid://dfttci386ohip" path="res://src/equipment/balls/physics_ball/physics_ball.tscn" id="1_yh4fp"]
|
|
||||||
[ext_resource type="Texture2D" uid="uid://c47bkx508biqr" path="res://assets/sprites/particles/plasma.png" id="2_8fdyx"]
|
|
||||||
[ext_resource type="Script" path="res://src/equipment/balls/plasma_ball/plasma_ball.gd" id="2_pdts3"]
|
|
||||||
|
|
||||||
[sub_resource type="Curve" id="Curve_kabhn"]
|
|
||||||
max_value = 2.0
|
|
||||||
_data = [Vector2(0, 2), 0.0, 0.0, 0, 0, Vector2(1, 0), 0.0, 0.0, 0, 0]
|
|
||||||
point_count = 2
|
|
||||||
|
|
||||||
[sub_resource type="CurveTexture" id="CurveTexture_oxhrr"]
|
|
||||||
curve = SubResource("Curve_kabhn")
|
|
||||||
|
|
||||||
[sub_resource type="Curve" id="Curve_77lhu"]
|
|
||||||
_data = [Vector2(0, 1), 0.0, 0.0, 0, 0, Vector2(0.249135, 1), 0.0, 0.0, 0, 0, Vector2(1, 0.598878), -0.922125, -0.922125, 0, 0]
|
|
||||||
point_count = 3
|
|
||||||
|
|
||||||
[sub_resource type="CurveTexture" id="CurveTexture_vfusk"]
|
|
||||||
curve = SubResource("Curve_77lhu")
|
|
||||||
|
|
||||||
[sub_resource type="ParticleProcessMaterial" id="ParticleProcessMaterial_uffe8"]
|
|
||||||
angle_min = -720.0
|
|
||||||
angle_max = 720.0
|
|
||||||
direction = Vector3(0, 1, 0)
|
|
||||||
spread = 10.0
|
|
||||||
initial_velocity_max = 0.1
|
|
||||||
gravity = Vector3(0, 2, 0)
|
|
||||||
scale_curve = SubResource("CurveTexture_vfusk")
|
|
||||||
emission_curve = SubResource("CurveTexture_oxhrr")
|
|
||||||
|
|
||||||
[sub_resource type="StandardMaterial3D" id="StandardMaterial3D_7ptri"]
|
|
||||||
transparency = 1
|
|
||||||
vertex_color_use_as_albedo = true
|
|
||||||
albedo_color = Color(0.48, 1, 1, 0.384314)
|
|
||||||
albedo_texture = ExtResource("2_8fdyx")
|
|
||||||
emission_enabled = true
|
|
||||||
emission = Color(0.42, 1, 1, 1)
|
|
||||||
billboard_mode = 3
|
|
||||||
billboard_keep_scale = true
|
|
||||||
particles_anim_h_frames = 1
|
|
||||||
particles_anim_v_frames = 1
|
|
||||||
particles_anim_loop = false
|
|
||||||
grow_amount = -0.6
|
|
||||||
|
|
||||||
[sub_resource type="QuadMesh" id="QuadMesh_go8iw"]
|
|
||||||
material = SubResource("StandardMaterial3D_7ptri")
|
|
||||||
size = Vector2(0.4, 0.4)
|
|
||||||
|
|
||||||
[node name="PlasmaBall" instance=ExtResource("1_yh4fp")]
|
|
||||||
script = ExtResource("2_pdts3")
|
|
||||||
|
|
||||||
[node name="PlasmaFireEffect" type="GPUParticles3D" parent="BallMesh" index="0"]
|
|
||||||
amount = 20
|
|
||||||
lifetime = 0.6
|
|
||||||
process_material = SubResource("ParticleProcessMaterial_uffe8")
|
|
||||||
draw_pass_1 = SubResource("QuadMesh_go8iw")
|
|
||||||
|
|
||||||
[node name="ManualSleepTimer" type="Timer" parent="." index="3"]
|
|
||||||
unique_name_in_owner = true
|
|
||||||
one_shot = true
|
|
||||||
|
|
||||||
[connection signal="body_entered" from="." to="." method="_on_body_entered"]
|
|
||||||
[connection signal="timeout" from="ManualSleepTimer" to="." method="_fire_sleep_signal"]
|
|
|
@ -99,12 +99,3 @@ func _process(_delta: float) -> void:
|
||||||
|
|
||||||
if not _loading_resources and loading_screen.visible:
|
if not _loading_resources and loading_screen.visible:
|
||||||
loader_transition.play("fade_out")
|
loader_transition.play("fade_out")
|
||||||
|
|
||||||
|
|
||||||
func _notification(what: int) -> void:
|
|
||||||
if what == NOTIFICATION_WM_CLOSE_REQUEST:
|
|
||||||
# Handle close request here
|
|
||||||
# TODO: save?
|
|
||||||
get_tree().quit()
|
|
||||||
elif what == NOTIFICATION_CRASH:
|
|
||||||
print_debug("CRASHING!")
|
|
||||||
|
|
|
@ -162,7 +162,6 @@ libraries = {
|
||||||
|
|
||||||
[node name="Rumbler" type="Control" parent="RootControl"]
|
[node name="Rumbler" type="Control" parent="RootControl"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
process_mode = 1
|
|
||||||
layout_mode = 1
|
layout_mode = 1
|
||||||
anchors_preset = 15
|
anchors_preset = 15
|
||||||
anchor_right = 1.0
|
anchor_right = 1.0
|
||||||
|
|
|
@ -6,6 +6,7 @@ signal ball_collision(ball: GameBall)
|
||||||
@export var ignored_balls: Array[GameBall] = []
|
@export var ignored_balls: Array[GameBall] = []
|
||||||
|
|
||||||
@onready var shot_setup: ShotSetup = $".."
|
@onready var shot_setup: ShotSetup = $".."
|
||||||
|
@onready var physics_ball: GameBall = %PhysicsBall
|
||||||
|
|
||||||
|
|
||||||
func _on_ball_entered(ball: GameBall) -> void:
|
func _on_ball_entered(ball: GameBall) -> void:
|
||||||
|
|
|
@ -22,7 +22,6 @@ const ZOOM_MAX := 12.0
|
||||||
const ARROW_ACCELERATION := 8.0
|
const ARROW_ACCELERATION := 8.0
|
||||||
const PLAYER_ACCELERATION := 2.0
|
const PLAYER_ACCELERATION := 2.0
|
||||||
|
|
||||||
const FREE_CAM_GIMBAL_TWEEN_TIME := 0.2
|
|
||||||
const FREE_CAM_RETURN_TIME := 0.618
|
const FREE_CAM_RETURN_TIME := 0.618
|
||||||
const BALL_RETURN_TIME := 0.618
|
const BALL_RETURN_TIME := 0.618
|
||||||
const CAMERA_SNAP_TIME := 0.3
|
const CAMERA_SNAP_TIME := 0.3
|
||||||
|
@ -46,6 +45,8 @@ const WATER_DAMAGE := 10.0
|
||||||
@export var base_curve := 0.0
|
@export var base_curve := 0.0
|
||||||
|
|
||||||
@export_category("Debug")
|
@export_category("Debug")
|
||||||
|
## When enabled, the game will pause and enter free cam mode when the ball has a collision.
|
||||||
|
@export var debug_ball_impact := false
|
||||||
## When enabled, ignore curve meter and hit a perfect shot every time.
|
## When enabled, ignore curve meter and hit a perfect shot every time.
|
||||||
@export var perfect_aim := false
|
@export var perfect_aim := false
|
||||||
## Keep projection visible
|
## Keep projection visible
|
||||||
|
@ -78,7 +79,9 @@ var phase: Phase = Phase.FINISHED:
|
||||||
_on_phase_change(value)
|
_on_phase_change(value)
|
||||||
phase = value
|
phase = value
|
||||||
|
|
||||||
var hud: ShotHUD
|
var hud: ShotHUD:
|
||||||
|
get:
|
||||||
|
return world.ui.shot_hud if world and world.ui else null
|
||||||
|
|
||||||
var club: Club.Type:
|
var club: Club.Type:
|
||||||
set(value):
|
set(value):
|
||||||
|
@ -124,8 +127,7 @@ var _tracking_camera: OrbitalCamera
|
||||||
@onready var shot_projection: ProjectileArc = %ShotProjection
|
@onready var shot_projection: ProjectileArc = %ShotProjection
|
||||||
|
|
||||||
@onready var ball_point: Node3D = %BallPoint
|
@onready var ball_point: Node3D = %BallPoint
|
||||||
# @onready var game_ball: GameBall = %PhysicsBall
|
@onready var physics_ball: GameBall = %PhysicsBall
|
||||||
@onready var game_ball: GameBall = %PlasmaBall
|
|
||||||
|
|
||||||
@onready var drive_ref: RayCast3D = %DriveRef
|
@onready var drive_ref: RayCast3D = %DriveRef
|
||||||
@onready var drive_arrow: Node3D = %DriveArrow
|
@onready var drive_arrow: Node3D = %DriveArrow
|
||||||
|
@ -143,6 +145,8 @@ var _tracking_camera: OrbitalCamera
|
||||||
@onready var camera_distance := zoom.position.z:
|
@onready var camera_distance := zoom.position.z:
|
||||||
set = _set_camera_distance
|
set = _set_camera_distance
|
||||||
|
|
||||||
|
@onready var phys_ball_scene := preload("res://src/equipment/balls/physics_ball/physics_ball.tscn")
|
||||||
|
|
||||||
@onready var world: World = get_tree().get_first_node_in_group(World.group)
|
@onready var world: World = get_tree().get_first_node_in_group(World.group)
|
||||||
@onready var game: Game = get_tree().get_first_node_in_group(Game.group)
|
@onready var game: Game = get_tree().get_first_node_in_group(Game.group)
|
||||||
|
|
||||||
|
@ -151,13 +155,15 @@ var _tracking_camera: OrbitalCamera
|
||||||
static var scene := preload("res://src/player/shot_setup/shot_setup.tscn")
|
static var scene := preload("res://src/player/shot_setup/shot_setup.tscn")
|
||||||
|
|
||||||
|
|
||||||
func _ready() -> void:
|
func _init_deferred() -> void:
|
||||||
# Create & set up HUD
|
# Set up HUD
|
||||||
hud = ShotHUD.create(player)
|
|
||||||
world.ui.add_player_hud(hud)
|
|
||||||
club = initial_club
|
club = initial_club
|
||||||
|
|
||||||
|
|
||||||
|
func _ready() -> void:
|
||||||
|
_init_deferred.call_deferred()
|
||||||
|
|
||||||
|
|
||||||
func _set_camera_distance(value: float) -> void:
|
func _set_camera_distance(value: float) -> void:
|
||||||
var tween := get_tree().create_tween()
|
var tween := get_tree().create_tween()
|
||||||
tween.tween_property(zoom, "position:z", value, ZOOM_LENGTH).set_trans(Tween.TRANS_SINE)
|
tween.tween_property(zoom, "position:z", value, ZOOM_LENGTH).set_trans(Tween.TRANS_SINE)
|
||||||
|
@ -227,15 +233,15 @@ func take_shot() -> void:
|
||||||
Transform3D.IDENTITY.scaled(Vector3.ONE * impulse.length()).looking_at(impulse)
|
Transform3D.IDENTITY.scaled(Vector3.ONE * impulse.length()).looking_at(impulse)
|
||||||
)
|
)
|
||||||
|
|
||||||
game_ball.freeze = false
|
physics_ball.freeze = false
|
||||||
game_ball.apply_central_impulse(impulse)
|
physics_ball.apply_central_impulse(impulse)
|
||||||
|
|
||||||
|
|
||||||
## Make the shot projection widget visible, with animated transition
|
## Make the shot projection widget visible, with animated transition
|
||||||
func _show_shot_projection() -> void:
|
func _show_shot_projection() -> void:
|
||||||
shot_projection.initial_speed = 1
|
shot_projection.initial_speed = 1
|
||||||
shot_projection.basis = shot_ref.basis.orthonormalized()
|
shot_projection.basis = shot_ref.basis.orthonormalized()
|
||||||
var shot_speed := get_shot_impulse(1.0).length() / game_ball.mass
|
var shot_speed := get_shot_impulse(1.0).length() / physics_ball.mass
|
||||||
var tween := get_tree().create_tween()
|
var tween := get_tree().create_tween()
|
||||||
tween.tween_property(shot_projection, "initial_speed", shot_speed, CAMERA_SNAP_TIME).set_trans(
|
tween.tween_property(shot_projection, "initial_speed", shot_speed, CAMERA_SNAP_TIME).set_trans(
|
||||||
Tween.TRANS_QUAD
|
Tween.TRANS_QUAD
|
||||||
|
@ -249,9 +255,6 @@ func insert_free_cam() -> void:
|
||||||
hud.hide_hud()
|
hud.hide_hud()
|
||||||
_free_camera = FreeCamera.create(camera)
|
_free_camera = FreeCamera.create(camera)
|
||||||
add_sibling(_free_camera)
|
add_sibling(_free_camera)
|
||||||
# Un-gimbal-lock ourselves: quickly tween Z rotation to 0
|
|
||||||
var tween := get_tree().create_tween()
|
|
||||||
tween.tween_property(_free_camera, "rotation:z", 0, FREE_CAM_GIMBAL_TWEEN_TIME)
|
|
||||||
control_disabled = true
|
control_disabled = true
|
||||||
camera.current = false
|
camera.current = false
|
||||||
|
|
||||||
|
@ -272,12 +275,12 @@ func return_free_cam() -> void:
|
||||||
|
|
||||||
|
|
||||||
func return_ball() -> void:
|
func return_ball() -> void:
|
||||||
game_ball.freeze = true
|
physics_ball.freeze = true
|
||||||
var tween := get_tree().create_tween()
|
var tween := get_tree().create_tween()
|
||||||
(
|
(
|
||||||
tween
|
tween
|
||||||
. tween_property(
|
. tween_property(
|
||||||
game_ball,
|
physics_ball,
|
||||||
"global_transform",
|
"global_transform",
|
||||||
ball_point.global_transform,
|
ball_point.global_transform,
|
||||||
BALL_RETURN_TIME,
|
BALL_RETURN_TIME,
|
||||||
|
@ -288,22 +291,14 @@ func return_ball() -> void:
|
||||||
|
|
||||||
|
|
||||||
func travel_to_ball() -> void:
|
func travel_to_ball() -> void:
|
||||||
game_ball.freeze = true
|
physics_ball.freeze = true
|
||||||
global_position = game_ball.global_position
|
global_position = physics_ball.global_position
|
||||||
|
physics_ball.global_transform = ball_point.global_transform
|
||||||
# Re-orient to the ball's last contact normal if there is one.
|
|
||||||
# Normally this will just be Vector3.UP or something close to it.
|
|
||||||
direction.rotation.y = 0
|
|
||||||
_target_rotation.y = 0
|
|
||||||
global_basis = game_ball.get_reoriented_basis()
|
|
||||||
print_debug("REORIENTED BASIS: ", global_basis)
|
|
||||||
|
|
||||||
game_ball.global_transform = ball_point.global_transform
|
|
||||||
|
|
||||||
|
|
||||||
func start_shot_track() -> void:
|
func start_shot_track() -> void:
|
||||||
if phase == Phase.SHOT:
|
if phase == Phase.SHOT:
|
||||||
_tracking_camera = OrbitalCamera.create(game_ball)
|
_tracking_camera = OrbitalCamera.create(physics_ball)
|
||||||
_tracking_camera.rotation.y = randf_range(0.0, TAU)
|
_tracking_camera.rotation.y = randf_range(0.0, TAU)
|
||||||
add_sibling(_tracking_camera)
|
add_sibling(_tracking_camera)
|
||||||
_tracking_camera.global_transform = ball_point.global_transform
|
_tracking_camera.global_transform = ball_point.global_transform
|
||||||
|
@ -331,7 +326,7 @@ func _on_club_change(new_club_type: Club.Type) -> void:
|
||||||
wedge_arrow.hide()
|
wedge_arrow.hide()
|
||||||
iron_arrow.hide()
|
iron_arrow.hide()
|
||||||
putt_arrow.hide()
|
putt_arrow.hide()
|
||||||
game_ball.iron_ball = false
|
physics_ball.iron_ball = false
|
||||||
hud.club_selector.value = new_club_type
|
hud.club_selector.value = new_club_type
|
||||||
# TODO club change animation
|
# TODO club change animation
|
||||||
character.hold_right(new_club.get_model())
|
character.hold_right(new_club.get_model())
|
||||||
|
@ -348,7 +343,7 @@ func _on_club_change(new_club_type: Club.Type) -> void:
|
||||||
Club.Type.IRON:
|
Club.Type.IRON:
|
||||||
shot_ref = iron_ref
|
shot_ref = iron_ref
|
||||||
iron_arrow.show()
|
iron_arrow.show()
|
||||||
game_ball.iron_ball = true
|
physics_ball.iron_ball = true
|
||||||
Club.Type.SPECIAL:
|
Club.Type.SPECIAL:
|
||||||
# TODO figure this out
|
# TODO figure this out
|
||||||
shot_ref = drive_ref
|
shot_ref = drive_ref
|
||||||
|
@ -361,6 +356,7 @@ func _on_phase_change(new_phase: Phase) -> void:
|
||||||
print_debug("Player ", player.name, ": change to ", Phase.keys()[new_phase])
|
print_debug("Player ", player.name, ": change to ", Phase.keys()[new_phase])
|
||||||
match new_phase:
|
match new_phase:
|
||||||
Phase.AIM:
|
Phase.AIM:
|
||||||
|
hud.set_state_for_player(player)
|
||||||
hud.show_hud()
|
hud.show_hud()
|
||||||
if not arrow.visible:
|
if not arrow.visible:
|
||||||
arrow_animation.play("show")
|
arrow_animation.play("show")
|
||||||
|
@ -397,6 +393,7 @@ func _on_phase_change(new_phase: Phase) -> void:
|
||||||
Phase.FINISHED:
|
Phase.FINISHED:
|
||||||
hud.power_bar.hide()
|
hud.power_bar.hide()
|
||||||
hud.curve_bar.hide()
|
hud.curve_bar.hide()
|
||||||
|
travel_to_ball()
|
||||||
finished.emit(self)
|
finished.emit(self)
|
||||||
|
|
||||||
|
|
||||||
|
@ -473,14 +470,14 @@ func _process(delta: float) -> void:
|
||||||
# TODO set power gauge parameters if needed
|
# TODO set power gauge parameters if needed
|
||||||
character.start_upswing()
|
character.start_upswing()
|
||||||
hud.start_power_bar()
|
hud.start_power_bar()
|
||||||
if Input.is_action_just_pressed("shot_cancel"):
|
if Input.is_action_just_pressed("ui_cancel"):
|
||||||
hud.reset_power_bar()
|
hud.reset_power_bar()
|
||||||
phase = Phase.AIM
|
phase = Phase.AIM
|
||||||
if Input.is_action_just_released("shot_accept") and shot_power > 0:
|
if Input.is_action_just_released("shot_accept") and shot_power > 0:
|
||||||
hud.stop_power_bar()
|
hud.stop_power_bar()
|
||||||
phase = Phase.CURVE_ADJUST
|
phase = Phase.CURVE_ADJUST
|
||||||
Phase.CURVE_ADJUST:
|
Phase.CURVE_ADJUST:
|
||||||
if Input.is_action_just_pressed("shot_cancel"):
|
if Input.is_action_just_pressed("ui_cancel"):
|
||||||
hud.reset_curve_bar()
|
hud.reset_curve_bar()
|
||||||
phase = Phase.POWER_ADJUST
|
phase = Phase.POWER_ADJUST
|
||||||
if Input.is_action_just_pressed("shot_accept"):
|
if Input.is_action_just_pressed("shot_accept"):
|
||||||
|
@ -496,21 +493,33 @@ func _process(delta: float) -> void:
|
||||||
phase = Phase.AIM
|
phase = Phase.AIM
|
||||||
|
|
||||||
|
|
||||||
func _on_ball_sleeping_state_changed() -> void:
|
func _on_physics_ball_sleeping_state_changed() -> void:
|
||||||
if game_ball.sleeping and phase == Phase.SHOT:
|
if physics_ball.sleeping and phase == Phase.SHOT:
|
||||||
travel_to_ball()
|
|
||||||
end_shot_track()
|
end_shot_track()
|
||||||
|
|
||||||
|
|
||||||
func _on_ball_entered_water() -> void:
|
func _on_ball_entered_water() -> void:
|
||||||
# Should only be possible during SHOT phase, but let's check just to be sure...
|
# Should only be possible during SHOT phase, but let's check just to be sure...
|
||||||
if phase == Phase.SHOT:
|
if phase == Phase.SHOT:
|
||||||
game_ball.freeze = true
|
physics_ball.freeze = true
|
||||||
hud.play_wasted_animation()
|
hud.play_wasted_animation()
|
||||||
player.life -= WATER_DAMAGE
|
player.life -= WATER_DAMAGE
|
||||||
ball_return_timer.start(WASTED_BALL_RETURN_DELAY)
|
ball_return_timer.start(WASTED_BALL_RETURN_DELAY)
|
||||||
|
|
||||||
|
|
||||||
|
func _on_physics_ball_body_entered(_body: Node) -> void:
|
||||||
|
print_debug("BONK!")
|
||||||
|
if debug_ball_impact:
|
||||||
|
get_tree().paused = true
|
||||||
|
var snap_point: Node3D = camera
|
||||||
|
if _tracking_camera:
|
||||||
|
snap_point = _tracking_camera
|
||||||
|
_free_camera = FreeCamera.create(snap_point)
|
||||||
|
add_sibling(_free_camera)
|
||||||
|
control_disabled = true
|
||||||
|
camera.current = false
|
||||||
|
|
||||||
|
|
||||||
func _on_ball_return_timer_timeout() -> void:
|
func _on_ball_return_timer_timeout() -> void:
|
||||||
return_ball()
|
return_ball()
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
[gd_scene load_steps=19 format=3 uid="uid://cy7t2tc4y3b4"]
|
[gd_scene load_steps=19 format=3 uid="uid://cy7t2tc4y3b4"]
|
||||||
|
|
||||||
[ext_resource type="Script" path="res://src/player/shot_setup/shot_setup.gd" id="1_r6ei4"]
|
[ext_resource type="Script" path="res://src/player/shot_setup/shot_setup.gd" id="1_r6ei4"]
|
||||||
|
[ext_resource type="PackedScene" uid="uid://dfttci386ohip" path="res://src/equipment/balls/physics_ball/physics_ball.tscn" id="2_1i5j5"]
|
||||||
[ext_resource type="PackedScene" uid="uid://c2k88ns0h5ie1" path="res://src/ui/3d/arrow/arrow.tscn" id="2_s70wl"]
|
[ext_resource type="PackedScene" uid="uid://c2k88ns0h5ie1" path="res://src/ui/3d/arrow/arrow.tscn" id="2_s70wl"]
|
||||||
[ext_resource type="PackedScene" uid="uid://dcqxlbsrubapk" path="res://src/equipment/balls/plasma_ball/plasma_ball.tscn" id="3_8dte7"]
|
|
||||||
[ext_resource type="PackedScene" uid="uid://1s3gywmoi20e" path="res://src/characters/player_characters/gfolf_girl/gfolf_girl.tscn" id="3_e4aur"]
|
[ext_resource type="PackedScene" uid="uid://1s3gywmoi20e" path="res://src/characters/player_characters/gfolf_girl/gfolf_girl.tscn" id="3_e4aur"]
|
||||||
[ext_resource type="PackedScene" uid="uid://fht6j87o8ecr" path="res://src/ui/3d/projectile_arc/projectile_arc.tscn" id="4_ry2ho"]
|
[ext_resource type="PackedScene" uid="uid://fht6j87o8ecr" path="res://src/ui/3d/projectile_arc/projectile_arc.tscn" id="4_ry2ho"]
|
||||||
[ext_resource type="PackedScene" uid="uid://dbdul15c4oblg" path="res://src/ui/3d/projected_target.tscn" id="6_mynqj"]
|
[ext_resource type="PackedScene" uid="uid://dbdul15c4oblg" path="res://src/ui/3d/projected_target.tscn" id="6_mynqj"]
|
||||||
|
@ -214,8 +214,10 @@ script = ExtResource("1_r6ei4")
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0.08, 0)
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0.08, 0)
|
||||||
|
|
||||||
[node name="PlasmaBall" parent="BallPoint" instance=ExtResource("3_8dte7")]
|
[node name="PhysicsBall" parent="BallPoint" instance=ExtResource("2_1i5j5")]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
|
transform = Transform3D(1, 0, 0, 0, -4.37114e-08, -1, 0, 1, -4.37114e-08, 0, 0, 0)
|
||||||
|
freeze = true
|
||||||
|
|
||||||
[node name="BallImpulseDebug" type="Node3D" parent="BallPoint"]
|
[node name="BallImpulseDebug" type="Node3D" parent="BallPoint"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
|
@ -232,9 +234,6 @@ unique_name_in_owner = true
|
||||||
[node name="GfolfGirl" parent="PlayerPivot" instance=ExtResource("3_e4aur")]
|
[node name="GfolfGirl" parent="PlayerPivot" instance=ExtResource("3_e4aur")]
|
||||||
transform = Transform3D(-4.37114e-08, 0, 1, 0, 1, 0, -1, 0, -4.37114e-08, -0.555968, 0, 0.0999683)
|
transform = Transform3D(-4.37114e-08, 0, 1, 0, 1, 0, -1, 0, -4.37114e-08, -0.555968, 0, 0.0999683)
|
||||||
|
|
||||||
[node name="DemoCamera" type="Camera3D" parent="PlayerPivot" groups=["DemoCamera"]]
|
|
||||||
transform = Transform3D(-0.124487, 0.584637, 0.801687, 0, 0.807972, -0.589221, -0.992221, -0.0733503, -0.100582, 0.395614, 0.0284514, -0.0394773)
|
|
||||||
|
|
||||||
[node name="Direction" type="Node3D" parent="."]
|
[node name="Direction" type="Node3D" parent="."]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
|
|
||||||
|
@ -350,7 +349,7 @@ visible = false
|
||||||
initial_speed = 50.0
|
initial_speed = 50.0
|
||||||
time_step = 0.01
|
time_step = 0.01
|
||||||
max_steps = 800
|
max_steps = 800
|
||||||
excluded_bodies = [NodePath("../../BallPoint/PlasmaBall")]
|
excluded_bodies = [NodePath("../../BallPoint/PhysicsBall")]
|
||||||
|
|
||||||
[node name="ProjectedTarget" parent="ArrowPivot/ShotProjection" instance=ExtResource("6_mynqj")]
|
[node name="ProjectedTarget" parent="ArrowPivot/ShotProjection" instance=ExtResource("6_mynqj")]
|
||||||
|
|
||||||
|
@ -367,13 +366,14 @@ one_shot = true
|
||||||
|
|
||||||
[node name="Hitbox" type="Area3D" parent="." node_paths=PackedStringArray("ignored_balls")]
|
[node name="Hitbox" type="Area3D" parent="." node_paths=PackedStringArray("ignored_balls")]
|
||||||
script = ExtResource("7_uh8kn")
|
script = ExtResource("7_uh8kn")
|
||||||
ignored_balls = [NodePath("../BallPoint/PlasmaBall")]
|
ignored_balls = [NodePath("../BallPoint/PhysicsBall")]
|
||||||
|
|
||||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="Hitbox"]
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="Hitbox"]
|
||||||
shape = SubResource("SphereShape3D_xvvdi")
|
shape = SubResource("SphereShape3D_xvvdi")
|
||||||
|
|
||||||
[connection signal="entered_water" from="BallPoint/PlasmaBall" to="." method="_on_ball_entered_water"]
|
[connection signal="body_entered" from="BallPoint/PhysicsBall" to="." method="_on_physics_ball_body_entered"]
|
||||||
[connection signal="sleeping_state_changed" from="BallPoint/PlasmaBall" to="." method="_on_ball_sleeping_state_changed"]
|
[connection signal="entered_water" from="BallPoint/PhysicsBall" to="." method="_on_ball_entered_water"]
|
||||||
|
[connection signal="sleeping_state_changed" from="BallPoint/PhysicsBall" to="." method="_on_physics_ball_sleeping_state_changed"]
|
||||||
[connection signal="timeout" from="BallReturnTimer" to="." method="_on_ball_return_timer_timeout"]
|
[connection signal="timeout" from="BallReturnTimer" to="." method="_on_ball_return_timer_timeout"]
|
||||||
[connection signal="ball_collision" from="Hitbox" to="." method="_on_hitbox_ball_collision"]
|
[connection signal="ball_collision" from="Hitbox" to="." method="_on_hitbox_ball_collision"]
|
||||||
[connection signal="body_entered" from="Hitbox" to="Hitbox" method="_on_body_entered"]
|
[connection signal="body_entered" from="Hitbox" to="Hitbox" method="_on_body_entered"]
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
[ext_resource type="Material" uid="uid://cift6p0wn1oce" path="res://assets/materials/guard_rail.tres" id="2_1s4wy"]
|
[ext_resource type="Material" uid="uid://cift6p0wn1oce" path="res://assets/materials/guard_rail.tres" id="2_1s4wy"]
|
||||||
[ext_resource type="PlaneMesh" uid="uid://bdcmgvgpj1e0w" path="res://src/props/scenery/highway/guard_rail/guard_rail_post_mesh.tres" id="3_hha2c"]
|
[ext_resource type="PlaneMesh" uid="uid://bdcmgvgpj1e0w" path="res://src/props/scenery/highway/guard_rail/guard_rail_post_mesh.tres" id="3_hha2c"]
|
||||||
|
|
||||||
[sub_resource type="MultiMesh" id="MultiMesh_1o4mq"]
|
[sub_resource type="MultiMesh" id="MultiMesh_suiix"]
|
||||||
transform_format = 1
|
transform_format = 1
|
||||||
mesh = ExtResource("3_hha2c")
|
mesh = ExtResource("3_hha2c")
|
||||||
|
|
||||||
|
@ -42,6 +42,6 @@ path_joined = false
|
||||||
material = ExtResource("2_1s4wy")
|
material = ExtResource("2_1s4wy")
|
||||||
|
|
||||||
[node name="PostMultiMesh" type="MultiMeshInstance3D" parent="."]
|
[node name="PostMultiMesh" type="MultiMeshInstance3D" parent="."]
|
||||||
multimesh = SubResource("MultiMesh_1o4mq")
|
multimesh = SubResource("MultiMesh_suiix")
|
||||||
|
|
||||||
[connection signal="curve_changed" from="." to="." method="_on_curve_changed"]
|
[connection signal="curve_changed" from="." to="." method="_on_curve_changed"]
|
||||||
|
|
|
@ -65,7 +65,7 @@ func _reset_position() -> void:
|
||||||
func _process(_delta: float) -> void:
|
func _process(_delta: float) -> void:
|
||||||
if _hit_lag_frames >= 0:
|
if _hit_lag_frames >= 0:
|
||||||
if _hit_lag_frames == 0:
|
if _hit_lag_frames == 0:
|
||||||
get_tree().paused = false
|
content.process_mode = Node.PROCESS_MODE_INHERIT
|
||||||
else:
|
else:
|
||||||
get_tree().paused = true
|
content.process_mode = Node.PROCESS_MODE_DISABLED
|
||||||
_hit_lag_frames -= 1
|
_hit_lag_frames -= 1
|
||||||
|
|
|
@ -1,13 +1,9 @@
|
||||||
[gd_resource type="Theme" load_steps=5 format=3 uid="uid://diodjft5u2cck"]
|
[gd_resource type="Theme" load_steps=3 format=3 uid="uid://diodjft5u2cck"]
|
||||||
|
|
||||||
[ext_resource type="FontFile" uid="uid://dsa0oh7c0h4pu" path="res://assets/fonts/Racing_Sans_One/RacingSansOne-Regular.ttf" id="1_3rv2b"]
|
[ext_resource type="FontFile" uid="uid://dsa0oh7c0h4pu" path="res://assets/fonts/Racing_Sans_One/RacingSansOne-Regular.ttf" id="1_3rv2b"]
|
||||||
[ext_resource type="FontFile" uid="uid://comihs66wounx" path="res://assets/fonts/Dokdo/Dokdo-Regular.ttf" id="1_eha6a"]
|
[ext_resource type="FontFile" uid="uid://comihs66wounx" path="res://assets/fonts/Dokdo/Dokdo-Regular.ttf" id="1_eha6a"]
|
||||||
[ext_resource type="FontFile" uid="uid://b6gxwgomstkgu" path="res://assets/fonts/Geo/Geo-Italic.ttf" id="2_5ty6u"]
|
|
||||||
[ext_resource type="FontFile" uid="uid://s4c1kf0rk2mb" path="res://assets/fonts/Geo/Geo-Regular.ttf" id="3_cee6l"]
|
|
||||||
|
|
||||||
[resource]
|
[resource]
|
||||||
default_font = ExtResource("3_cee6l")
|
|
||||||
default_font_size = 18
|
|
||||||
ClubSelectLabel/base_type = &"Label"
|
ClubSelectLabel/base_type = &"Label"
|
||||||
ClubSelectLabel/colors/font_color = Color(1, 0.933333, 0.894118, 1)
|
ClubSelectLabel/colors/font_color = Color(1, 0.933333, 0.894118, 1)
|
||||||
ClubSelectLabel/colors/font_outline_color = Color(0, 0, 0, 1)
|
ClubSelectLabel/colors/font_outline_color = Color(0, 0, 0, 1)
|
||||||
|
@ -21,13 +17,6 @@ ClubSelectLabelDisabled/base_type = &"ClubSelectLabel"
|
||||||
ClubSelectLabelDisabled/colors/font_color = Color(0.4, 0.3848, 0.376, 1)
|
ClubSelectLabelDisabled/colors/font_color = Color(0.4, 0.3848, 0.376, 1)
|
||||||
ClubSelectLabelDisabled/colors/font_outline_color = Color(0.2, 0.2, 0.2, 1)
|
ClubSelectLabelDisabled/colors/font_outline_color = Color(0.2, 0.2, 0.2, 1)
|
||||||
ClubSelectLabelDisabled/colors/font_shadow_color = Color(0.2, 0.2, 0.2, 1)
|
ClubSelectLabelDisabled/colors/font_shadow_color = Color(0.2, 0.2, 0.2, 1)
|
||||||
ClubSelectLabelDisabled/font_sizes/font_size = 84
|
|
||||||
ClubSelectLabelDisabled/fonts/font = ExtResource("1_3rv2b")
|
|
||||||
PauseMenuButton/base_type = &"Button"
|
|
||||||
PauseMenuButton/colors/font_outline_color = Color(0, 0, 0, 1)
|
|
||||||
PauseMenuButton/constants/outline_size = 6
|
|
||||||
PauseMenuButton/font_sizes/font_size = 32
|
|
||||||
PauseMenuButton/fonts/font = ExtResource("2_5ty6u")
|
|
||||||
ShotFeedback/base_type = &"RichTextLabel"
|
ShotFeedback/base_type = &"RichTextLabel"
|
||||||
ShotFeedback/colors/font_shadow_color = Color(0, 0, 0, 1)
|
ShotFeedback/colors/font_shadow_color = Color(0, 0, 0, 1)
|
||||||
ShotFeedback/constants/shadow_offset_x = 6
|
ShotFeedback/constants/shadow_offset_x = 6
|
||||||
|
|
|
@ -1,50 +0,0 @@
|
||||||
extends Control
|
|
||||||
## Menu shown in-game when the user presses pause.
|
|
||||||
|
|
||||||
@onready var menu_list: VBoxContainer = %MenuList
|
|
||||||
@onready var quit_confirm: CenterContainer = %QuitConfirm
|
|
||||||
|
|
||||||
|
|
||||||
func _ready() -> void:
|
|
||||||
print_debug("Pause menu _ready()")
|
|
||||||
Input.set_mouse_mode(Input.MOUSE_MODE_VISIBLE)
|
|
||||||
|
|
||||||
|
|
||||||
func _exit_tree() -> void:
|
|
||||||
print_debug("Pause menu _exit_tree()")
|
|
||||||
Input.set_mouse_mode(Input.MOUSE_MODE_CAPTURED)
|
|
||||||
|
|
||||||
|
|
||||||
func _unhandled_key_input(event: InputEvent) -> void:
|
|
||||||
if event.is_action_pressed("pause"):
|
|
||||||
get_viewport().set_input_as_handled()
|
|
||||||
resume()
|
|
||||||
|
|
||||||
|
|
||||||
func _unhide() -> void:
|
|
||||||
menu_list.show()
|
|
||||||
|
|
||||||
|
|
||||||
func _hide() -> void:
|
|
||||||
menu_list.hide()
|
|
||||||
|
|
||||||
|
|
||||||
func resume() -> void:
|
|
||||||
print_debug("Pause menu resume()")
|
|
||||||
queue_free()
|
|
||||||
|
|
||||||
|
|
||||||
func settings() -> void:
|
|
||||||
pass # TODO
|
|
||||||
|
|
||||||
|
|
||||||
func quit() -> void:
|
|
||||||
quit_confirm.show()
|
|
||||||
|
|
||||||
|
|
||||||
func cancel_quit() -> void:
|
|
||||||
quit_confirm.hide()
|
|
||||||
|
|
||||||
|
|
||||||
func confirm_quit() -> void:
|
|
||||||
get_tree().root.propagate_notification(NOTIFICATION_WM_CLOSE_REQUEST)
|
|
|
@ -1,111 +0,0 @@
|
||||||
[gd_scene load_steps=3 format=3 uid="uid://byvjsvavbg5xe"]
|
|
||||||
|
|
||||||
[ext_resource type="FontFile" uid="uid://b6gxwgomstkgu" path="res://assets/fonts/Geo/Geo-Italic.ttf" id="1_4nw1f"]
|
|
||||||
[ext_resource type="Script" path="res://src/ui/menus/pause_menu/pause_menu.gd" id="1_rd0j2"]
|
|
||||||
|
|
||||||
[node name="PauseMenu" type="Control"]
|
|
||||||
process_mode = 3
|
|
||||||
layout_mode = 3
|
|
||||||
anchors_preset = 15
|
|
||||||
anchor_right = 1.0
|
|
||||||
anchor_bottom = 1.0
|
|
||||||
grow_horizontal = 2
|
|
||||||
grow_vertical = 2
|
|
||||||
script = ExtResource("1_rd0j2")
|
|
||||||
|
|
||||||
[node name="Shade" type="ColorRect" parent="."]
|
|
||||||
layout_mode = 1
|
|
||||||
anchors_preset = 15
|
|
||||||
anchor_right = 1.0
|
|
||||||
anchor_bottom = 1.0
|
|
||||||
grow_horizontal = 2
|
|
||||||
grow_vertical = 2
|
|
||||||
color = Color(0, 0, 0, 0.156863)
|
|
||||||
|
|
||||||
[node name="MarginContainer" type="MarginContainer" parent="."]
|
|
||||||
layout_mode = 1
|
|
||||||
anchors_preset = 3
|
|
||||||
anchor_left = 1.0
|
|
||||||
anchor_top = 1.0
|
|
||||||
anchor_right = 1.0
|
|
||||||
anchor_bottom = 1.0
|
|
||||||
grow_horizontal = 0
|
|
||||||
grow_vertical = 0
|
|
||||||
theme_override_constants/margin_right = 160
|
|
||||||
theme_override_constants/margin_bottom = 160
|
|
||||||
|
|
||||||
[node name="MenuList" type="VBoxContainer" parent="MarginContainer"]
|
|
||||||
unique_name_in_owner = true
|
|
||||||
layout_mode = 2
|
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="MarginContainer/MenuList"]
|
|
||||||
layout_mode = 2
|
|
||||||
theme_override_colors/font_color = Color(1, 1, 1, 1)
|
|
||||||
theme_override_colors/font_outline_color = Color(0, 0, 0, 1)
|
|
||||||
theme_override_constants/outline_size = 8
|
|
||||||
theme_override_fonts/font = ExtResource("1_4nw1f")
|
|
||||||
theme_override_font_sizes/font_size = 72
|
|
||||||
text = "Paused"
|
|
||||||
|
|
||||||
[node name="ResumeButton" type="Button" parent="MarginContainer/MenuList"]
|
|
||||||
layout_mode = 2
|
|
||||||
theme_type_variation = &"PauseMenuButton"
|
|
||||||
text = "Resume"
|
|
||||||
|
|
||||||
[node name="SettingsButton" type="Button" parent="MarginContainer/MenuList"]
|
|
||||||
layout_mode = 2
|
|
||||||
theme_type_variation = &"PauseMenuButton"
|
|
||||||
text = "Settings"
|
|
||||||
|
|
||||||
[node name="QuitButton" type="Button" parent="MarginContainer/MenuList"]
|
|
||||||
layout_mode = 2
|
|
||||||
theme_type_variation = &"PauseMenuButton"
|
|
||||||
theme_override_colors/font_color = Color(1, 0.36, 0.36, 1)
|
|
||||||
text = "Quit"
|
|
||||||
|
|
||||||
[node name="QuitConfirm" type="CenterContainer" parent="."]
|
|
||||||
unique_name_in_owner = true
|
|
||||||
visible = false
|
|
||||||
layout_mode = 1
|
|
||||||
anchors_preset = 15
|
|
||||||
anchor_right = 1.0
|
|
||||||
anchor_bottom = 1.0
|
|
||||||
grow_horizontal = 2
|
|
||||||
grow_vertical = 2
|
|
||||||
|
|
||||||
[node name="PanelContainer" type="PanelContainer" parent="QuitConfirm"]
|
|
||||||
layout_mode = 2
|
|
||||||
|
|
||||||
[node name="MarginContainer" type="MarginContainer" parent="QuitConfirm/PanelContainer"]
|
|
||||||
layout_mode = 2
|
|
||||||
theme_override_constants/margin_left = 8
|
|
||||||
theme_override_constants/margin_top = 8
|
|
||||||
theme_override_constants/margin_right = 8
|
|
||||||
theme_override_constants/margin_bottom = 8
|
|
||||||
|
|
||||||
[node name="VBoxContainer" type="VBoxContainer" parent="QuitConfirm/PanelContainer/MarginContainer"]
|
|
||||||
layout_mode = 2
|
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="QuitConfirm/PanelContainer/MarginContainer/VBoxContainer"]
|
|
||||||
layout_mode = 2
|
|
||||||
text = "Quit to desktop?"
|
|
||||||
|
|
||||||
[node name="HBoxContainer" type="HBoxContainer" parent="QuitConfirm/PanelContainer/MarginContainer/VBoxContainer"]
|
|
||||||
layout_mode = 2
|
|
||||||
theme_override_constants/separation = 16
|
|
||||||
|
|
||||||
[node name="CancelButton" type="Button" parent="QuitConfirm/PanelContainer/MarginContainer/VBoxContainer/HBoxContainer"]
|
|
||||||
layout_mode = 2
|
|
||||||
size_flags_horizontal = 3
|
|
||||||
text = "Cancel"
|
|
||||||
|
|
||||||
[node name="ConfirmQuitButton" type="Button" parent="QuitConfirm/PanelContainer/MarginContainer/VBoxContainer/HBoxContainer"]
|
|
||||||
layout_mode = 2
|
|
||||||
size_flags_horizontal = 3
|
|
||||||
text = "Quit"
|
|
||||||
|
|
||||||
[connection signal="pressed" from="MarginContainer/MenuList/ResumeButton" to="." method="resume"]
|
|
||||||
[connection signal="pressed" from="MarginContainer/MenuList/SettingsButton" to="." method="settings"]
|
|
||||||
[connection signal="pressed" from="MarginContainer/MenuList/QuitButton" to="." method="quit"]
|
|
||||||
[connection signal="pressed" from="QuitConfirm/PanelContainer/MarginContainer/VBoxContainer/HBoxContainer/CancelButton" to="." method="cancel_quit"]
|
|
||||||
[connection signal="pressed" from="QuitConfirm/PanelContainer/MarginContainer/VBoxContainer/HBoxContainer/ConfirmQuitButton" to="." method="confirm_quit"]
|
|
|
@ -60,20 +60,16 @@ func _reset_label_scale() -> void:
|
||||||
|
|
||||||
|
|
||||||
func _set_value(new_value: Club.Type) -> void:
|
func _set_value(new_value: Club.Type) -> void:
|
||||||
var old_label := _get_club_label(value)
|
|
||||||
var new_label := _get_club_label(new_value)
|
|
||||||
value = new_value
|
|
||||||
if not (old_label or new_label):
|
|
||||||
return
|
|
||||||
|
|
||||||
var tween := get_tree().create_tween()
|
var tween := get_tree().create_tween()
|
||||||
tween.set_parallel()
|
tween.set_parallel()
|
||||||
|
|
||||||
|
var old_label := _get_club_label(value)
|
||||||
if old_label:
|
if old_label:
|
||||||
tween.tween_property(old_label, "scale", UNSELECTED_SCALE, LABEL_SCALE_TIME).set_trans(
|
tween.tween_property(old_label, "scale", UNSELECTED_SCALE, LABEL_SCALE_TIME).set_trans(
|
||||||
Tween.TRANS_SINE
|
Tween.TRANS_SINE
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var new_label := _get_club_label(new_value)
|
||||||
if new_label:
|
if new_label:
|
||||||
tween.tween_property(new_label, "scale", SELECTED_SCALE, LABEL_SCALE_TIME).set_trans(
|
tween.tween_property(new_label, "scale", SELECTED_SCALE, LABEL_SCALE_TIME).set_trans(
|
||||||
Tween.TRANS_SINE
|
Tween.TRANS_SINE
|
||||||
|
@ -82,3 +78,5 @@ func _set_value(new_value: Club.Type) -> void:
|
||||||
tween.tween_property(club_hub, "rotation_degrees", theta, HUB_ROTATION_TIME).set_trans(
|
tween.tween_property(club_hub, "rotation_degrees", theta, HUB_ROTATION_TIME).set_trans(
|
||||||
Tween.TRANS_QUAD
|
Tween.TRANS_QUAD
|
||||||
)
|
)
|
||||||
|
|
||||||
|
value = new_value
|
||||||
|
|
|
@ -6,7 +6,7 @@ const LIFE_BAR_DAMAGE_RUMBLE_SCALE := 0.2
|
||||||
## Time it takes to dampen the life bar rumble on taking damage, in seconds
|
## Time it takes to dampen the life bar rumble on taking damage, in seconds
|
||||||
const LIFE_BAR_DAMAGE_RUMBLE_TIME := 0.2
|
const LIFE_BAR_DAMAGE_RUMBLE_TIME := 0.2
|
||||||
|
|
||||||
var player: WorldPlayer
|
var _life_signal: Signal
|
||||||
|
|
||||||
@onready var power_bar: TextureProgressBar = %PowerBar
|
@onready var power_bar: TextureProgressBar = %PowerBar
|
||||||
@onready var curve_bar: ProgressBar = %CurveBar
|
@onready var curve_bar: ProgressBar = %CurveBar
|
||||||
|
@ -14,45 +14,47 @@ var player: WorldPlayer
|
||||||
|
|
||||||
@onready var club_selector: ClubSelector = %ClubSelector
|
@onready var club_selector: ClubSelector = %ClubSelector
|
||||||
|
|
||||||
|
@onready var hud_state_machine: AnimationTree = %HUDStateMachine
|
||||||
|
|
||||||
@onready var _curve_animation: AnimationPlayer = %CurveAnimation
|
@onready var _curve_animation: AnimationPlayer = %CurveAnimation
|
||||||
@onready var _power_animation: AnimationPlayer = %PowerAnimation
|
@onready var _power_animation: AnimationPlayer = %PowerAnimation
|
||||||
|
|
||||||
@onready var _nice_animation: AnimationPlayer = %NiceAnimation
|
@onready var _nice_animation: AnimationPlayer = %NiceAnimation
|
||||||
@onready var _wasted_animation: AnimationPlayer = %WastedAnimation
|
@onready var _wasted_animation: AnimationPlayer = %WastedAnimation
|
||||||
|
|
||||||
@onready var _club_selector_animation: AnimationPlayer = %ClubSelectorAnimation
|
|
||||||
@onready var _sw_animation: AnimationPlayer = %SWAnimation
|
|
||||||
|
|
||||||
@onready var _player_name: Label = %PlayerName
|
@onready var _player_name: Label = %PlayerName
|
||||||
|
|
||||||
@onready var _life_bar_rumbler: Rumbler = %LifeBarRumbler
|
@onready var _life_bar_rumbler: Rumbler = %LifeBarRumbler
|
||||||
|
|
||||||
static var scene: PackedScene = preload("res://src/ui/shot_hud/shot_hud.tscn")
|
@onready var _state: AnimationNodeStateMachinePlayback = hud_state_machine["parameters/playback"]
|
||||||
|
|
||||||
|
|
||||||
func _ready() -> void:
|
## Set any HUD state specific to the player.
|
||||||
|
func set_state_for_player(player: WorldPlayer) -> void:
|
||||||
|
print_debug("Setting HUD for player ", player.name)
|
||||||
club_selector.set_state_for_player(player)
|
club_selector.set_state_for_player(player)
|
||||||
_player_name.text = player.name
|
_player_name.text = player.name
|
||||||
|
# TODO animate on life loss?
|
||||||
life_bar.value = player.life
|
life_bar.value = player.life
|
||||||
life_bar.tint_progress = player.color
|
life_bar.tint_progress = player.color
|
||||||
|
|
||||||
player.on_life_changed.connect(set_life_value)
|
# TODO this is soooooo wack...
|
||||||
|
# TODO we should just revert to having distinct ShotHUDs for each player
|
||||||
|
if _life_signal and _life_signal.is_connected(set_life_value):
|
||||||
|
_life_signal.disconnect(set_life_value)
|
||||||
|
_life_signal = player.on_life_changed
|
||||||
|
_life_signal.connect(set_life_value)
|
||||||
|
|
||||||
# TODO special equipment
|
# TODO special equipment
|
||||||
# TODO abilities
|
# TODO abilities
|
||||||
|
|
||||||
|
|
||||||
func show_hud() -> void:
|
func show_hud() -> void:
|
||||||
_club_selector_animation.play("show")
|
_state.travel("visible")
|
||||||
_sw_animation.play("show")
|
|
||||||
|
|
||||||
|
|
||||||
func hide_hud() -> void:
|
func hide_hud() -> void:
|
||||||
_club_selector_animation.play("hide")
|
_state.travel("hidden")
|
||||||
_sw_animation.play("hide")
|
|
||||||
|
|
||||||
|
|
||||||
func peek_life_bar() -> void:
|
|
||||||
_sw_animation.play("peek")
|
|
||||||
|
|
||||||
|
|
||||||
func start_power_bar() -> void:
|
func start_power_bar() -> void:
|
||||||
|
@ -94,7 +96,6 @@ func set_life_value(new_value: float) -> void:
|
||||||
var difference := new_value - life_bar.value
|
var difference := new_value - life_bar.value
|
||||||
if difference < 0:
|
if difference < 0:
|
||||||
# Taking damage
|
# Taking damage
|
||||||
peek_life_bar()
|
|
||||||
_life_bar_rumbler.intensity = LIFE_BAR_DAMAGE_RUMBLE_SCALE * abs(difference)
|
_life_bar_rumbler.intensity = LIFE_BAR_DAMAGE_RUMBLE_SCALE * abs(difference)
|
||||||
var tween := get_tree().create_tween()
|
var tween := get_tree().create_tween()
|
||||||
(
|
(
|
||||||
|
@ -107,10 +108,3 @@ func set_life_value(new_value: float) -> void:
|
||||||
# TODO: something for this?
|
# TODO: something for this?
|
||||||
pass
|
pass
|
||||||
life_bar.value = new_value
|
life_bar.value = new_value
|
||||||
|
|
||||||
|
|
||||||
static func create(player: WorldPlayer) -> ShotHUD:
|
|
||||||
var instance: ShotHUD = scene.instantiate()
|
|
||||||
instance.player = player
|
|
||||||
|
|
||||||
return instance
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
[gd_scene load_steps=32 format=3 uid="uid://c4ifdiohng830"]
|
[gd_scene load_steps=33 format=3 uid="uid://c4ifdiohng830"]
|
||||||
|
|
||||||
[ext_resource type="Script" path="res://src/ui/shot_hud/shot_hud.gd" id="1_x5b4c"]
|
[ext_resource type="Script" path="res://src/ui/shot_hud/shot_hud.gd" id="1_x5b4c"]
|
||||||
[ext_resource type="Shader" path="res://src/shaders/canvas_retro.gdshader" id="1_ybxxp"]
|
[ext_resource type="Shader" path="res://src/shaders/canvas_retro.gdshader" id="1_ybxxp"]
|
||||||
|
@ -376,13 +376,12 @@ _data = {
|
||||||
"fill": SubResource("Animation_uo6s7")
|
"fill": SubResource("Animation_uo6s7")
|
||||||
}
|
}
|
||||||
|
|
||||||
[sub_resource type="Animation" id="Animation_4h8gq"]
|
[sub_resource type="Animation" id="Animation_3cn2c"]
|
||||||
resource_name = "RESET"
|
|
||||||
length = 0.001
|
length = 0.001
|
||||||
tracks/0/type = "value"
|
tracks/0/type = "value"
|
||||||
tracks/0/imported = false
|
tracks/0/imported = false
|
||||||
tracks/0/enabled = true
|
tracks/0/enabled = true
|
||||||
tracks/0/path = NodePath(".:rotation")
|
tracks/0/path = NodePath("ClubSelector:rotation")
|
||||||
tracks/0/interp = 4
|
tracks/0/interp = 4
|
||||||
tracks/0/loop_wrap = true
|
tracks/0/loop_wrap = true
|
||||||
tracks/0/keys = {
|
tracks/0/keys = {
|
||||||
|
@ -392,14 +391,14 @@ tracks/0/keys = {
|
||||||
"values": [0.0]
|
"values": [0.0]
|
||||||
}
|
}
|
||||||
|
|
||||||
[sub_resource type="Animation" id="Animation_w7dmn"]
|
[sub_resource type="Animation" id="Animation_dt1yq"]
|
||||||
resource_name = "hide_selector"
|
resource_name = "hide"
|
||||||
length = 0.4
|
length = 0.4
|
||||||
step = 0.02
|
step = 0.02
|
||||||
tracks/0/type = "value"
|
tracks/0/type = "value"
|
||||||
tracks/0/imported = false
|
tracks/0/imported = false
|
||||||
tracks/0/enabled = true
|
tracks/0/enabled = true
|
||||||
tracks/0/path = NodePath(".:rotation")
|
tracks/0/path = NodePath("ClubSelector:rotation")
|
||||||
tracks/0/interp = 4
|
tracks/0/interp = 4
|
||||||
tracks/0/loop_wrap = true
|
tracks/0/loop_wrap = true
|
||||||
tracks/0/keys = {
|
tracks/0/keys = {
|
||||||
|
@ -409,14 +408,14 @@ tracks/0/keys = {
|
||||||
"values": [0.0, 0.0872665, -1.5708]
|
"values": [0.0, 0.0872665, -1.5708]
|
||||||
}
|
}
|
||||||
|
|
||||||
[sub_resource type="Animation" id="Animation_x6kyr"]
|
[sub_resource type="Animation" id="Animation_0maif"]
|
||||||
resource_name = "show"
|
resource_name = "show"
|
||||||
length = 0.4
|
length = 0.4
|
||||||
step = 0.02
|
step = 0.02
|
||||||
tracks/0/type = "value"
|
tracks/0/type = "value"
|
||||||
tracks/0/imported = false
|
tracks/0/imported = false
|
||||||
tracks/0/enabled = true
|
tracks/0/enabled = true
|
||||||
tracks/0/path = NodePath(".:rotation")
|
tracks/0/path = NodePath("ClubSelector:rotation")
|
||||||
tracks/0/interp = 4
|
tracks/0/interp = 4
|
||||||
tracks/0/loop_wrap = true
|
tracks/0/loop_wrap = true
|
||||||
tracks/0/keys = {
|
tracks/0/keys = {
|
||||||
|
@ -426,144 +425,45 @@ tracks/0/keys = {
|
||||||
"values": [-1.5708, 0.0872665, 0.0]
|
"values": [-1.5708, 0.0872665, 0.0]
|
||||||
}
|
}
|
||||||
|
|
||||||
[sub_resource type="AnimationLibrary" id="AnimationLibrary_5nauw"]
|
|
||||||
_data = {
|
|
||||||
"RESET": SubResource("Animation_4h8gq"),
|
|
||||||
"hide": SubResource("Animation_w7dmn"),
|
|
||||||
"show": SubResource("Animation_x6kyr")
|
|
||||||
}
|
|
||||||
|
|
||||||
[sub_resource type="Animation" id="Animation_3cn2c"]
|
|
||||||
resource_name = "RESET"
|
|
||||||
length = 0.001
|
|
||||||
tracks/0/type = "value"
|
|
||||||
tracks/0/imported = false
|
|
||||||
tracks/0/enabled = true
|
|
||||||
tracks/0/path = NodePath("SouthWest:position")
|
|
||||||
tracks/0/interp = 1
|
|
||||||
tracks/0/loop_wrap = true
|
|
||||||
tracks/0/keys = {
|
|
||||||
"times": PackedFloat32Array(0),
|
|
||||||
"transitions": PackedFloat32Array(1),
|
|
||||||
"update": 0,
|
|
||||||
"values": [Vector2(0, 982)]
|
|
||||||
}
|
|
||||||
tracks/1/type = "value"
|
|
||||||
tracks/1/imported = false
|
|
||||||
tracks/1/enabled = true
|
|
||||||
tracks/1/path = NodePath("SouthWest:visible")
|
|
||||||
tracks/1/interp = 1
|
|
||||||
tracks/1/loop_wrap = true
|
|
||||||
tracks/1/keys = {
|
|
||||||
"times": PackedFloat32Array(0),
|
|
||||||
"transitions": PackedFloat32Array(1),
|
|
||||||
"update": 1,
|
|
||||||
"values": [true]
|
|
||||||
}
|
|
||||||
|
|
||||||
[sub_resource type="Animation" id="Animation_yis4x"]
|
|
||||||
resource_name = "hide_health_bar"
|
|
||||||
length = 0.4
|
|
||||||
step = 0.02
|
|
||||||
tracks/0/type = "value"
|
|
||||||
tracks/0/imported = false
|
|
||||||
tracks/0/enabled = true
|
|
||||||
tracks/0/path = NodePath("SouthWest:position")
|
|
||||||
tracks/0/interp = 2
|
|
||||||
tracks/0/loop_wrap = true
|
|
||||||
tracks/0/keys = {
|
|
||||||
"times": PackedFloat32Array(0, 0.1, 0.4),
|
|
||||||
"transitions": PackedFloat32Array(1.618, 1.618, 1),
|
|
||||||
"update": 0,
|
|
||||||
"values": [Vector2(0, 982), Vector2(0, 960), Vector2(0, 1100)]
|
|
||||||
}
|
|
||||||
tracks/1/type = "value"
|
|
||||||
tracks/1/imported = false
|
|
||||||
tracks/1/enabled = true
|
|
||||||
tracks/1/path = NodePath("SouthWest:visible")
|
|
||||||
tracks/1/interp = 1
|
|
||||||
tracks/1/loop_wrap = true
|
|
||||||
tracks/1/keys = {
|
|
||||||
"times": PackedFloat32Array(0.4),
|
|
||||||
"transitions": PackedFloat32Array(1),
|
|
||||||
"update": 1,
|
|
||||||
"values": [false]
|
|
||||||
}
|
|
||||||
|
|
||||||
[sub_resource type="Animation" id="Animation_nicro"]
|
|
||||||
resource_name = "show_life_bar"
|
|
||||||
length = 0.4
|
|
||||||
step = 0.02
|
|
||||||
tracks/0/type = "value"
|
|
||||||
tracks/0/imported = false
|
|
||||||
tracks/0/enabled = true
|
|
||||||
tracks/0/path = NodePath("SouthWest:position")
|
|
||||||
tracks/0/interp = 2
|
|
||||||
tracks/0/loop_wrap = true
|
|
||||||
tracks/0/keys = {
|
|
||||||
"times": PackedFloat32Array(0, 0.34, 0.4),
|
|
||||||
"transitions": PackedFloat32Array(1.618, 1.618, 1),
|
|
||||||
"update": 0,
|
|
||||||
"values": [Vector2(0, 1100), Vector2(0, 960), Vector2(0, 982)]
|
|
||||||
}
|
|
||||||
tracks/1/type = "value"
|
|
||||||
tracks/1/imported = false
|
|
||||||
tracks/1/enabled = true
|
|
||||||
tracks/1/path = NodePath("SouthWest:visible")
|
|
||||||
tracks/1/interp = 1
|
|
||||||
tracks/1/loop_wrap = true
|
|
||||||
tracks/1/keys = {
|
|
||||||
"times": PackedFloat32Array(0),
|
|
||||||
"transitions": PackedFloat32Array(1),
|
|
||||||
"update": 1,
|
|
||||||
"values": [true]
|
|
||||||
}
|
|
||||||
|
|
||||||
[sub_resource type="Animation" id="Animation_jugqx"]
|
|
||||||
resource_name = "peek"
|
|
||||||
length = 2.4
|
|
||||||
step = 0.02
|
|
||||||
tracks/0/type = "value"
|
|
||||||
tracks/0/imported = false
|
|
||||||
tracks/0/enabled = true
|
|
||||||
tracks/0/path = NodePath("SouthWest:position")
|
|
||||||
tracks/0/interp = 1
|
|
||||||
tracks/0/loop_wrap = true
|
|
||||||
tracks/0/keys = {
|
|
||||||
"times": PackedFloat32Array(0, 0.1, 2.3, 2.4),
|
|
||||||
"transitions": PackedFloat32Array(1.618, 1, 1.618, 1),
|
|
||||||
"update": 0,
|
|
||||||
"values": [Vector2(0, 1100), Vector2(0, 982), Vector2(0, 982), Vector2(0, 1100)]
|
|
||||||
}
|
|
||||||
tracks/1/type = "value"
|
|
||||||
tracks/1/imported = false
|
|
||||||
tracks/1/enabled = true
|
|
||||||
tracks/1/path = NodePath("SouthWest:visible")
|
|
||||||
tracks/1/interp = 1
|
|
||||||
tracks/1/loop_wrap = true
|
|
||||||
tracks/1/keys = {
|
|
||||||
"times": PackedFloat32Array(0, 2.4),
|
|
||||||
"transitions": PackedFloat32Array(1, 1),
|
|
||||||
"update": 1,
|
|
||||||
"values": [true, false]
|
|
||||||
}
|
|
||||||
|
|
||||||
[sub_resource type="AnimationLibrary" id="AnimationLibrary_c3i4w"]
|
[sub_resource type="AnimationLibrary" id="AnimationLibrary_c3i4w"]
|
||||||
_data = {
|
_data = {
|
||||||
"RESET": SubResource("Animation_3cn2c"),
|
"RESET": SubResource("Animation_3cn2c"),
|
||||||
"hide": SubResource("Animation_yis4x"),
|
"hide": SubResource("Animation_dt1yq"),
|
||||||
"peek": SubResource("Animation_jugqx"),
|
"show": SubResource("Animation_0maif")
|
||||||
"show": SubResource("Animation_nicro")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[sub_resource type="AnimationNodeAnimation" id="AnimationNodeAnimation_8uxnp"]
|
||||||
|
animation = &"hide"
|
||||||
|
|
||||||
|
[sub_resource type="AnimationNodeAnimation" id="AnimationNodeAnimation_v05eu"]
|
||||||
|
animation = &"show"
|
||||||
|
|
||||||
|
[sub_resource type="AnimationNodeStateMachineTransition" id="AnimationNodeStateMachineTransition_28a4x"]
|
||||||
|
advance_mode = 2
|
||||||
|
|
||||||
|
[sub_resource type="AnimationNodeStateMachineTransition" id="AnimationNodeStateMachineTransition_bj7v0"]
|
||||||
|
switch_mode = 2
|
||||||
|
|
||||||
|
[sub_resource type="AnimationNodeStateMachineTransition" id="AnimationNodeStateMachineTransition_xpwgd"]
|
||||||
|
switch_mode = 2
|
||||||
|
|
||||||
|
[sub_resource type="AnimationNodeStateMachine" id="AnimationNodeStateMachine_osrbp"]
|
||||||
|
states/hidden/node = SubResource("AnimationNodeAnimation_8uxnp")
|
||||||
|
states/hidden/position = Vector2(592, 100)
|
||||||
|
states/visible/node = SubResource("AnimationNodeAnimation_v05eu")
|
||||||
|
states/visible/position = Vector2(364, 100)
|
||||||
|
transitions = ["Start", "visible", SubResource("AnimationNodeStateMachineTransition_28a4x"), "visible", "hidden", SubResource("AnimationNodeStateMachineTransition_bj7v0"), "hidden", "visible", SubResource("AnimationNodeStateMachineTransition_xpwgd")]
|
||||||
|
graph_offset = Vector2(-309, -132)
|
||||||
|
|
||||||
[node name="ShotHUD" type="Control"]
|
[node name="ShotHUD" type="Control"]
|
||||||
|
top_level = true
|
||||||
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 = 2
|
mouse_filter = 1
|
||||||
script = ExtResource("1_x5b4c")
|
script = ExtResource("1_x5b4c")
|
||||||
|
|
||||||
[node name="WoahNiceFeedback" type="RichTextLabel" parent="."]
|
[node name="WoahNiceFeedback" type="RichTextLabel" parent="."]
|
||||||
|
@ -644,7 +544,7 @@ anchor_right = 0.6
|
||||||
anchor_bottom = 0.85
|
anchor_bottom = 0.85
|
||||||
grow_horizontal = 2
|
grow_horizontal = 2
|
||||||
grow_vertical = 2
|
grow_vertical = 2
|
||||||
mouse_filter = 2
|
mouse_filter = 1
|
||||||
|
|
||||||
[node name="PowerGauge" type="Control" parent="ShotGauges"]
|
[node name="PowerGauge" type="Control" parent="ShotGauges"]
|
||||||
layout_mode = 1
|
layout_mode = 1
|
||||||
|
@ -750,21 +650,25 @@ grow_horizontal = 1
|
||||||
grow_vertical = 1
|
grow_vertical = 1
|
||||||
pivot_offset = Vector2(-400, 0)
|
pivot_offset = Vector2(-400, 0)
|
||||||
|
|
||||||
[node name="ClubSelectorAnimation" type="AnimationPlayer" parent="ClubSelector"]
|
[node name="HUDAnimation" type="AnimationPlayer" parent="."]
|
||||||
unique_name_in_owner = true
|
|
||||||
libraries = {
|
libraries = {
|
||||||
"": SubResource("AnimationLibrary_5nauw")
|
"": SubResource("AnimationLibrary_c3i4w")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[node name="HUDStateMachine" type="AnimationTree" parent="."]
|
||||||
|
unique_name_in_owner = true
|
||||||
|
root_node = NodePath("%HUDStateMachine/..")
|
||||||
|
tree_root = SubResource("AnimationNodeStateMachine_osrbp")
|
||||||
|
anim_player = NodePath("../HUDAnimation")
|
||||||
|
|
||||||
[node name="SouthWest" type="MarginContainer" parent="."]
|
[node name="SouthWest" type="MarginContainer" parent="."]
|
||||||
layout_mode = 1
|
layout_mode = 1
|
||||||
anchors_preset = -1
|
anchors_preset = -1
|
||||||
anchor_top = 1.0
|
anchor_top = 1.0
|
||||||
anchor_right = 0.333
|
anchor_right = 0.333
|
||||||
anchor_bottom = 1.0
|
anchor_bottom = 1.0
|
||||||
offset_top = 20.0
|
offset_top = -40.0
|
||||||
offset_right = 40.0
|
offset_right = 40.0
|
||||||
offset_bottom = 118.0
|
|
||||||
grow_vertical = 0
|
grow_vertical = 0
|
||||||
theme_override_constants/margin_left = 16
|
theme_override_constants/margin_left = 16
|
||||||
theme_override_constants/margin_bottom = 16
|
theme_override_constants/margin_bottom = 16
|
||||||
|
@ -805,10 +709,3 @@ script = ExtResource("3_6groq")
|
||||||
[node name="LifeBar" parent="SouthWest/VBoxContainer/MarginContainer/LifeBarRumbler" instance=ExtResource("9_w1fiw")]
|
[node name="LifeBar" parent="SouthWest/VBoxContainer/MarginContainer/LifeBarRumbler" instance=ExtResource("9_w1fiw")]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
layout_mode = 1
|
layout_mode = 1
|
||||||
|
|
||||||
[node name="SWAnimation" type="AnimationPlayer" parent="SouthWest"]
|
|
||||||
unique_name_in_owner = true
|
|
||||||
root_node = NodePath("../..")
|
|
||||||
libraries = {
|
|
||||||
"": SubResource("AnimationLibrary_c3i4w")
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,45 +1,4 @@
|
||||||
class_name WorldUI extends Control
|
class_name WorldUI extends Control
|
||||||
## Container & accessor for the world UI.
|
## Container & accessor for the world UI.
|
||||||
|
|
||||||
const DEMO_CAMERA_GROUP := "DemoCamera"
|
@onready var shot_hud: ShotHUD = %ShotHUD
|
||||||
|
|
||||||
@export var pause_scene := preload("res://src/ui/menus/pause_menu/pause_menu.tscn")
|
|
||||||
|
|
||||||
var _prev_camera: Camera3D
|
|
||||||
|
|
||||||
@onready var hud_container: Control = %HUDContainer
|
|
||||||
@onready var pause_container: Control = %PauseContainer
|
|
||||||
|
|
||||||
|
|
||||||
func _unhandled_key_input(event: InputEvent) -> void:
|
|
||||||
if event.is_action_pressed("pause"):
|
|
||||||
get_viewport().set_input_as_handled()
|
|
||||||
pause()
|
|
||||||
|
|
||||||
|
|
||||||
func add_player_hud(hud: ShotHUD) -> void:
|
|
||||||
hud_container.add_child(hud)
|
|
||||||
|
|
||||||
|
|
||||||
func pause() -> void:
|
|
||||||
# Switch to demo cam, if there is one.
|
|
||||||
var democams: Array[Node] = get_tree().get_nodes_in_group(DEMO_CAMERA_GROUP)
|
|
||||||
if democams:
|
|
||||||
_prev_camera = get_viewport().get_camera_3d()
|
|
||||||
var democam: Camera3D = democams.pick_random()
|
|
||||||
democam.make_current()
|
|
||||||
|
|
||||||
var menu := pause_scene.instantiate()
|
|
||||||
pause_container.add_child(menu)
|
|
||||||
menu.tree_exiting.connect(_unpause)
|
|
||||||
hud_container.hide()
|
|
||||||
get_tree().paused = true
|
|
||||||
|
|
||||||
|
|
||||||
func _unpause() -> void:
|
|
||||||
# Unset demo camera, if there is one.
|
|
||||||
if is_instance_valid(_prev_camera):
|
|
||||||
_prev_camera.make_current()
|
|
||||||
_prev_camera = null
|
|
||||||
hud_container.show()
|
|
||||||
get_tree().paused = false
|
|
||||||
|
|
|
@ -3,6 +3,7 @@ class_name RoundRobinManager extends PlayManager
|
||||||
|
|
||||||
|
|
||||||
func on_initialization() -> void:
|
func on_initialization() -> void:
|
||||||
|
print("IN ON_INITIALIZATION")
|
||||||
# Set first player as active
|
# Set first player as active
|
||||||
players[0].shot_setup.phase = ShotSetup.Phase.AIM
|
players[0].shot_setup.phase = ShotSetup.Phase.AIM
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
[gd_scene load_steps=8 format=3 uid="uid://cwnwcd8kushl3"]
|
[gd_scene load_steps=9 format=3 uid="uid://cwnwcd8kushl3"]
|
||||||
|
|
||||||
[ext_resource type="Script" path="res://src/world/world.gd" id="1_ybjyx"]
|
[ext_resource type="Script" path="res://src/world/world.gd" id="1_ybjyx"]
|
||||||
[ext_resource type="PackedScene" uid="uid://bm2o3mex10v11" path="res://levels/debug_level/debug_level.tscn" id="2_0xu5a"]
|
[ext_resource type="PackedScene" uid="uid://bm2o3mex10v11" path="res://levels/debug_level/debug_level.tscn" id="2_0xu5a"]
|
||||||
|
[ext_resource type="PackedScene" uid="uid://c4ifdiohng830" path="res://src/ui/shot_hud/shot_hud.tscn" id="2_5b7qb"]
|
||||||
[ext_resource type="Script" path="res://src/player/world_player.gd" id="2_e743i"]
|
[ext_resource type="Script" path="res://src/player/world_player.gd" id="2_e743i"]
|
||||||
[ext_resource type="Script" path="res://src/ui/world_ui.gd" id="2_imewa"]
|
[ext_resource type="Script" path="res://src/ui/world_ui.gd" id="2_imewa"]
|
||||||
[ext_resource type="Resource" uid="uid://crock3revdn73" path="res://src/player/debug_player.tres" id="3_pyw81"]
|
[ext_resource type="Resource" uid="uid://crock3revdn73" path="res://src/player/debug_player.tres" id="3_pyw81"]
|
||||||
|
@ -30,21 +31,6 @@ grow_vertical = 2
|
||||||
mouse_filter = 1
|
mouse_filter = 1
|
||||||
script = ExtResource("2_imewa")
|
script = ExtResource("2_imewa")
|
||||||
|
|
||||||
[node name="HUDContainer" type="Control" parent="UI"]
|
[node name="ShotHUD" parent="UI" instance=ExtResource("2_5b7qb")]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
layout_mode = 1
|
layout_mode = 1
|
||||||
anchors_preset = 15
|
|
||||||
anchor_right = 1.0
|
|
||||||
anchor_bottom = 1.0
|
|
||||||
grow_horizontal = 2
|
|
||||||
grow_vertical = 2
|
|
||||||
|
|
||||||
[node name="PauseContainer" type="Control" parent="UI"]
|
|
||||||
unique_name_in_owner = true
|
|
||||||
layout_mode = 1
|
|
||||||
anchors_preset = 15
|
|
||||||
anchor_right = 1.0
|
|
||||||
anchor_bottom = 1.0
|
|
||||||
grow_horizontal = 2
|
|
||||||
grow_vertical = 2
|
|
||||||
mouse_filter = 1
|
|
||||||
|
|
Loading…
Reference in New Issue