X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=koperkapel%2Fscenes%2Froach_management.py;h=d5fc67ffe749bcb3039778b2f7142e29c96d47ec;hb=bc8a030300c8367c5412585ffe37c07ce2d7bcee;hp=e7dcd7c66b8c188b81cfd585ad6181fe1c7fe0d8;hpb=ac587543218e5179289e18a147e7118f10348dfe;p=koperkapel.git diff --git a/koperkapel/scenes/roach_management.py b/koperkapel/scenes/roach_management.py index e7dcd7c..d5fc67f 100644 --- a/koperkapel/scenes/roach_management.py +++ b/koperkapel/scenes/roach_management.py @@ -48,6 +48,7 @@ class RoachesScene(Scene): def enter(self, world): self._vehicle = Vehicle.current(world) + self._update_calls = [] self._init_bg() self._init_seats() self._init_roaches(world) @@ -91,7 +92,7 @@ class RoachesScene(Scene): def _update_roaches(self, world): self._roach_layer.clear() seating = self._vehicle.seating(world) - outside_roaches = [] + self._outside_roaches = [] for roach in world.roaches: seat_pos = seating.get(roach.name) if seat_pos is not None: @@ -99,16 +100,18 @@ class RoachesScene(Scene): roach_actor.pos = self._seat_layer[seat_pos].pos self._roach_layer.add(roach_actor) else: - outside_roaches.append(roach.name) - self._outside_roach_pos %= len(outside_roaches) - if outside_roaches: + self._outside_roaches.append(roach.name) + if self._outside_roaches: + self._outside_roach_pos %= len(self._outside_roaches) roach_actor = self._roach_actors[ - outside_roaches[self._outside_roach_pos]] + self._outside_roaches[self._outside_roach_pos]] roach_pad_center = self._roach_pad.center roach_actor.pos = ( roach_pad_center[0] + ROACH_PAD_OFFSET[0], roach_pad_center[1] + ROACH_PAD_OFFSET[1]) self._roach_layer.add(roach_actor) + else: + self._outside_roach_pos = 0 def _init_pads(self): self._roach_pad = self._pad_layer.add( @@ -163,12 +166,33 @@ class RoachesScene(Scene): self._seat_pos = seat_pos self._seat_layer[self._seat_pos].selected = True - def _eject_roach(self): - print("Eject roach.") + def _eject_roach(self, world=None): + if world is None: + self._update_calls.append(self._eject_roach) + return + self._vehicle.seat_roach(world, None, self._seat_pos) + + def _click_roach_pad(self, world=None): + if world is None: + self._update_calls.append(self._click_roach_pad) + return + if self._outside_roaches: + roach = self._outside_roaches[self._outside_roach_pos] + self._vehicle.seat_roach(world, roach, self._seat_pos) + + def _click_inventory_pad(self, world=None): + if world is None: + self._update_calls.append(self._click_inventory_pad) + return def update(self, world, engine, dt): + while self._update_calls: + f = self._update_calls.pop() + f(world) + events = world.pop_events() self._update_inventory(world) self._update_roaches(world) + return events def on_key_down(self, key, mod, unicode): if key == keys.ESCAPE: @@ -183,3 +207,7 @@ class RoachesScene(Scene): for i, actor in enumerate(self.actors.seats): if actor.collidepoint(pos): return self._select_seat(i) + if self._roach_pad.collidepoint(pos): + return self._click_roach_pad() + if self._inventory_pad.collidepoint(pos): + return self._click_inventory_pad()