This commit is contained in:
2026-06-17 17:41:28 +02:00
parent cca539dc32
commit 00a79e55de
15 changed files with 228 additions and 35 deletions

BIN
assets/sfx/tube_connect.wav Normal file

Binary file not shown.

View File

@@ -0,0 +1,24 @@
[remap]
importer="wav"
type="AudioStreamWAV"
uid="uid://bxxi7grsubvgm"
path="res://.godot/imported/tube_connect.wav-1fe9cadbb3e3c66b255ef4556d86a7af.sample"
[deps]
source_file="res://assets/sfx/tube_connect.wav"
dest_files=["res://.godot/imported/tube_connect.wav-1fe9cadbb3e3c66b255ef4556d86a7af.sample"]
[params]
force/8_bit=false
force/mono=false
force/max_rate=false
force/max_rate_hz=44100
edit/trim=false
edit/normalize=false
edit/loop_mode=0
edit/loop_begin=0
edit/loop_end=-1
compress/mode=2

Binary file not shown.

View File

@@ -0,0 +1,24 @@
[remap]
importer="wav"
type="AudioStreamWAV"
uid="uid://cimb1xertnfor"
path="res://.godot/imported/tube_connect_2.wav-2efbb2986383719e05eac50cfe243d79.sample"
[deps]
source_file="res://assets/sfx/tube_connect_2.wav"
dest_files=["res://.godot/imported/tube_connect_2.wav-2efbb2986383719e05eac50cfe243d79.sample"]
[params]
force/8_bit=false
force/mono=false
force/max_rate=false
force/max_rate_hz=44100
edit/trim=false
edit/normalize=false
edit/loop_mode=0
edit/loop_begin=0
edit/loop_end=-1
compress/mode=2

Binary file not shown.

View File

@@ -0,0 +1,24 @@
[remap]
importer="wav"
type="AudioStreamWAV"
uid="uid://mj8wvuwfc6o7"
path="res://.godot/imported/tube_disconnect.wav-20a1bab1cf9ccbee7621f9a058127981.sample"
[deps]
source_file="res://assets/sfx/tube_disconnect.wav"
dest_files=["res://.godot/imported/tube_disconnect.wav-20a1bab1cf9ccbee7621f9a058127981.sample"]
[params]
force/8_bit=false
force/mono=false
force/max_rate=false
force/max_rate_hz=44100
edit/trim=false
edit/normalize=false
edit/loop_mode=0
edit/loop_begin=0
edit/loop_end=-1
compress/mode=2

9
default_bus_layout.tres Normal file
View File

@@ -0,0 +1,9 @@
[gd_resource type="AudioBusLayout" format=3 uid="uid://djkq0k3jsuxcg"]
[resource]
bus/1/name = &"SoundFX"
bus/1/solo = false
bus/1/mute = false
bus/1/bypass_fx = false
bus/1/volume_db = -15.375541
bus/1/send = &"Master"

View File

@@ -15,6 +15,10 @@ run/main_scene="uid://drxbsnqoi4wmw"
config/features=PackedStringArray("4.6", "C#", "Forward Plus") config/features=PackedStringArray("4.6", "C#", "Forward Plus")
config/icon="res://assets/icon.svg" config/icon="res://assets/icon.svg"
[audio]
buses/default_bus_layout="uid://djkq0k3jsuxcg"
[display] [display]
window/size/viewport_width=480 window/size/viewport_width=480
@@ -59,6 +63,10 @@ cam_down={
] ]
} }
[layer_names]
2d_physics/layer_2="TubeConnections"
[physics] [physics]
3d/physics_engine="Jolt Physics" 3d/physics_engine="Jolt Physics"

View File

