regeländerung und formatierung
This commit is contained in:
parent
c48222991b
commit
c110dd67c7
1 changed files with 94 additions and 54 deletions
72
main.py
72
main.py
|
@ -50,6 +50,7 @@ def finde_nachbarn(x, y):
|
|||
bel = (y + 1) % feldy, (x - 1) % feldx
|
||||
return [ovl, ov, ovr, r, l, bel, be, ber]
|
||||
|
||||
|
||||
def verarbeite_feld(feld):
|
||||
feldx, feldy = len(feld[0]), len(feld) # bekomme feld größe
|
||||
feld2 = copy.deepcopy(feld) # mache neue kopie
|
||||
|
@ -60,25 +61,32 @@ def verarbeite_feld(feld):
|
|||
if feld[pos[0]][pos[1]]:
|
||||
lives += 1
|
||||
if feld[y][x]:
|
||||
if lives <= 1:new = False
|
||||
elif lives >= 4:new = False
|
||||
else: new = True
|
||||
if lives <= 1 or lives >= 4:
|
||||
new = False
|
||||
else:
|
||||
if lives == 3:new = True
|
||||
else: new = False
|
||||
new = True
|
||||
else:
|
||||
if lives == 3:
|
||||
new = True
|
||||
else:
|
||||
new = False
|
||||
feld2[y][x] = new
|
||||
return feld2 # gib kopie zurück
|
||||
|
||||
|
||||
## Funktion zum Verarbeiten des Feldes
|
||||
|
||||
|
||||
def make_feld(size, rand):
|
||||
x = screensize[0] // size
|
||||
y = screensize[1] // size
|
||||
if rand:
|
||||
feld = [[random.choice([False, True]) for _ in range(x)] for _ in range(y)]
|
||||
else: feld = [[False for _ in range(x)] for _ in range(y)]
|
||||
else:
|
||||
feld = [[False for _ in range(x)] for _ in range(y)]
|
||||
return feld, x, y
|
||||
|
||||
|
||||
def resize_feld(feld, new_size, fill_with=False):
|
||||
sx = screensize[0] // new_size
|
||||
sy = screensize[1] // new_size
|
||||
|
@ -93,11 +101,14 @@ def resize_feld(feld, new_size, fill_with=False):
|
|||
new_feld[y][x] = fill_with
|
||||
return new_feld, sx, sy
|
||||
|
||||
|
||||
def setbutton_pos():
|
||||
global buttons
|
||||
for i, button in enumerate(buttons):
|
||||
i += 1
|
||||
button.pos = (screensize[0] - 70, button_abstandy * i)
|
||||
|
||||
|
||||
## klassen
|
||||
|
||||
|
||||
|
@ -123,7 +134,15 @@ buttons = [
|
|||
Button(screen, (200, 200, 200), (screensize[0] - 70, 50), 100, 25, "Randomize"),
|
||||
Button(screen, (200, 200, 200), (screensize[0] - 70, 50), 100, 25, "Clear"),
|
||||
]
|
||||
buttona = {"dropdown": 0, "debug": 1, "reset": 2, "zoom": 3, "pause": 4, "random": 5, "clear": 6}
|
||||
buttona = {
|
||||
"dropdown": 0,
|
||||
"debug": 1,
|
||||
"reset": 2,
|
||||
"zoom": 3,
|
||||
"pause": 4,
|
||||
"random": 5,
|
||||
"clear": 6,
|
||||
}
|
||||
setbutton_pos()
|
||||
buttonhovered = [False, False, False, False, False, False, False]
|
||||
buttons_to_render = 6 # button begrenzung
|
||||
|
@ -143,15 +162,24 @@ if __name__ == "__main__":
|
|||
if True in pressed_keys:
|
||||
if pressed_keys[pygame.K_ESCAPE]:
|
||||
exit()
|
||||
if pressed_keys[pygame.K_PLUS] and not before_pressed_keys[pygame.K_PLUS]:
|
||||
if (
|
||||
pressed_keys[pygame.K_PLUS]
|
||||
and not before_pressed_keys[pygame.K_PLUS]
|
||||
):
|
||||
pixelsize += 2
|
||||
feld, feldx, feldy = resize_feld(feld, pixelsize)
|
||||
if pressed_keys[pygame.K_MINUS] and not before_pressed_keys[pygame.K_MINUS]:
|
||||
if (
|
||||
pressed_keys[pygame.K_MINUS]
|
||||
and not before_pressed_keys[pygame.K_MINUS]
|
||||
):
|
||||
pixelsize -= 2
|
||||
feld, feldx, feldy = resize_feld(feld, pixelsize)
|
||||
if pressed_keys[pygame.K_d] and not before_pressed_keys[pygame.K_d]:
|
||||
show_debug = not show_debug
|
||||
if pressed_keys[pygame.K_SPACE] and not before_pressed_keys[pygame.K_SPACE]:
|
||||
if (
|
||||
pressed_keys[pygame.K_SPACE]
|
||||
and not before_pressed_keys[pygame.K_SPACE]
|
||||
):
|
||||
pause = not pause
|
||||
if pressed_keys[pygame.K_r] and not before_pressed_keys[pygame.K_r]:
|
||||
feld, feldx, feldy = make_feld(pixelsize, False)
|
||||
|
@ -185,11 +213,17 @@ if __name__ == "__main__":
|
|||
else:
|
||||
feld[my // pixelsize][mx // pixelsize] = False
|
||||
|
||||
if mousepressed[0] and not before_mousepressed[0]: # einmalklick von maus erfassen
|
||||
if buttonhovered[buttona["dropdown"]]: # falls button "dropdown" mit index von buttona = True
|
||||
if (
|
||||
mousepressed[0] and not before_mousepressed[0]
|
||||
): # einmalklick von maus erfassen
|
||||
if buttonhovered[
|
||||
buttona["dropdown"]
|
||||
]: # falls button "dropdown" mit index von buttona = True
|
||||
dropdown = not dropdown
|
||||
if dropdown:
|
||||
buttons_to_render = len(buttons) # dropdown menü begrenzen indem man nicht alle buttons verarbeitet
|
||||
buttons_to_render = len(
|
||||
buttons
|
||||
) # dropdown menü begrenzen indem man nicht alle buttons verarbeitet
|
||||
buttons[buttona["dropdown"]].text = "\/"
|
||||
else:
|
||||
buttons_to_render = 1
|
||||
|
@ -200,7 +234,9 @@ if __name__ == "__main__":
|
|||
feld, feldx, feldy = make_feld(pixelsize, False)
|
||||
if buttonhovered[buttona["zoom"]]:
|
||||
pixelsize += 2
|
||||
feld, feldx, feldy = resize_feld(feld,pixelsize,False)#make_feld(pixelsize,False)
|
||||
feld, feldx, feldy = resize_feld(
|
||||
feld, pixelsize, False
|
||||
) # make_feld(pixelsize,False)
|
||||
if buttonhovered[buttona["clear"]]:
|
||||
feld, feldx, feldy = make_feld(pixelsize, False)
|
||||
if buttonhovered[buttona["random"]]:
|
||||
|
@ -210,9 +246,13 @@ if __name__ == "__main__":
|
|||
if mousepressed[2] and not before_mousepressed[2]:
|
||||
if buttonhovered[buttona["zoom"]]:
|
||||
pixelsize -= 2
|
||||
feld, feldx, feldy = resize_feld(feld,pixelsize,False)#make_feld(pixelsize,False)
|
||||
feld, feldx, feldy = resize_feld(
|
||||
feld, pixelsize, False
|
||||
) # make_feld(pixelsize,False)
|
||||
|
||||
before_buttonhovered = buttonhovered # bevorige maus und button hover daten erfassen
|
||||
before_buttonhovered = (
|
||||
buttonhovered # bevorige maus und button hover daten erfassen
|
||||
)
|
||||
before_mousepressed = mousepressed
|
||||
before_pressed_keys = pressed_keys
|
||||
if not pause:
|
||||
|
|
Loading…
Reference in a new issue