Merge branch 'master' of ctpug.org.za:koperkapel
[koperkapel.git] / koperkapel / scenes / roach_management.py
index c0e82107a93ec56ed08059e8dba3a89bbaa56b3c..6c867fb4f196142b424a7508c063b7bca751026f 100644 (file)
@@ -1,8 +1,11 @@
 """ Roach management scene. """
 
+from pygame.constants import BLEND_RGBA_MULT, BLEND_RGBA_SUB
 from pgzero.constants import keys, mouse
 from pgzero.actor import Actor
+from pgzero.screen import Screen
 from ..actors.buttons import ImageButton
+from ..actors.surf import SurfActor
 from ..constants import WIDTH, HEIGHT
 from ..roaches import big_roaches, roach_by_name
 from ..serums import big_serums, roach_is_serumless, SERUMS
@@ -57,7 +60,24 @@ class RoachesScene(Scene):
 
     def _init_bg(self):
         self.actors.default.clear()
-        self.actors.default.add(self._vehicle.roach_management_overlay())
+        overlay = self._vehicle.roach_management_overlay()
+        base = overlay.copy()
+        if self._level_scene is not None:
+            base.fill((0, 0, 0))
+            self._level_scene.draw(Screen(base))
+        else:
+            base.fill((10, 10, 10))
+        base.blit(overlay, (0, 0))
+        frame = self._vehicle.roach_management_frame()
+        if frame is not None:
+            frame = frame.copy()
+            frame.fill((255, 255, 255, 8), None, BLEND_RGBA_MULT)
+            frame_rect = frame.get_rect()
+            base.blit(frame, (
+                VEHICLE_MID_X - frame_rect.w // 2,
+                VEHICLE_MID_Y - frame_rect.h // 2),
+                None, BLEND_RGBA_SUB)
+        self.actors.default.add(SurfActor(base))
 
     def _init_seats(self):
         self._seat_layer.clear()