import random from cosmic import CosmicUnicorn graphics = None colour = (230, 150, 0) def init(): global width, height, lifetime, age width = CosmicUnicorn.WIDTH height = CosmicUnicorn.HEIGHT lifetime = [[0.0 for y in range(height)] for x in range(width)] age = [[0.0 for y in range(height)] for x in range(width)] for y in range(height): for x in range(width): lifetime[x][y] = 1.0 + random.uniform(0.0, 0.1) age[x][y] = random.uniform(0.0, 1.0) * lifetime[x][y] @micropython.native # noqa: F821 def draw(): for y in range(height): for x in range(width): if age[x][y] >= lifetime[x][y]: age[x][y] = 0.0 lifetime[x][y] = 1.0 + random.uniform(0.0, 0.1) age[x][y] += 0.025 for y in range(height): for x in range(width): if age[x][y] < lifetime[x][y] * 0.3: graphics.set_pen(graphics.create_pen(colour[0], colour[1], colour[2])) elif age[x][y] < lifetime[x][y] * 0.5: decay = (lifetime[x][y] * 0.5 - age[x][y]) * 5.0 graphics.set_pen(graphics.create_pen(int(decay * colour[0]), int(decay * colour[1]), int(decay * colour[2]))) else: graphics.set_pen(0) graphics.pixel(x, y)