diff options
| author | Star Rauchenberger <fefferburbia@gmail.com> | 2023-04-14 11:32:40 -0400 | 
|---|---|---|
| committer | Star Rauchenberger <fefferburbia@gmail.com> | 2023-04-14 11:32:40 -0400 | 
| commit | deab7140f9415f0f5fea9240a291b976e507593f (patch) | |
| tree | 1ce784f6b89bd6560fff3367a9ffe3891e6edfe8 /Archipelago | |
| parent | ce9cc1c0ef41d342802798cad51d6dbe6ae49fe4 (diff) | |
| download | lingo-archipelago-deab7140f9415f0f5fea9240a291b976e507593f.tar.gz lingo-archipelago-deab7140f9415f0f5fea9240a291b976e507593f.tar.bz2 lingo-archipelago-deab7140f9415f0f5fea9240a291b976e507593f.zip | |
Created rudimentary message display
It shows when the player sends a location or receives an item. Currently it just shows IDs instead of names. We need to download all data packages so that we can read the names. We are also currently queueing a message when we send a location, which isn't the best because if that location turns out to contain an item for us, we'll get two messages. It would be better to hold off until we receive a PrintJSON message describing the location that was sent out. We also now cache the ID of the most recently processed item, so that on relaunch we know which items are new and should be announced.
Diffstat (limited to 'Archipelago')
| -rw-r--r-- | Archipelago/client.gd | 61 | ||||
| -rw-r--r-- | Archipelago/load.gd | 16 | ||||
| -rw-r--r-- | Archipelago/messages.gd | 35 | 
3 files changed, 103 insertions, 9 deletions
| diff --git a/Archipelago/client.gd b/Archipelago/client.gd index e8f9bba..be0ef2d 100644 --- a/Archipelago/client.gd +++ b/Archipelago/client.gd | |||
| @@ -30,10 +30,12 @@ var _mentioned_doors = [] | |||
| 30 | var _painting_ids_by_item = {} | 30 | var _painting_ids_by_item = {} | 
| 31 | var _mentioned_paintings = [] | 31 | var _mentioned_paintings = [] | 
| 32 | var _panel_ids_by_location = {} | 32 | var _panel_ids_by_location = {} | 
| 33 | var _localdata_file = "" | ||
| 33 | 34 | ||
| 34 | var _map_loaded = false | 35 | var _map_loaded = false | 
| 35 | var _held_items = [] | 36 | var _held_items = [] | 
| 36 | var _held_locations = [] | 37 | var _held_locations = [] | 
| 38 | var _last_new_item = -1 | ||
| 37 | var _tower_floors = 0 | 39 | var _tower_floors = 0 | 
| 38 | 40 | ||
| 39 | signal client_connected | 41 | signal client_connected | 
| @@ -135,6 +137,18 @@ func _on_data(): | |||
| 135 | if _slot_data.has("panel_ids_by_location_id"): | 137 | if _slot_data.has("panel_ids_by_location_id"): | 
| 136 | _panel_ids_by_location = _slot_data["panel_ids_by_location_id"] | 138 | _panel_ids_by_location = _slot_data["panel_ids_by_location_id"] | 
| 137 | 139 | ||
| 140 | _localdata_file = "user://archipelago/%s_%d" % [_seed, _slot] | ||
| 141 | var ap_file = File.new() | ||
| 142 | if ap_file.file_exists(_localdata_file): | ||
| 143 | ap_file.open(_localdata_file, File.READ) | ||
| 144 | var localdata = ap_file.get_var(true) | ||
| 145 | ap_file.close() | ||
| 146 | |||
| 147 | if localdata.size() > 0: | ||
| 148 | _last_new_item = localdata[0] | ||
| 149 | else: | ||
| 150 | _last_new_item = -1 | ||
| 151 | |||
| 138 | requestSync() | 152 | requestSync() | 
| 139 | 153 | ||
| 140 | emit_signal("client_connected") | 154 | emit_signal("client_connected") | 
| @@ -150,11 +164,19 @@ func _on_data(): | |||
| 150 | _tower_floors = 0 | 164 | _tower_floors = 0 | 
| 151 | _held_items = [] | 165 | _held_items = [] | 
| 152 | 166 | ||
| 167 | var i = 0 | ||
| 153 | for item in message["items"]: | 168 | for item in message["items"]: | 
| 154 | if _map_loaded: | 169 | if _map_loaded: | 
| 155 | processItem(item["item"]) | 170 | processItem(item["item"], message["index"] + i, item["player"]) | 
| 156 | else: | 171 | else: | 
| 157 | _held_items.append(item["item"]) | 172 | _held_items.append( | 
| 173 | { | ||
| 174 | "item": item["item"], | ||
| 175 | "index": message["index"] + i, | ||
| 176 | "from": item["player"] | ||
| 177 | } | ||
| 178 | ) | ||
| 179 | i += 1 | ||
| 158 | 180 | ||
| 159 | 181 | ||
| 160 | func _process(_delta): | 182 | func _process(_delta): | 
| @@ -181,6 +203,23 @@ func saveSettings(): | |||
| 181 | file.close() | 203 | file.close() | 
| 182 | 204 | ||
| 183 | 205 | ||
| 206 | func saveLocaldata(): | ||
| 207 | # Save the MW/slot specific settings to disk. | ||
| 208 | var dir = Directory.new() | ||
| 209 | var path = "user://archipelago" | ||
| 210 | if dir.dir_exists(path): | ||
| 211 | pass | ||
| 212 | else: | ||
| 213 | dir.make_dir(path) | ||
| 214 | |||
| 215 | var file = File.new() | ||
| 216 | file.open(_localdata_file, File.WRITE) | ||
| 217 | |||
| 218 | var data = [_last_new_item] | ||
| 219 | file.store_var(data, true) | ||
| 220 | file.close() | ||
| 221 | |||
| 222 | |||
| 184 | func getSaveFileName(): | 223 | func getSaveFileName(): | 
| 185 | return "zzAP_%s_%d" % [_seed, _slot] | 224 | return "zzAP_%s_%d" % [_seed, _slot] | 
| 186 | 225 | ||
| @@ -229,6 +268,9 @@ func requestSync(): | |||
| 229 | func sendLocation(loc_id): | 268 | func sendLocation(loc_id): | 
| 230 | if _map_loaded: | 269 | if _map_loaded: | 
| 231 | sendMessage([{"cmd": "LocationChecks", "locations": [loc_id]}]) | 270 | sendMessage([{"cmd": "LocationChecks", "locations": [loc_id]}]) | 
| 271 | |||
| 272 | var messages_node = get_tree().get_root().get_node("Spatial/AP_Messages") | ||
| 273 | messages_node.showMessage("Sent %d" % loc_id) | ||
| 232 | else: | 274 | else: | 
| 233 | _held_locations.append(loc_id) | 275 | _held_locations.append(loc_id) | 
| 234 | 276 | ||
| @@ -240,7 +282,7 @@ func completedGoal(): | |||
| 240 | func mapFinishedLoading(): | 282 | func mapFinishedLoading(): | 
| 241 | if !_map_loaded: | 283 | if !_map_loaded: | 
| 242 | for item in _held_items: | 284 | for item in _held_items: | 
| 243 | processItem(item) | 285 | processItem(item["item"], item["index"], item["from"]) | 
| 244 | 286 | ||
| 245 | sendMessage([{"cmd": "LocationChecks", "locations": _held_locations}]) | 287 | sendMessage([{"cmd": "LocationChecks", "locations": _held_locations}]) | 
| 246 | 288 | ||
| @@ -249,7 +291,7 @@ func mapFinishedLoading(): | |||
| 249 | _held_locations = [] | 291 | _held_locations = [] | 
| 250 | 292 | ||
| 251 | 293 | ||
| 252 | func processItem(item): | 294 | func processItem(item, index, from): | 
| 253 | global._print(item) | 295 | global._print(item) | 
| 254 | 296 | ||
| 255 | var stringified = String(item) | 297 | var stringified = String(item) | 
| @@ -270,6 +312,17 @@ func processItem(item): | |||
| 270 | processItem(_item_name_to_id[subitem_name]) | 312 | processItem(_item_name_to_id[subitem_name]) | 
| 271 | _tower_floors += 1 | 313 | _tower_floors += 1 | 
| 272 | 314 | ||
| 315 | # Show a message about the item if it's new. | ||
| 316 | if index > _last_new_item: | ||
| 317 | _last_new_item = index | ||
| 318 | saveLocaldata() | ||
| 319 | |||
| 320 | var messages_node = get_tree().get_root().get_node("Spatial/AP_Messages") | ||
| 321 | if from == _slot: | ||
| 322 | messages_node.showMessage("Found %d" % item) | ||
| 323 | else: | ||
| 324 | messages_node.showMessage("Received %d from %d" % [item, from]) | ||
| 325 | |||
| 273 | 326 | ||
| 274 | func doorIsVanilla(door): | 327 | func doorIsVanilla(door): | 
| 275 | return !_mentioned_doors.has(door) | 328 | return !_mentioned_doors.has(door) | 
| diff --git a/Archipelago/load.gd b/Archipelago/load.gd index d17bfac..ca1269b 100644 --- a/Archipelago/load.gd +++ b/Archipelago/load.gd | |||
| @@ -38,11 +38,17 @@ func _load(): | |||
| 38 | "answer_correct", location, "handle_correct" | 38 | "answer_correct", location, "handle_correct" | 
| 39 | ) | 39 | ) | 
| 40 | 40 | ||
| 41 | # Hardcode THE END as the goal for now. | 41 | # Hardcode THE END as the goal for now. | 
| 42 | var the_end = self.get_node("Decorations/EndPanel/Panel_end_end") | 42 | var the_end = self.get_node("Decorations/EndPanel/Panel_end_end") | 
| 43 | the_end.get_node("Viewport/GUI/Panel/TextEdit").connect( | 43 | the_end.get_node("Viewport/GUI/Panel/TextEdit").connect( | 
| 44 | "answer_correct", apclient, "completedGoal" | 44 | "answer_correct", apclient, "completedGoal" | 
| 45 | ) | 45 | ) | 
| 46 | |||
| 47 | # Create the messages node. | ||
| 48 | var messages_script = ResourceLoader.load("user://maps/Archipelago/messages.gd") | ||
| 49 | var messages = messages_script.new() | ||
| 50 | messages.set_name("AP_Messages") | ||
| 51 | self.add_child(messages) | ||
| 46 | 52 | ||
| 47 | # Proceed with the rest of the load. | 53 | # Proceed with the rest of the load. | 
| 48 | global._print("Hooked Load End") | 54 | global._print("Hooked Load End") | 
| diff --git a/Archipelago/messages.gd b/Archipelago/messages.gd new file mode 100644 index 0000000..63ce182 --- /dev/null +++ b/Archipelago/messages.gd | |||
| @@ -0,0 +1,35 @@ | |||
| 1 | extends Node | ||
| 2 | |||
| 3 | |||
| 4 | func _ready(): | ||
| 5 | var label = Label.new() | ||
| 6 | label.set_name("label") | ||
| 7 | label.margin_right = 1920.0 | ||
| 8 | label.margin_bottom = 1080.0 - 20 | ||
| 9 | label.margin_left = 20.0 | ||
| 10 | label.align = Label.ALIGN_LEFT | ||
| 11 | label.valign = Label.VALIGN_BOTTOM | ||
| 12 | |||
| 13 | var dynamic_font = DynamicFont.new() | ||
| 14 | dynamic_font.font_data = load("res://fonts/Lingo.ttf") | ||
| 15 | dynamic_font.size = 36 | ||
| 16 | dynamic_font.outline_color = Color(0, 0, 0, 1) | ||
| 17 | dynamic_font.outline_size = 2 | ||
| 18 | label.add_font_override("font", dynamic_font) | ||
| 19 | |||
| 20 | add_child(label) | ||
| 21 | |||
| 22 | |||
| 23 | func showMessage(text): | ||
| 24 | var label = self.get_node("label") | ||
| 25 | if !label.text == "": | ||
| 26 | label.text += "\n" | ||
| 27 | label.text += text | ||
| 28 | |||
| 29 | yield(get_tree().create_timer(10.0), "timeout") | ||
| 30 | |||
| 31 | var newline = label.text.find("\n") | ||
| 32 | if newline == -1: | ||
| 33 | label.text = "" | ||
| 34 | else: | ||
| 35 | label.text = label.text.substr(newline + 1) | ||
