generated from krampus/template-godot4
Players have separate HUDs
This commit is contained in:
parent
af31c3c431
commit
5878a2efd5
|
@ -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.5
|
roughness = 0.43
|
||||||
texture_filter = 2
|
texture_filter = 2
|
||||||
|
|
|
@ -79,9 +79,7 @@ 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):
|
||||||
|
@ -155,13 +153,11 @@ 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 _init_deferred() -> void:
|
|
||||||
# Set up HUD
|
|
||||||
club = initial_club
|
|
||||||
|
|
||||||
|
|
||||||
func _ready() -> void:
|
func _ready() -> void:
|
||||||
_init_deferred.call_deferred()
|
# Create & set up HUD
|
||||||
|
hud = ShotHUD.create(player)
|
||||||
|
world.ui.add_player_hud(hud)
|
||||||
|
club = initial_club
|
||||||
|
|
||||||
|
|
||||||
func _set_camera_distance(value: float) -> void:
|
func _set_camera_distance(value: float) -> void:
|
||||||
|
@ -356,7 +352,6 @@ 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")
|
||||||
|
|
|
@ -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 _life_signal: Signal
|
var player: WorldPlayer
|
||||||
|
|
||||||
@onready var power_bar: TextureProgressBar = %PowerBar
|
@onready var power_bar: TextureProgressBar = %PowerBar
|
||||||
@onready var curve_bar: ProgressBar = %CurveBar
|
@onready var curve_bar: ProgressBar = %CurveBar
|
||||||
|
@ -28,23 +28,16 @@ var _life_signal: Signal
|
||||||
|
|
||||||
@onready var _state: AnimationNodeStateMachinePlayback = hud_state_machine["parameters/playback"]
|
@onready var _state: AnimationNodeStateMachinePlayback = hud_state_machine["parameters/playback"]
|
||||||
|
|
||||||
|
static var scene: PackedScene = preload("res://src/ui/shot_hud/shot_hud.tscn")
|
||||||
|
|
||||||
## Set any HUD state specific to the player.
|
|
||||||
func set_state_for_player(player: WorldPlayer) -> void:
|
func _ready() -> 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
|
||||||
|
|
||||||
# TODO this is soooooo wack...
|
player.on_life_changed.connect(set_life_value)
|
||||||
# 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
|
||||||
|
|
||||||
|
@ -108,3 +101,10 @@ 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
|
||||||
|
|
|
@ -390,6 +390,18 @@ tracks/0/keys = {
|
||||||
"update": 0,
|
"update": 0,
|
||||||
"values": [0.0]
|
"values": [0.0]
|
||||||
}
|
}
|
||||||
|
tracks/1/type = "value"
|
||||||
|
tracks/1/imported = false
|
||||||
|
tracks/1/enabled = true
|
||||||
|
tracks/1/path = NodePath("SouthWest:position")
|
||||||
|
tracks/1/interp = 1
|
||||||
|
tracks/1/loop_wrap = true
|
||||||
|
tracks/1/keys = {
|
||||||
|
"times": PackedFloat32Array(0),
|
||||||
|
"transitions": PackedFloat32Array(1),
|
||||||
|
"update": 0,
|
||||||
|
"values": [Vector2(0, 982)]
|
||||||
|
}
|
||||||
|
|
||||||
[sub_resource type="Animation" id="Animation_dt1yq"]
|
[sub_resource type="Animation" id="Animation_dt1yq"]
|
||||||
resource_name = "hide"
|
resource_name = "hide"
|
||||||
|
@ -407,6 +419,18 @@ tracks/0/keys = {
|
||||||
"update": 0,
|
"update": 0,
|
||||||
"values": [0.0, 0.0872665, -1.5708]
|
"values": [0.0, 0.0872665, -1.5708]
|
||||||
}
|
}
|
||||||
|
tracks/1/type = "value"
|
||||||
|
tracks/1/imported = false
|
||||||
|
tracks/1/enabled = true
|
||||||
|
tracks/1/path = NodePath("SouthWest:position")
|
||||||
|
tracks/1/interp = 2
|
||||||
|
tracks/1/loop_wrap = true
|
||||||
|
tracks/1/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)]
|
||||||
|
}
|
||||||
|
|
||||||
[sub_resource type="Animation" id="Animation_0maif"]
|
[sub_resource type="Animation" id="Animation_0maif"]
|
||||||
resource_name = "show"
|
resource_name = "show"
|
||||||
|
@ -424,6 +448,18 @@ tracks/0/keys = {
|
||||||
"update": 0,
|
"update": 0,
|
||||||
"values": [-1.5708, 0.0872665, 0.0]
|
"values": [-1.5708, 0.0872665, 0.0]
|
||||||
}
|
}
|
||||||
|
tracks/1/type = "value"
|
||||||
|
tracks/1/imported = false
|
||||||
|
tracks/1/enabled = true
|
||||||
|
tracks/1/path = NodePath("SouthWest:position")
|
||||||
|
tracks/1/interp = 2
|
||||||
|
tracks/1/loop_wrap = true
|
||||||
|
tracks/1/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)]
|
||||||
|
}
|
||||||
|
|
||||||
[sub_resource type="AnimationLibrary" id="AnimationLibrary_c3i4w"]
|
[sub_resource type="AnimationLibrary" id="AnimationLibrary_c3i4w"]
|
||||||
_data = {
|
_data = {
|
||||||
|
@ -438,21 +474,21 @@ animation = &"hide"
|
||||||
[sub_resource type="AnimationNodeAnimation" id="AnimationNodeAnimation_v05eu"]
|
[sub_resource type="AnimationNodeAnimation" id="AnimationNodeAnimation_v05eu"]
|
||||||
animation = &"show"
|
animation = &"show"
|
||||||
|
|
||||||
[sub_resource type="AnimationNodeStateMachineTransition" id="AnimationNodeStateMachineTransition_28a4x"]
|
|
||||||
advance_mode = 2
|
|
||||||
|
|
||||||
[sub_resource type="AnimationNodeStateMachineTransition" id="AnimationNodeStateMachineTransition_bj7v0"]
|
[sub_resource type="AnimationNodeStateMachineTransition" id="AnimationNodeStateMachineTransition_bj7v0"]
|
||||||
switch_mode = 2
|
switch_mode = 2
|
||||||
|
|
||||||
[sub_resource type="AnimationNodeStateMachineTransition" id="AnimationNodeStateMachineTransition_xpwgd"]
|
[sub_resource type="AnimationNodeStateMachineTransition" id="AnimationNodeStateMachineTransition_xpwgd"]
|
||||||
switch_mode = 2
|
switch_mode = 2
|
||||||
|
|
||||||
|
[sub_resource type="AnimationNodeStateMachineTransition" id="AnimationNodeStateMachineTransition_3o88y"]
|
||||||
|
advance_mode = 2
|
||||||
|
|
||||||
[sub_resource type="AnimationNodeStateMachine" id="AnimationNodeStateMachine_osrbp"]
|
[sub_resource type="AnimationNodeStateMachine" id="AnimationNodeStateMachine_osrbp"]
|
||||||
states/hidden/node = SubResource("AnimationNodeAnimation_8uxnp")
|
states/hidden/node = SubResource("AnimationNodeAnimation_8uxnp")
|
||||||
states/hidden/position = Vector2(592, 100)
|
states/hidden/position = Vector2(378, 100)
|
||||||
states/visible/node = SubResource("AnimationNodeAnimation_v05eu")
|
states/visible/node = SubResource("AnimationNodeAnimation_v05eu")
|
||||||
states/visible/position = Vector2(364, 100)
|
states/visible/position = Vector2(597, 100)
|
||||||
transitions = ["Start", "visible", SubResource("AnimationNodeStateMachineTransition_28a4x"), "visible", "hidden", SubResource("AnimationNodeStateMachineTransition_bj7v0"), "hidden", "visible", SubResource("AnimationNodeStateMachineTransition_xpwgd")]
|
transitions = ["visible", "hidden", SubResource("AnimationNodeStateMachineTransition_bj7v0"), "hidden", "visible", SubResource("AnimationNodeStateMachineTransition_xpwgd"), "Start", "hidden", SubResource("AnimationNodeStateMachineTransition_3o88y")]
|
||||||
graph_offset = Vector2(-309, -132)
|
graph_offset = Vector2(-309, -132)
|
||||||
|
|
||||||
[node name="ShotHUD" type="Control"]
|
[node name="ShotHUD" type="Control"]
|
||||||
|
@ -650,24 +686,13 @@ grow_horizontal = 1
|
||||||
grow_vertical = 1
|
grow_vertical = 1
|
||||||
pivot_offset = Vector2(-400, 0)
|
pivot_offset = Vector2(-400, 0)
|
||||||
|
|
||||||
[node name="HUDAnimation" type="AnimationPlayer" parent="."]
|
|
||||||
libraries = {
|
|
||||||
"": 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 = -40.0
|
offset_top = -98.0
|
||||||
offset_right = 40.0
|
offset_right = 40.0
|
||||||
grow_vertical = 0
|
grow_vertical = 0
|
||||||
theme_override_constants/margin_left = 16
|
theme_override_constants/margin_left = 16
|
||||||
|
@ -709,3 +734,14 @@ 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="HUDAnimation" type="AnimationPlayer" parent="."]
|
||||||
|
libraries = {
|
||||||
|
"": 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")
|
||||||
|
|
|
@ -1,4 +1,8 @@
|
||||||
class_name WorldUI extends Control
|
class_name WorldUI extends Control
|
||||||
## Container & accessor for the world UI.
|
## Container & accessor for the world UI.
|
||||||
|
|
||||||
@onready var shot_hud: ShotHUD = %ShotHUD
|
@onready var hud_container: Control = %HUDContainer
|
||||||
|
|
||||||
|
|
||||||
|
func add_player_hud(hud: ShotHUD) -> void:
|
||||||
|
hud_container.add_child(hud)
|
||||||
|
|
|
@ -3,7 +3,6 @@ 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,8 +1,7 @@
|
||||||
[gd_scene load_steps=9 format=3 uid="uid://cwnwcd8kushl3"]
|
[gd_scene load_steps=8 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"]
|
||||||
|
@ -31,6 +30,11 @@ grow_vertical = 2
|
||||||
mouse_filter = 1
|
mouse_filter = 1
|
||||||
script = ExtResource("2_imewa")
|
script = ExtResource("2_imewa")
|
||||||
|
|
||||||
[node name="ShotHUD" parent="UI" instance=ExtResource("2_5b7qb")]
|
[node name="HUDContainer" type="Control" parent="UI"]
|
||||||
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
|
||||||
|
|
Loading…
Reference in New Issue