Merge branch 'master' of ctpug.org.za:koperkapel
authorSimon Cross <hodgestar@gmail.com>
Sat, 5 Mar 2016 14:53:09 +0000 (16:53 +0200)
committerSimon Cross <hodgestar@gmail.com>
Sat, 5 Mar 2016 14:53:09 +0000 (16:53 +0200)
koperkapel/actors/animsurf.py [new file with mode: 0644]
koperkapel/roaches.py

diff --git a/koperkapel/actors/animsurf.py b/koperkapel/actors/animsurf.py
new file mode 100644 (file)
index 0000000..fb9e73a
--- /dev/null
@@ -0,0 +1,23 @@
+""" Surface-based actor with multiple frames. """
+
+import random
+from pgzero.clock import each_tick
+from .orientatedsurf import OrientatedSurfActor
+
+
+class AnimatedSurfActor(OrientatedSurfActor):
+    def __init__(self, frames, cycle_dt=0.2):
+        self._frames = frames
+        self._frame = random.randint(0, len(frames) - 1)
+        self._dt = 0
+        self._cycle_dt = cycle_dt
+        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]
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("")