mirror of
				https://github.com/d3vyce/Python-Game.git
				synced 2025-10-26 21:14:56 +01:00 
			
		
		
		
	
							
								
								
									
										154
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										154
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1 +1,153 @@ | |||||||
| venv | # Byte-compiled / optimized / DLL files | ||||||
|  | __pycache__/ | ||||||
|  | *.py[cod] | ||||||
|  | *$py.class | ||||||
|  |  | ||||||
|  | # C extensions | ||||||
|  | *.so | ||||||
|  |  | ||||||
|  | # Distribution / packaging | ||||||
|  | .Python | ||||||
|  | build/ | ||||||
|  | develop-eggs/ | ||||||
|  | dist/ | ||||||
|  | downloads/ | ||||||
|  | eggs/ | ||||||
|  | .eggs/ | ||||||
|  | lib/ | ||||||
|  | lib64/ | ||||||
|  | parts/ | ||||||
|  | sdist/ | ||||||
|  | var/ | ||||||
|  | wheels/ | ||||||
|  | share/python-wheels/ | ||||||
|  | *.egg-info/ | ||||||
|  | .installed.cfg | ||||||
|  | *.egg | ||||||
|  | MANIFEST | ||||||
|  |  | ||||||
|  | # PyInstaller | ||||||
|  | #  Usually these files are written by a python script from a template | ||||||
|  | #  before PyInstaller builds the exe, so as to inject date/other infos into it. | ||||||
|  | *.manifest | ||||||
|  | *.spec | ||||||
|  |  | ||||||
|  | # Installer logs | ||||||
|  | pip-log.txt | ||||||
|  | pip-delete-this-directory.txt | ||||||
|  |  | ||||||
|  | # Unit test / coverage reports | ||||||
|  | htmlcov/ | ||||||
|  | .tox/ | ||||||
|  | .nox/ | ||||||
|  | .coverage | ||||||
|  | .coverage.* | ||||||
|  | .cache | ||||||
|  | nosetests.xml | ||||||
|  | coverage.xml | ||||||
|  | *.cover | ||||||
|  | *.py,cover | ||||||
|  | .hypothesis/ | ||||||
|  | .pytest_cache/ | ||||||
|  | cover/ | ||||||
|  |  | ||||||
|  | # Translations | ||||||
|  | *.mo | ||||||
|  | *.pot | ||||||
|  |  | ||||||
|  | # Django stuff: | ||||||
|  | *.log | ||||||
|  | local_settings.py | ||||||
|  | db.sqlite3 | ||||||
|  | db.sqlite3-journal | ||||||
|  |  | ||||||
|  | # Flask stuff: | ||||||
|  | instance/ | ||||||
|  | .webassets-cache | ||||||
|  |  | ||||||
|  | # Scrapy stuff: | ||||||
|  | .scrapy | ||||||
|  |  | ||||||
|  | # Sphinx documentation | ||||||
|  | docs/_build/ | ||||||
|  |  | ||||||
|  | # PyBuilder | ||||||
|  | .pybuilder/ | ||||||
|  | target/ | ||||||
|  |  | ||||||
|  | # Jupyter Notebook | ||||||
|  | .ipynb_checkpoints | ||||||
|  |  | ||||||
|  | # IPython | ||||||
|  | profile_default/ | ||||||
|  | ipython_config.py | ||||||
|  |  | ||||||
|  | # pyenv | ||||||
|  | #   For a library or package, you might want to ignore these files since the code is | ||||||
|  | #   intended to run in multiple environments; otherwise, check them in: | ||||||
|  | # .python-version | ||||||
|  |  | ||||||
|  | # pipenv | ||||||
|  | #   According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control. | ||||||
|  | #   However, in case of collaboration, if having platform-specific dependencies or dependencies | ||||||
|  | #   having no cross-platform support, pipenv may install dependencies that don't work, or not | ||||||
|  | #   install all needed dependencies. | ||||||
|  | #Pipfile.lock | ||||||
|  |  | ||||||
|  | # poetry | ||||||
|  | #   Similar to Pipfile.lock, it is generally recommended to include poetry.lock in version control. | ||||||
|  | #   This is especially recommended for binary packages to ensure reproducibility, and is more | ||||||
|  | #   commonly ignored for libraries. | ||||||
|  | #   https://python-poetry.org/docs/basic-usage/#commit-your-poetrylock-file-to-version-control | ||||||
|  | #poetry.lock | ||||||
|  |  | ||||||
|  | # pdm | ||||||
|  | #   Similar to Pipfile.lock, it is generally recommended to include pdm.lock in version control. | ||||||
|  | #pdm.lock | ||||||
|  | #   pdm stores project-wide configurations in .pdm.toml, but it is recommended to not include it | ||||||
|  | #   in version control. | ||||||
|  | #   https://pdm.fming.dev/#use-with-ide | ||||||
|  | .pdm.toml | ||||||
|  |  | ||||||
|  | # PEP 582; used by e.g. github.com/David-OConnor/pyflow and github.com/pdm-project/pdm | ||||||
|  | __pypackages__/ | ||||||
|  |  | ||||||
|  | # Celery stuff | ||||||
|  | celerybeat-schedule | ||||||
|  | celerybeat.pid | ||||||
|  |  | ||||||
|  | # SageMath parsed files | ||||||
|  | *.sage.py | ||||||
|  |  | ||||||
|  | # Environments | ||||||
|  | .env | ||||||
|  | .venv | ||||||
|  | env/ | ||||||
|  | venv/ | ||||||
|  | ENV/ | ||||||
|  | env.bak/ | ||||||
|  | venv.bak/ | ||||||
|  |  | ||||||
|  | # Spyder project settings | ||||||
|  | .spyderproject | ||||||
|  | .spyproject | ||||||
|  |  | ||||||
|  | # Rope project settings | ||||||
|  | .ropeproject | ||||||
|  |  | ||||||
|  | # mkdocs documentation | ||||||
|  | /site | ||||||
|  |  | ||||||
|  | # mypy | ||||||
|  | .mypy_cache/ | ||||||
|  | .dmypy.json | ||||||
|  | dmypy.json | ||||||
|  |  | ||||||
|  | # Pyre type checker | ||||||
|  | .pyre/ | ||||||
|  |  | ||||||
|  | # pytype static type analyzer | ||||||
|  | .pytype/ | ||||||
|  |  | ||||||
|  | # Cython debug symbols | ||||||
|  | cython_debug/ | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								Snake/img/Snake.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								Snake/img/Snake.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 12 KiB | 
| @@ -0,0 +1,79 @@ | |||||||
|  | from ast import Break, Global | ||||||
|  | import pygame | ||||||
|  | from pygame.locals import * | ||||||
|  | import src.level as level | ||||||
|  | import src.snake as snake | ||||||
|  | import src.window as window | ||||||
|  |  | ||||||
|  | HEIGH = 20 | ||||||
|  | WIDTH = 40 | ||||||
|  |  | ||||||
|  | def main(): | ||||||
|  |     # Init Matrix/Window | ||||||
|  |     Matrix = level.init_level(HEIGH, WIDTH) | ||||||
|  |     Screen = window.init_game() | ||||||
|  |  | ||||||
|  |     # Init Game Variables | ||||||
|  |     clock = pygame.time.Clock() | ||||||
|  |     Running = True | ||||||
|  |     Direction = 'right' | ||||||
|  |     Direction_prev = 'right' | ||||||
|  |     Move_loop = 10 | ||||||
|  |     Score = 0 | ||||||
|  |     Difficulty = 1 | ||||||
|  |     Fruit = False | ||||||
|  |  | ||||||
|  |     # Spawn snake head | ||||||
|  |     L_snake = snake.List((5, 5), None) | ||||||
|  |  | ||||||
|  |     # Spawn first apple | ||||||
|  |     level.spawn_apple(Matrix, HEIGH, WIDTH) | ||||||
|  |  | ||||||
|  |     while Running: | ||||||
|  |         clock.tick(60) | ||||||
|  |  | ||||||
|  |         for event in pygame.event.get(): | ||||||
|  |             if event.type == pygame.KEYDOWN and event.key == pygame.K_ESCAPE: | ||||||
|  |                 Running = False | ||||||
|  |             if event.type == pygame.KEYDOWN and event.key == pygame.K_RIGHT: | ||||||
|  |                 Direction = 'right' | ||||||
|  |             if event.type == pygame.KEYDOWN and event.key == pygame.K_LEFT: | ||||||
|  |                 Direction = 'left' | ||||||
|  |             if event.type == pygame.KEYDOWN and event.key == pygame.K_UP: | ||||||
|  |                 Direction = 'up' | ||||||
|  |             if event.type == pygame.KEYDOWN and event.key == pygame.K_DOWN: | ||||||
|  |                 Direction = 'down' | ||||||
|  |  | ||||||
|  |         if Move_loop == 0: | ||||||
|  |             if Direction == 'left' and Direction_prev == 'right' or Direction == 'right' and Direction_prev == 'left' or Direction == 'up' and Direction_prev == 'down' or Direction == 'down' and Direction_prev == 'up': | ||||||
|  |                 Direction = Direction_prev | ||||||
|  |  | ||||||
|  |             try: | ||||||
|  |                 L_snake, Matrix, Fruit, Score = snake.Snake_move(Matrix, L_snake, Direction, Score, HEIGH, WIDTH) | ||||||
|  |             except ValueError as Error: | ||||||
|  |                 if Error.args[0] == 1: | ||||||
|  |                     print("You take a wall !") | ||||||
|  |                 elif Error.args[0] == 2: | ||||||
|  |                     print("You ate your tale !") | ||||||
|  |                 exit() | ||||||
|  |              | ||||||
|  |             if Fruit: | ||||||
|  |                 level.spawn_apple(Matrix, HEIGH, WIDTH) | ||||||
|  |              | ||||||
|  |             Direction_prev = Direction | ||||||
|  |             if(Score > 1000): | ||||||
|  |                 Difficulty = int(Score/1000) + 1 | ||||||
|  |             Move_loop = 11 - Difficulty | ||||||
|  |  | ||||||
|  |         Move_loop -= 1 | ||||||
|  |  | ||||||
|  |         # Draw Scene | ||||||
|  |         Screen = window.draw_level(Screen, Matrix, Difficulty, Score, int(clock.get_fps()), HEIGH, WIDTH) | ||||||
|  |         pygame.display.flip() | ||||||
|  |  | ||||||
|  |         # Print current fps | ||||||
|  |         print(float("{0:.2f}".format(clock.get_fps())), 'fps') | ||||||
|  |  | ||||||
|  |  | ||||||
|  | if __name__ == "__main__": | ||||||
|  |     main() | ||||||
| @@ -1 +1,2 @@ | |||||||
| pygame | pygame | ||||||
|  | numpy | ||||||
| @@ -0,0 +1,21 @@ | |||||||
|  | import numpy as np | ||||||
|  | import random | ||||||
|  |  | ||||||
|  | # 0 = AIR | ||||||
|  | # 1 = SNAKE | ||||||
|  | # 2 = WALL | ||||||
|  | # 3 = APPLE | ||||||
|  |  | ||||||
|  | def init_level(heigh, width): | ||||||
|  |     return np.zeros((heigh, width)) | ||||||
|  |  | ||||||
|  | def spawn_apple(M, heigh, width): | ||||||
|  |     random.seed() | ||||||
|  |     rand_heigh = random.randrange(0, heigh) | ||||||
|  |     rand_width = random.randrange(0, width) | ||||||
|  |  | ||||||
|  |     if M[rand_heigh][rand_width] == 0: | ||||||
|  |         M[rand_heigh][rand_width] = 3 | ||||||
|  |     else: | ||||||
|  |         spawn_apple(M, heigh, width) | ||||||
|  |      | ||||||
| @@ -0,0 +1,78 @@ | |||||||
|  |  | ||||||
|  | DIRECTION = {'left': (0, -1), 'right': (0, 1), 'up': (-1, 0), 'down': (1, 0)} | ||||||
|  |  | ||||||
|  | class List: | ||||||
|  |     def __init__(self, val, next): | ||||||
|  |         self.val = val | ||||||
|  |         self.next = next | ||||||
|  |  | ||||||
|  |     def __str__(self): | ||||||
|  |         if self.next == None: | ||||||
|  |             return(f"{self.val} -> None") | ||||||
|  |         else: | ||||||
|  |             return(f"{self.val} -> {str(self.next)}") | ||||||
|  |  | ||||||
|  |     def is_empty(L): | ||||||
|  |         return L is None | ||||||
|  |  | ||||||
|  |     def List_add(L, value): | ||||||
|  |         if L == None: | ||||||
|  |             return List(value, None) | ||||||
|  |         else: | ||||||
|  |             return List(L.val, List.List_add(L.next, value)) | ||||||
|  |  | ||||||
|  |     def List_size(L): | ||||||
|  |         i = 0 | ||||||
|  |         while L is not None: | ||||||
|  |             i += 1 | ||||||
|  |             L = L.next | ||||||
|  |          | ||||||
|  |         return i | ||||||
|  |  | ||||||
|  | def Snake_move(M, L, dir, score, heigh, width): | ||||||
|  |     Fruit = False | ||||||
|  |     List_save = L | ||||||
|  |     Save_Value = L.val | ||||||
|  |      | ||||||
|  |     # Calculate new snake head coord | ||||||
|  |     if dir == 'left' and L.val[1] == 0: | ||||||
|  |         Next_coord = (L.val[0], width-1) | ||||||
|  |     elif dir == 'right' and L.val[1] == width-1: | ||||||
|  |         Next_coord = (L.val[0], 0) | ||||||
|  |     elif dir == 'up' and L.val[0] == 0: | ||||||
|  |         Next_coord = (heigh-1, L.val[1]) | ||||||
|  |     elif dir == 'down' and L.val[0] == heigh-1: | ||||||
|  |         Next_coord = (0, L.val[1]) | ||||||
|  |     else: | ||||||
|  |         Next_coord = (DIRECTION[dir][0] + L.val[0], DIRECTION[dir][1] + L.val[1]) | ||||||
|  |  | ||||||
|  |     # Check nature of the future snake head coord | ||||||
|  |     if M[Next_coord[0]][Next_coord[1]] == 3: | ||||||
|  |         Fruit = True | ||||||
|  |     elif M[Next_coord[0]][Next_coord[1]] == 2:  | ||||||
|  |         raise ValueError(1)         # Error : You take a wall ! | ||||||
|  |         quit | ||||||
|  |     elif M[Next_coord[0]][Next_coord[1]] == 1: | ||||||
|  |         raise ValueError(2)         # Error : You ate your tale ! | ||||||
|  |         quit | ||||||
|  |  | ||||||
|  |     # Update snake head coord and print on matrix | ||||||
|  |     L.val = Next_coord | ||||||
|  |     M[Next_coord[0]][Next_coord[1]] = 1 | ||||||
|  |     L = L.next | ||||||
|  |  | ||||||
|  |     # Loot to update snake segment coord | ||||||
|  |     while L is not None: | ||||||
|  |         Save_bis_Value = L.val | ||||||
|  |         L.val = Save_Value | ||||||
|  |         Save_Value = Save_bis_Value | ||||||
|  |         L = L.next | ||||||
|  |      | ||||||
|  |     # If snake eat fruit -> spawn new segment at the end of the snake | ||||||
|  |     if Fruit: | ||||||
|  |         List_save = List.List_add(List_save, Save_Value) | ||||||
|  |         score += 50 | ||||||
|  |     else: | ||||||
|  |         M[Save_Value[0]][Save_Value[1]] = 0 | ||||||
|  |  | ||||||
|  |     return List_save, M, Fruit, score | ||||||
| @@ -0,0 +1,50 @@ | |||||||
|  | import pygame | ||||||
|  | from pygame.locals import * | ||||||
|  |  | ||||||
|  | def init_game(): | ||||||
|  |     pygame.init() | ||||||
|  |     pygame.font.init() | ||||||
|  |     screen = pygame.display.set_mode((1000, 525), pygame.SCALED) | ||||||
|  |     pygame.display.set_caption("Snake") | ||||||
|  |  | ||||||
|  |     return screen | ||||||
|  |  | ||||||
|  | def draw_level(S, M, difficulty, score, fps, heigh, width): | ||||||
|  |     WHITE = (255, 255, 255) # AIR | ||||||
|  |     GREEN = (0, 255, 0)     # SNAKE | ||||||
|  |     BROWN = (255,248,220)   # WALL | ||||||
|  |     RED = (255, 0, 0)       # APPLE | ||||||
|  |  | ||||||
|  |     # Reset screen | ||||||
|  |     pygame.draw.rect(S, (0, 0, 0), pygame.Rect(0, 0, 1000, 525)) | ||||||
|  |      | ||||||
|  |     my_font = pygame.font.SysFont('Comic Sans MS', 18) | ||||||
|  |  | ||||||
|  |     # Add FPS counter | ||||||
|  |     text_fps = my_font.render(str(fps) + ' fps', False, (255, 255, 255)) | ||||||
|  |     S.blit(text_fps, (10, 0)) | ||||||
|  |      | ||||||
|  |     # Add Score | ||||||
|  |     text_score = my_font.render('Score : '+ str(score), False, (255, 255, 255)) | ||||||
|  |     S.blit(text_score, (400, 0)) | ||||||
|  |  | ||||||
|  |     # Add Diffucilty | ||||||
|  |     text_difficulty = my_font.render('Difficulty : '+ str(difficulty), False, (255, 255, 255)) | ||||||
|  |     S.blit(text_difficulty, (850, 0)) | ||||||
|  |  | ||||||
|  |     Color = WHITE | ||||||
|  |  | ||||||
|  |     for j in range(heigh): | ||||||
|  |         for i in range(width): | ||||||
|  |             if M[j][i] == 0: | ||||||
|  |                 Color = WHITE | ||||||
|  |             elif M[j][i] == 1: | ||||||
|  |                 Color = GREEN | ||||||
|  |             elif M[j][i] == 2: | ||||||
|  |                 Color = BROWN | ||||||
|  |             elif M[j][i] == 3: | ||||||
|  |                 Color = RED | ||||||
|  |  | ||||||
|  |             pygame.draw.rect(S, Color, pygame.Rect(i*25, j*25+25, 25, 25)) | ||||||
|  |      | ||||||
|  |     return S | ||||||
		Reference in New Issue
	
	Block a user