X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=tabakrolletjie%2Fscenes%2Fday.py;h=20b297e1ae7b070a1c99981f01f813fdb2480a69;hb=91a4b8b363cb25c8fe30a4c49bae171c508c7b0e;hp=31590d4bb3558eb3363edc0ea918cb909b0ffcda;hpb=58ac0aea3fcfbac1a3b2f8ec310c4f5d818bceb4;p=tabakrolletjie.git diff --git a/tabakrolletjie/scenes/day.py b/tabakrolletjie/scenes/day.py index 31590d4..20b297e 100644 --- a/tabakrolletjie/scenes/day.py +++ b/tabakrolletjie/scenes/day.py @@ -3,10 +3,11 @@ import pygame.locals as pgl import pymunk +import pymunk.pygame_util from .base import BaseScene -from ..lights import BaseLight -from ..obstacles import BaseObstacle +from ..lights import LightManager +from ..obstacles import ObstacleManager from ..events import SceneChangeEvent from ..utils import debug_timer @@ -14,33 +15,25 @@ from ..utils import debug_timer class DayScene(BaseScene): def enter(self, gamestate): self._space = pymunk.Space() - self._obstacles = [ - BaseObstacle.load(cfg) for cfg in gamestate.station["obstacles"]] - self._lights = [ - BaseLight.load(cfg) for cfg in gamestate.station["lights"]] - for obs in self._obstacles: - obs.add(self._space) - for light in self._lights: - light.add(self._space) + self._obstacles = ObstacleManager(self._space, gamestate) + self._lights = LightManager(self._space, gamestate) @debug_timer("day.render") def render(self, surface, gamestate): surface.fill((0, 0, 155)) - for light in self._lights: - light.render_light(surface) - for obs in self._obstacles: - obs.render(surface) - for light in self._lights: - light.render_fittings(surface) + self._lights.render_light(surface) + self._obstacles.render(surface) + self._lights.render_fittings(surface) def event(self, ev, gamestate): if ev.type == pgl.KEYDOWN: if ev.key in (pgl.K_q, pgl.K_ESCAPE): from .menu import MenuScene SceneChangeEvent.post(scene=MenuScene()) - elif ev.key == pgl.K_t: - for light in self._lights: - light.toggle() + elif ev.type == pgl.MOUSEBUTTONDOWN: + if ev.button == 1: + self._lights.toggle_nearest(ev.pos, surfpos=True) + print self._lights.lit_by(ev.pos, surfpos=True) @debug_timer("day.tick") def tick(self, gamestate):