diff --git a/gamedata/objects/bg/menubackground.py b/gamedata/objects/bg/menubackground.py index 04e3584..7ae6b1f 100644 --- a/gamedata/objects/bg/menubackground.py +++ b/gamedata/objects/bg/menubackground.py @@ -1,4 +1,6 @@ from gamedata.objects.base import BaseObject +from gamedata.objects.fallingpinmik import FallingPinmik +import random class MenuBackground(BaseObject): @@ -7,11 +9,14 @@ class MenuBackground(BaseObject): # Islands self.sprite = game.sprite_lib["islands.png"] - + self.depth = -2 self.cameraratio = 0.1 + # Pinmik falling + self.pinmiktimer = game.lib.Timer(1) + def step(self): game = self.game @@ -20,6 +25,10 @@ class MenuBackground(BaseObject): game.globals["camerax"] += (destx-game.globals["camerax"])/6 game.globals["cameray"] += (desty-game.globals["cameray"])/6 + if self.pinmiktimer.tick(self.game.dt): + self.pinmiktimer = game.lib.Timer(1+random.random()) + self.game.gameloop.summon(FallingPinmik(game)) + def draw(self): game = self.game game.window.blit(self.sprite,[-game.globals["camerax"]*self.cameraratio,-game.globals["cameray"]*self.cameraratio]) diff --git a/gamedata/objects/fallingpinmik.py b/gamedata/objects/fallingpinmik.py new file mode 100644 index 0000000..a5d5c3a --- /dev/null +++ b/gamedata/objects/fallingpinmik.py @@ -0,0 +1,27 @@ +from gamedata.objects.base import BaseObject +import random + +class FallingPinmik(BaseObject): + + def __init__(self,game): + + x = random.randint(0,game.DISPLAY_WIDTH) + y = -30 + + super().__init__(x,y,game,0,0) + + self.cameraratio = random.random()*0.1+0.05 + + self.sprite = game.sprite_lib["lemmings/falling.png"] + + self.offset = 0 + self.speed = 100*(0.30-self.cameraratio)/0.30 + + self.depth = -1.5 + + def step(self): + + self.offset+=self.game.dt*self.speed + + def draw(self): + self.game.lib.drawcenter(self.game,self.sprite,self.rect[0]-self.game.globals["camerax"]*self.cameraratio,self.rect[1]+self.offset-self.game.globals["cameray"]*self.cameraratio)