+ def power_usage(self):
+ if not self.on:
+ return 0.0
+ area = math.pi * (self.ray_manager.max_radius ** 2) # radius
+ area = area * (self.ray_manager.spread / (2 * math.pi)) # spread
+ return 5 * area * self.intensity
+
+ def base_damage(self):
+ return 5 * self.intensity
+
+ def toggle(self):
+ self.colour_pos += 1
+ if self.colour_pos >= len(self.colour_cycle):
+ self.colour = self.colour_cycle[0]
+ self.colour_pos = -1
+ self.on = False
+ else:
+ self.colour = self.colour_cycle[self.colour_pos]
+ self.on = True
+ self.invalidate_fitting_image()
+