@@ -1,4 +1,5 @@
using Godot; using Godot;
using Slimepire.Gameplay.Nodules;
namespace Slimepire.Gameplay; namespace Slimepire.Gameplay;
@@ -7,18 +8,64 @@ public partial class BuildGhost : Node2D
{ {
public event Action<Vector2>? OnBuild; public event Action<Vector2>? OnBuild;
private Tube? _tube; private Tube? _tube;
private readonly Dictionary<Nodule, Tube> _connectedTubes = [];
public override void _Ready() public override void _Ready()
{ {
_tube = Instantiator.Instantiate<Tube>(); TubeConnectionArea.AreaEntered += TubeConnectionAreaOnAreaEntered;
_tube.Position = Position / 2; // TODO WHYYY???? TubeConnectionArea.AreaExited += TubeConnectionAreaOnAreaExited;
GetParent()?.AddChild(_tube); }
private void TubeConnectionAreaOnAreaEntered(Area2D area)
{
if (area.GetParent() is Nodule nodule)
{
CreateGhostTube(nodule, area.GlobalPosition);
ConnectTubePlayer.Play();
}
}
private void TubeConnectionAreaOnAreaExited(Area2D area)
{
if (area.GetParent() is Nodule nodule)
{
var tube = _connectedTubes.GetValueOrDefault(nodule);
if (tube == null)
return;
_connectedTubes.Remove(nodule);
tube.QueueFree();
DisconnectTubePlayer.Play();
}
}
private void CreateGhostTube(Nodule connectedNodule, Vector2 pos)
{
var tube = Instantiator.Instantiate<Tube>();
tube.Position = pos / 2; // TODO WHYYY????
_connectedTubes.Add(connectedNodule, tube);
GetParent()?.AddChild(tube);
} }
public override void _Process(double delta) public override void _Process(double delta)
{ {
GlobalPosition = GetGlobalMousePosition(); GlobalPosition = GetGlobalMousePosition();
_tube?.SetTarget(GlobalPosition); foreach (var (_, tube) in _connectedTubes)
{
tube.SetTarget(GlobalPosition);
}
}
public override void _UnhandledKeyInput(InputEvent @event)
{
using (@event)
{
if (@event is InputEventKey { Keycode: Key.Escape, Pressed: true })
{
NoduleManager.Instance.Building = false;
QueueFree();
}
}
} }
public override void _UnhandledInput(InputEvent @event) public override void _UnhandledInput(InputEvent @event)
@@ -27,9 +74,20 @@ public partial class BuildGhost : Node2D
{ {
if (@event is InputEventMouseButton { Pressed: false, ButtonIndex: MouseButton.Left }) if (@event is InputEventMouseButton { Pressed: false, ButtonIndex: MouseButton.Left })
{ {
NoduleManager.Instance.Building = false;
OnBuild?.Invoke(GlobalPosition); OnBuild?.Invoke(GlobalPosition);
_tube?.QueueFree(); var nodule = Instantiator.Instantiate<Nodule>();
nodule.Position = Position;
GetParent()?.AddChild(nodule);
foreach (var (_, tube) in _connectedTubes)
{
tube.QueueFree();
}
_connectedTubes.Clear();
QueueFree(); QueueFree();
GetViewport().SetInputAsHandled(); GetViewport().SetInputAsHandled();

View File

@@ -1,12 +1,65 @@
[gd_scene format=3 uid="uid://c3n70a52kk34f"] [gd_scene format=3 uid="uid://c3n70a52kk34f"]
[ext_resource type="Script" uid="uid://ck5yw760bu8sb" path="res://src/Gameplay/BuildGhost.cs" id="1_ahcoi"] [ext_resource type="Script" uid="uid://ck5yw760bu8sb" path="res://src/Gameplay/BuildGhost.cs" id="1_ahcoi"]
[ext_resource type="Texture2D" uid="uid://ddduid7esr36f" path="res://assets/icon.svg" id="2_uo42j"] [ext_resource type="Texture2D" uid="uid://cecg47efx7gw8" path="res://assets/Sprite-0001.png" id="2_uo42j"]
[ext_resource type="AudioStream" uid="uid://mj8wvuwfc6o7" path="res://assets/sfx/tube_disconnect.wav" id="3_nxaxp"]
[ext_resource type="AudioStream" uid="uid://bxxi7grsubvgm" path="res://assets/sfx/tube_connect.wav" id="3_quiac"]
[sub_resource type="AtlasTexture" id="AtlasTexture_uo42j"]
atlas = ExtResource("2_uo42j")
region = Rect2(0, 0, 32, 32)
[sub_resource type="AtlasTexture" id="AtlasTexture_nxaxp"]
atlas = ExtResource("2_uo42j")
region = Rect2(32, 0, 32, 32)
[sub_resource type="AtlasTexture" id="AtlasTexture_quiac"]
atlas = ExtResource("2_uo42j")
region = Rect2(64, 0, 32, 32)
[sub_resource type="SpriteFrames" id="SpriteFrames_vecmk"]
animations = [{
"frames": [{
"duration": 1.0,
"texture": SubResource("AtlasTexture_uo42j")
}, {
"duration": 1.0,
"texture": SubResource("AtlasTexture_nxaxp")
}, {
"duration": 1.0,
"texture": SubResource("AtlasTexture_quiac")
}],
"loop": true,
"name": &"default",
"speed": 5.0
}]
[sub_resource type="CircleShape2D" id="CircleShape2D_uo42j"]
radius = 96.38
[node name="BuildGhost" type="Node2D" unique_id=150653292] [node name="BuildGhost" type="Node2D" unique_id=150653292]
script = ExtResource("1_ahcoi") script = ExtResource("1_ahcoi")
[node name="Sprite2D" type="Sprite2D" parent="." unique_id=218448453] [node name="Sprite2D" type="AnimatedSprite2D" parent="." unique_id=260566565]
modulate = Color(0.32941177, 0.29411766, 0.2901961, 0.5764706) self_modulate = Color(0.1752002, 0.36830294, 0.26058322, 0.50980395)
scale = Vector2(0.3, 0.3) texture_filter = 1
texture = ExtResource("2_uo42j") sprite_frames = SubResource("SpriteFrames_vecmk")
[node name="TubeConnectionArea" type="Area2D" parent="." unique_id=2116427547]
unique_name_in_owner = true
collision_layer = 2
collision_mask = 2
[node name="CollisionShape2D" type="CollisionShape2D" parent="TubeConnectionArea" unique_id=1558952717]
shape = SubResource("CircleShape2D_uo42j")
debug_color = Color(0.38922516, 0.6054754, 0.25354394, 0.41960785)
[node name="ConnectTubePlayer" type="AudioStreamPlayer" parent="." unique_id=111889028]
unique_name_in_owner = true
stream = ExtResource("3_quiac")
bus = &"SoundFX"
[node name="DisconnectTubePlayer" type="AudioStreamPlayer" parent="." unique_id=1165411609]
unique_name_in_owner = true
stream = ExtResource("3_nxaxp")
bus = &"SoundFX"

View File

@@ -4,22 +4,17 @@ using Slimepire.Gameplay.Nodules;
namespace Slimepire.Gameplay; namespace Slimepire.Gameplay;
[Singleton] [Singleton]
public partial class TubeManager public partial class NoduleManager
{ {
private Nodule? _root; public bool Building { get; set; }
private List<Nodule> _nodules = []; private readonly List<Nodule> _nodules = [];
private HashSet<NoduleConnection> _connections = []; private readonly HashSet<NoduleConnection> _connections = [];
private Dictionary<NoduleConnection, Tube> _tubeConnections = new(); private readonly Dictionary<NoduleConnection, Tube> _tubeConnections = new();
private List<Tube> _tubes = []; private readonly List<Tube> _tubes = [];
public void RegisterNodule(Nodule nodule) public void RegisterNodule(Nodule nodule)
{ {
if (nodule.IsRoot)
{
_root = nodule;
}
_nodules.Add(nodule); _nodules.Add(nodule);
UpdateNoduleConnections(); UpdateNoduleConnections();

View File

@@ -5,11 +5,6 @@ namespace Slimepire.Gameplay.Nodules;
[SceneTree] [SceneTree]
public partial class Nodule : Node2D public partial class Nodule : Node2D
{ {
[Export]
public bool IsRoot;
private BuildGhost? _ghost;
private bool _mouseInsideClickArea; private bool _mouseInsideClickArea;
private bool _clickedInside; private bool _clickedInside;
@@ -26,7 +21,7 @@ public partial class Nodule : Node2D
TubeConnectionArea.AreaEntered += TubeConnectionAreaOnAreaEntered; TubeConnectionArea.AreaEntered += TubeConnectionAreaOnAreaEntered;
TubeConnectionArea.AreaExited += TubeConnectionAreaOnAreaExited; TubeConnectionArea.AreaExited += TubeConnectionAreaOnAreaExited;
TubeManager.Instance.RegisterNodule(this); NoduleManager.Instance.RegisterNodule(this);
} }
private void TubeConnectionAreaOnAreaEntered(Area2D area) private void TubeConnectionAreaOnAreaEntered(Area2D area)
@@ -34,7 +29,7 @@ public partial class Nodule : Node2D
if (area.GetParent() is Nodule nodule) if (area.GetParent() is Nodule nodule)
{ {
Connections.Add(nodule); Connections.Add(nodule);
TubeManager.Instance.Update(); NoduleManager.Instance.Update();
} }
} }
@@ -68,23 +63,24 @@ public partial class Nodule : Node2D
_mouseInsideClickArea = false; _mouseInsideClickArea = false;
// ghost == null check probably unnecessary // ghost == null check probably unnecessary
if (_clickedInside && _ghost == null) if (_clickedInside && !NoduleManager.Instance.Building)
{ {
NoduleManager.Instance.Building = true;
_clickedInside = false; _clickedInside = false;
_isExpanding = true; _isExpanding = true;
_ghost = Instantiator.Instantiate<BuildGhost>(); var ghost = Instantiator.Instantiate<BuildGhost>();
_ghost.Position = Position; ghost.Position = Position;
_ghost.OnBuild += OnBuildComplete; // ghost.OnBuild += OnBuildComplete;
GetParent()?.AddChild(_ghost); GetParent()?.AddChild(ghost);
} }
} }
private void OnBuildComplete(Vector2 pos) private void OnBuildComplete(Vector2 pos)
{ {
NoduleManager.Instance.Building = false;
_isExpanding = false; _isExpanding = false;
_ghost = null;
var nodule = Instantiator.Instantiate<Nodule>(); var nodule = Instantiator.Instantiate<Nodule>();

View File

@@ -58,6 +58,8 @@ frame_progress = 0.9100785
[node name="TubeConnectionArea" type="Area2D" parent="." unique_id=339547035] [node name="TubeConnectionArea" type="Area2D" parent="." unique_id=339547035]
unique_name_in_owner = true unique_name_in_owner = true
collision_layer = 2
collision_mask = 2
[node name="CollisionShape2D" type="CollisionShape2D" parent="TubeConnectionArea" unique_id=234655540] [node name="CollisionShape2D" type="CollisionShape2D" parent="TubeConnectionArea" unique_id=234655540]
shape = SubResource("CircleShape2D_x44k2") shape = SubResource("CircleShape2D_x44k2")

View File

@@ -11,7 +11,7 @@ public partial class Tube : Node2D
private void GenerateTube() private void GenerateTube()
{ {
float maxLength = 200; float maxLength = 180;
// Generate 5 points from origin to Target // Generate 5 points from origin to Target
var diff = Target.Position - Position; var diff = Target.Position - Position;