pybeamshow/effects/effect.py

86 lines
2.4 KiB
Python
Raw Normal View History

2023-02-17 02:06:34 +01:00
from dataclasses import dataclass
from enum import Enum
import math
import random
2023-02-18 22:51:52 +01:00
from typing import Generator, Tuple
2023-02-15 21:08:47 +01:00
import pygame as pg
from abc import abstractmethod
2023-02-18 22:51:52 +01:00
def copy_color(source: pg.Color) -> pg.Color:
return pg.Color(source.r, source.g, source.b, source.a)
2023-02-17 02:06:34 +01:00
@dataclass(frozen=True, slots=True)
class Colors:
Black = pg.Color(0, 0, 0)
White = pg.Color(255, 255, 255)
Red = pg.Color(255, 0, 0)
Green = pg.Color(0, 255, 0)
Blue = pg.Color(0, 0, 255)
Cyan = pg.Color(0, 255, 255)
Yellow = pg.Color(255, 255, 0)
Magenta = pg.Color(255, 0, 255)
2023-02-18 23:17:03 +01:00
def color_wheel(hue=0, increase=1) -> Generator[pg.Color, None, None]:
2023-02-18 22:51:52 +01:00
color = copy_color(Colors.Red)
2023-02-15 22:37:45 +01:00
h, s, l, a = color.hsla
2023-02-18 22:51:52 +01:00
h = hue
2023-02-15 22:37:45 +01:00
while True:
2023-02-18 22:51:52 +01:00
color.hsla = h, s, l, a
2023-02-15 22:37:45 +01:00
yield color
h = (h + increase) % 360
2023-02-18 23:17:03 +01:00
def color_randomize() -> Generator[pg.Color, None, None]:
2023-02-18 22:51:52 +01:00
color = copy_color(Colors.Red)
2023-02-17 02:06:34 +01:00
h, s, l, a = color.hsla
color.hsla = random.randint(0, 359), s, l, a
while True:
yield color
color.hsla = random.randint(0, 359), s, l, a
def transform_bounce(
bounds: pg.Rect,
velocity: Tuple[int, int],
x_factor: Tuple[int, int],
y_factor: Tuple[int, int],
2023-02-18 23:17:03 +01:00
) -> Generator[Tuple[int, int], Tuple[int, int], None]:
2023-02-17 02:06:34 +01:00
min_velocity = velocity[0]
max_velocity = velocity[1]
2023-02-18 23:17:03 +01:00
current_velocity = random.randint(min_velocity, max_velocity)
2023-02-17 02:06:34 +01:00
ticks = random.randint(0, 360)
2023-02-18 23:17:03 +01:00
current_x_factor = random.uniform(x_factor[0], x_factor[1])
current_y_factor = random.uniform(y_factor[0], y_factor[1])
2023-02-17 02:06:34 +01:00
size_x, size_y = yield (bounds.centerx, bounds.centery)
while True:
2023-02-18 23:17:03 +01:00
pos_x = int(
math.cos(current_x_factor * ticks) * (bounds.width - size_x) // 2
+ bounds.centerx
2023-02-17 02:06:34 +01:00
)
2023-02-18 23:17:03 +01:00
pos_y = int(
math.sin(current_y_factor * ticks) * (bounds.height - size_y) // 2
+ bounds.centery
2023-02-17 02:06:34 +01:00
)
2023-02-18 23:17:03 +01:00
ticks += int(current_velocity / 180 * math.pi)
current_velocity = random.randint(min_velocity, max_velocity)
2023-02-17 02:06:34 +01:00
size_x, size_y = yield (pos_x, pos_y)
2023-02-15 21:08:47 +01:00
class Effect(pg.sprite.Sprite):
def __init__(
self, image: pg.Surface, rect: pg.Rect, *groups: pg.sprite.Group
) -> None:
super().__init__(*groups)
self.rect = rect
self.image = image
def draw(self, surface: pg.Surface):
surface.blit(self.image, self.rect)