X-Git-Url: https://plomlompom.com/repos/feed.xml?a=blobdiff_plain;f=plomrogue%2Fmapping.py;h=01c10e893c872322c44e7dab1c8bc571d270bf16;hb=3ab9a2ef6f42f109e9b8460be2ea3ebfcc0af19b;hp=58809ef8a2764cf7e3212e59687ae9e938013f86;hpb=cf8ab4843ff083bd174a30a5bb148ed3a9c531e2;p=plomrogue2 diff --git a/plomrogue/mapping.py b/plomrogue/mapping.py index 58809ef..01c10e8 100644 --- a/plomrogue/mapping.py +++ b/plomrogue/mapping.py @@ -20,6 +20,7 @@ class MapGeometry(): def __init__(self, size): self.size = size + self.neighbors_i = {} def get_directions(self): directions = [] @@ -34,6 +35,21 @@ class MapGeometry(): neighbors[direction] = self.move(pos, direction) return neighbors + def get_neighbors_i(self, i): + if i in self.neighbors_i: + return self.neighbors_i[i] + pos = YX(i // self.size.x, i % self.size.x) + neighbors_pos = self.get_neighbors(pos) + neighbors_i = {} + for direction in neighbors_pos: + pos = neighbors_pos[direction] + if pos is None: + neighbors_i[direction] = None + else: + neighbors_i[direction] = pos.y * self.size.x + pos.x + self.neighbors_i[i] = neighbors_i + return self.neighbors_i[i] + def move(self, start_pos, direction): mover = getattr(self, 'move_' + direction) target = mover(start_pos)