From 90eb3291208def83d01164789250c017a5ce2303 Mon Sep 17 00:00:00 2001 From: Star Rauchenberger Date: Thu, 11 Sep 2025 09:58:54 -0400 Subject: [Client] Fixed darkroom double letter panel blockers --- client/Archipelago/settings_screen.gd | 2 ++ client/Archipelago/visibilityListener.gd | 38 ++++++++++++++++++++++++++++++++ 2 files changed, 40 insertions(+) create mode 100644 client/Archipelago/visibilityListener.gd diff --git a/client/Archipelago/settings_screen.gd b/client/Archipelago/settings_screen.gd index bc201b6..ff6f9df 100644 --- a/client/Archipelago/settings_screen.gd +++ b/client/Archipelago/settings_screen.gd @@ -45,6 +45,7 @@ func _ready(): installScriptExtension(ResourceLoader.load("user://maps/Archipelago/player.gd")) installScriptExtension(ResourceLoader.load("user://maps/Archipelago/saver.gd")) installScriptExtension(ResourceLoader.load("user://maps/Archipelago/teleportListener.gd")) + installScriptExtension(ResourceLoader.load("user://maps/Archipelago/visibilityListener.gd")) installScriptExtension(ResourceLoader.load("user://maps/Archipelago/worldportListener.gd")) var proto_script = load("user://maps/Archipelago/generated/proto.gd") @@ -160,6 +161,7 @@ func connectionSuccessful(): clearResourceCache("res://objects/nodes/listeners/keyHolderChecker.tscn") clearResourceCache("res://objects/nodes/listeners/keyHolderResetterListener.tscn") clearResourceCache("res://objects/nodes/listeners/teleportListener.tscn") + clearResourceCache("res://objects/nodes/listeners/visibilityListener.tscn") clearResourceCache("res://objects/nodes/listeners/worldportListener.tscn") clearResourceCache("res://objects/nodes/panel.tscn") clearResourceCache("res://objects/nodes/player.tscn") diff --git a/client/Archipelago/visibilityListener.gd b/client/Archipelago/visibilityListener.gd new file mode 100644 index 0000000..5ea17a0 --- /dev/null +++ b/client/Archipelago/visibilityListener.gd @@ -0,0 +1,38 @@ +extends "res://scripts/nodes/listeners/visibilityListener.gd" + +var item_id +var item_amount + + +func _ready(): + var node_path = String( + get_tree().get_root().get_node("scene").get_path_to(self).get_concatenated_names() + ) + + var gamedata = global.get_node("Gamedata") + var door_id = gamedata.get_door_for_map_node_path(global.map, node_path) + if door_id != null: + var ap = global.get_node("Archipelago") + var item_lock = ap.get_item_id_for_door(door_id) + + if item_lock != null: + item_id = item_lock[0] + item_amount = item_lock[1] + + self.senders = [] + self.senderGroup = [] + self.nested = false + self.complete_at = 0 + self.max_length = 0 + self.excludeSenders = [] + + call_deferred("_readier") + + super._ready() + + +func _readier(): + var ap = global.get_node("Archipelago") + + if ap.client.getItemAmount(item_id) >= item_amount: + handleTriggered() -- cgit 1.4.1