aboutsummaryrefslogtreecommitdiff
path: root/client/map
diff options
context:
space:
mode:
authortpart <tpart120@proton.me>2026-02-26 20:41:51 +0100
committertpart <tpart120@proton.me>2026-02-26 20:49:58 +0100
commitcabc45cd02d2159d89bb37fc29bf83a23e89b8f0 (patch)
tree9a6ac402a1dbe3f396468ab74f000a7b24c76d3f /client/map
parent04dd47d13a8da9224e7f9ea8ccacf64129717ec1 (diff)
downloadhurrycurry-cabc45cd02d2159d89bb37fc29bf83a23e89b8f0.tar
hurrycurry-cabc45cd02d2159d89bb37fc29bf83a23e89b8f0.tar.bz2
hurrycurry-cabc45cd02d2159d89bb37fc29bf83a23e89b8f0.tar.zst
Fix kitchen background not working
Diffstat (limited to 'client/map')
-rw-r--r--client/map/kitchen_background.gd25
-rw-r--r--client/map/map.gd4
2 files changed, 17 insertions, 12 deletions
diff --git a/client/map/kitchen_background.gd b/client/map/kitchen_background.gd
index 4b728a94..a638ad5f 100644
--- a/client/map/kitchen_background.gd
+++ b/client/map/kitchen_background.gd
@@ -22,13 +22,13 @@ func _ready() -> void:
func init_map():
var map_tile = func (t): match t:
- ".": return "floor"
- "=": return "counter"
- "s": return "stove"
- "c": return "chair"
- "t": return "table"
- "o": return "oven"
- "#": return "wall"
+ ".": return ["floor"]
+ "=": return ["counter"]
+ "s": return ["stove"]
+ "c": return ["chair"]
+ "t": return ["table"]
+ "o": return ["oven"]
+ "#": return ["wall"]
_: push_error("unknown tile: ", t)
var tiles = [
"...............",
@@ -39,9 +39,10 @@ func init_map():
".............=#",
".............=#"
].map(func (l): return Array(l.split("")).map(map_tile))
- var gt = func (e): return null if e[1] >= tiles.size() else null if e[0] >= tiles[e[1]].size() else tiles[e[1]][e[0]]
- var co = Vector2i(floor(tiles[0].size() / 2), floor(tiles.size() - 2))
- for y in tiles.size():
- for x in tiles[y].size():
- map.set_tile(Vector2i(x,y) - co, gt.call([x,y]), [[x,y-1],[x-1,y],[x,y+1],[x+1,y]].map(gt))
+ var offset = Vector2i(floor(tiles[0].size() / 2), floor(tiles.size() - 2))
+ var pos_to_tile: Dictionary[Vector2i, Array] = {} # : Dictionary[Vector2i, Array[String]]
+ for y in range(tiles.size()):
+ for x in range(tiles[y].size()):
+ pos_to_tile[Vector2i(x,y) - offset] = tiles[y][x]
+ map.set_all_tiles(pos_to_tile)
map.flush()
diff --git a/client/map/map.gd b/client/map/map.gd
index afac0a1b..acf7c1a4 100644
--- a/client/map/map.gd
+++ b/client/map/map.gd
@@ -41,6 +41,10 @@ func get_tile_instance(pos: Vector2i) -> Tile:
if e != null: return e.tile
else: return null
+func set_all_tiles(changes: Dictionary[Vector2i, Array]):
+ for pos: Vector2i in changes:
+ set_tiles(Vector2i(pos.x, pos.y), changes[pos], changes)
+
func set_tiles(pos: Vector2i, tiles: Array = [], pending_changes: Dictionary[Vector2i, Array] = {}): # tiles: Array[String]
var inst = get_tile_instance(pos)
if inst != null and not tiles.is_empty():