Mercurial > boomslang
diff pyntnclick/gamescreen.py @ 677:a8c42709a689 pyntnclick
Event-driven inventory management magic. No more inventory recreation every frame!
author | Jeremy Thurgood <firxen@gmail.com> |
---|---|
date | Sun, 12 Feb 2012 19:47:56 +0200 |
parents | 106efeae9745 |
children | 36d7f7e9650e |
line wrap: on
line diff
--- a/pyntnclick/gamescreen.py Sun Feb 12 19:29:31 2012 +0200 +++ b/pyntnclick/gamescreen.py Sun Feb 12 19:47:56 2012 +0200 @@ -105,9 +105,11 @@ def up_callback(self, event, widget): self.inv_offset = max(self.inv_offset - len(self.slots), 0) + self.update_slots() def down_callback(self, event, widget): self.inv_offset += len(self.slots) + self.update_slots() def update_slots(self): items = (self.slot_items + [None] * len(self.slots))[:len(self.slots)] @@ -126,20 +128,12 @@ self.down_button.enable() def draw(self, surface): - self.update_slots() super(InventoryView, self).draw(surface) @property def slot_items(self): return self.game.inventory[self.inv_offset:][:len(self.slots)] - def draw_updown(self, surface): - rect = Rect((self.rect.width - self.updown_width, 0), - (self.updown_width, self.rect.height)) - s = Surface(rect.size) - s.fill(Color("blue")) - surface.blit(s, rect) - def mouse_down(self, event, widget): if event.button != 1: self.game.cancel_doodah(self.screen) @@ -360,6 +354,8 @@ def process_event(self, event_name, data): if event_name == 'restart': self.start_game() + elif event_name == 'inventory': + self.inventory.update_slots() def start_game(self): self._clear_all()