X-Git-Url: https://plomlompom.com/repos/foo.html?a=blobdiff_plain;f=new%2Fplomrogue%2Fmapping.py;h=b670938e64658e2ff34306483bdb6cb7adf12d77;hb=804c0812954c9ab11bffaef5fee644ee4350b2a6;hp=4c7658de4af83168481d24f3d16edd23a67f1813;hpb=b65fcff5e5499f5c3c57f0c4d8f205643be5ebb7;p=plomrogue2-experiments
diff --git a/new/plomrogue/mapping.py b/new/plomrogue/mapping.py
index 4c7658d..b670938 100644
--- a/new/plomrogue/mapping.py
+++ b/new/plomrogue/mapping.py
@@ -20,7 +20,7 @@ class Map:
def __init__(self, size=YX(0, 0), init_char = '?', start_indented=True):
self.size = size
- self.terrain = init_char*self.size_i
+ self.terrain = init_char * self.size_i
self.start_indented = start_indented
def __getitem__(self, yx):
@@ -64,6 +64,12 @@ class Map:
+class MapChunk(Map):
+ awake = 0 # asleep if zero
+ stats = {}
+
+
+
class MapGeometry():
def get_directions(self):
@@ -101,17 +107,20 @@ class MapGeometry():
def pos_in_view(self, pos, offset, maps_size):
return self.undouble_coordinate(maps_size, pos) - offset
- def get_view(self, maps_size, get_map, radius, view_offset):
+ def get_view_and_seen_maps(self, maps_size, get_map, radius, view_offset):
m = Map(size=YX(radius*2+1, radius*2+1),
start_indented=(view_offset.y % 2 == 0))
+ seen_maps = []
for pos in m:
seen_pos = self.correct_double_coordinate(maps_size, (0,0),
pos + view_offset)
- seen_map = get_map(seen_pos[0], False)
+ if seen_pos[0] not in seen_maps:
+ seen_maps += [seen_pos[0]]
+ seen_map = get_map(seen_pos[0])
if seen_map is None:
seen_map = Map(size=maps_size)
m[pos] = seen_map[seen_pos[1]]
- return m
+ return m, seen_maps
def correct_double_coordinate(self, map_size, big_yx, little_yx):