Factor out frame based actors.
authorSimon Cross <hodgestar@gmail.com>
Sat, 5 Mar 2016 14:52:13 +0000 (16:52 +0200)
committerSimon Cross <hodgestar@gmail.com>
Sat, 5 Mar 2016 14:52:13 +0000 (16:52 +0200)
koperkapel/roaches.py

index 95353ee18a441bdf947bb4cf07586c41e1faa18b..c844b5277c404c41c4448239d58daa564fecb570 100644 (file)
@@ -1,10 +1,8 @@
 """ Tools for creating roach actors. """
 
-import random
-from pgzero.clock import each_tick
 from pgzero.loaders import images
 from pygame.constants import BLEND_RGBA_MULT
-from .actors.orientatedsurf import OrientatedSurfActor
+from .actors.animsurf import AnimatedSurfActor
 from .serums import roach_serum_color
 
 
@@ -15,24 +13,6 @@ def roach_by_name(world, roach_name):
     return roaches[0]
 
 
-class RoachActor(OrientatedSurfActor):
-    def __init__(self, frames):
-        self._frames = frames
-        self._frame = random.randint(0, len(frames) - 1)
-        self._dt = 0
-        self._cycle_dt = 0.2
-        each_tick(self.update)
-        super().__init__(surf=frames[self._frame], angle=0)
-
-    def update(self, dt):
-        self._dt += dt
-        while self._dt > self._cycle_dt:
-            self._dt -= self._cycle_dt
-            self._frame += 1
-            self._frame %= len(self._frames)
-        self.surf = self._frames[self._frame]
-
-
 class WorldRoach(object):
     """A roach proxy with no properties for display on the game level."""
 
@@ -61,7 +41,7 @@ class RoachFactory:
         frames = [
             self.assemble_frame(i, color, roach_data)
             for i in range(self.frames)]
-        return RoachActor(frames)
+        return AnimatedSurfActor(frames)
 
 
 default_roaches = RoachFactory("")