update: master
This commit is contained in:
		
							parent
							
								
									7f6b65bdf3
								
							
						
					
					
						commit
						ecdd0c59ca
					
				
							
								
								
									
										276
									
								
								main.py
									
									
									
									
									
								
							
							
						
						
									
										276
									
								
								main.py
									
									
									
									
									
								
							| @ -0,0 +1,276 @@ | |||||||
|  | import arcade | ||||||
|  | import json | ||||||
|  | import math | ||||||
|  | import random | ||||||
|  | from fill_level import filler | ||||||
|  | 
 | ||||||
|  | SCREEN_WIDTH = 800 | ||||||
|  | SCREEN_HEIGHT = 600 | ||||||
|  | 
 | ||||||
|  | class food(): | ||||||
|  |     def __init__(self, x, y, healf = 1): | ||||||
|  |         self.x = x | ||||||
|  |         self.y = y | ||||||
|  |         self.healf = healf | ||||||
|  |      | ||||||
|  | class body(): | ||||||
|  |     def __init__(self, x, y, rotate, type): | ||||||
|  |         self.x = x | ||||||
|  |         self.y = y | ||||||
|  |         self.rotate = rotate | ||||||
|  |         self.type = type | ||||||
|  |      | ||||||
|  | class SNAKE(): | ||||||
|  |     def __init__(self, star_point_x, star_point_y, start_rotate = 90): | ||||||
|  |         self.body = [ | ||||||
|  |             body(star_point_x, star_point_y, start_rotate, "head"), | ||||||
|  |             body(star_point_x - 1, star_point_y, start_rotate, "tail") | ||||||
|  |         ] | ||||||
|  |     def check_contact(self,x,y): | ||||||
|  |         cont = 0 | ||||||
|  |         for body in self.body: | ||||||
|  |             if body.x == x and body.y == y: | ||||||
|  |                 cont = 1 | ||||||
|  |         return cont | ||||||
|  |     def add_dody(self): | ||||||
|  |         self.body[len(self.body)-1].type = "body" | ||||||
|  |         last_body = self.body[len(self.body)-1] | ||||||
|  |         new_body = body(0,0, last_body.rotate, "tail") | ||||||
|  |         v_x = int(-math.sin(-last_body.rotate * math.pi / 180)) | ||||||
|  |         new_body.x = -v_x + last_body.x | ||||||
|  |         v_y = int(math.cos(-last_body.rotate * math.pi / 180)) | ||||||
|  |         new_body.y = -v_y + last_body.y | ||||||
|  |         self.body.append(new_body) | ||||||
|  | 
 | ||||||
|  |     def move(self, vector): | ||||||
|  |         self.body[0].rotate = vector * 90 | ||||||
|  |         i = len(self.body)-1 | ||||||
|  |         while i > 0: | ||||||
|  |             if self.body[i].type == "body" or self.body[i].type == "tail": | ||||||
|  |                 self.body[i].x = self.body[i-1].x | ||||||
|  |                 self.body[i].y = self.body[i-1].y | ||||||
|  |                 self.body[i].rotate = self.body[i-1].rotate  | ||||||
|  |             i = i - 1 | ||||||
|  |              | ||||||
|  |         self.body[0].x = int(-math.sin(-self.body[0].rotate * math.pi / 180)) + self.body[0].x | ||||||
|  |         self.body[0].y = int(math.cos(-self.body[0].rotate * math.pi / 180)) + self.body[0].y | ||||||
|  | 
 | ||||||
|  |         # print(f"Move {vector}") | ||||||
|  | 
 | ||||||
|  | class Level_data(): | ||||||
|  |     def __init__(self, level_data_json = []): | ||||||
|  |         if level_data_json: | ||||||
|  |             self.fill_grid(level_data_json) | ||||||
|  | 
 | ||||||
|  |     def fill_grid(self, level_data_json): | ||||||
|  |         self.name = level_data_json["name"] | ||||||
|  |         self.floor = level_data_json["floor"] | ||||||
|  |         self.size = level_data_json["size"] | ||||||
|  |         self.enemy_types = level_data_json["enemy_types"] | ||||||
|  |         self.enemy_spawns  = level_data_json["enemy_spawns"] | ||||||
|  |         self.start_point = level_data_json["start_point"] | ||||||
|  | 
 | ||||||
|  | class MYGAME(arcade.Window): | ||||||
|  |     Sprites = [] | ||||||
|  | 
 | ||||||
|  |     def __init__(self, width, height): | ||||||
|  |         super().__init__(width, height) | ||||||
|  |         arcade.set_background_color(arcade.color.AMAZON) | ||||||
|  |      | ||||||
|  |     def setup(self, level_name): | ||||||
|  |         | ||||||
|  |         print(f"Upload level: {level_name}") | ||||||
|  |          | ||||||
|  |         with open(f'./DATA/Levels/{level_name}/data.json', 'r') as file: | ||||||
|  |             self.Lvl_data = Level_data(json.load(file)) | ||||||
|  | 
 | ||||||
|  |         if self.Lvl_data.name :  | ||||||
|  |             print(f"{self.Lvl_data.name} loaded") | ||||||
|  |         else: | ||||||
|  |             print("Error to load level") | ||||||
|  |          | ||||||
|  |         self.player_list = arcade.SpriteList() | ||||||
|  |         self.floor_list = arcade.SpriteList() | ||||||
|  |          | ||||||
|  |         self.enemies_list = arcade.SpriteList() | ||||||
|  |         self.enemy_spawn = arcade.SpriteList() | ||||||
|  | 
 | ||||||
|  |         grid = fill_empty_grid() | ||||||
|  |         self.floor_grid = self.arr2grid(self.Lvl_data.floor, grid) | ||||||
|  |         self.print_grid(self.floor_grid) | ||||||
|  |         self.snake = SNAKE(self.Lvl_data.start_point["x"], self.Lvl_data.start_point["y"]) | ||||||
|  | 
 | ||||||
|  |         # food | ||||||
|  |         self.food_list = arcade.SpriteList() | ||||||
|  |         self.food_sleep = 300 | ||||||
|  |         self.delay = 400 | ||||||
|  |         self.food = [] | ||||||
|  |         # Счет | ||||||
|  |         self.score = 0 | ||||||
|  |         self.scale_ = 1.3 | ||||||
|  | 
 | ||||||
|  |         screen_center = [SCREEN_WIDTH / 2, SCREEN_HEIGHT / 2] | ||||||
|  |         self.level_start = [screen_center[0] - self.Lvl_data.size[0] * 16 * self.scale_, screen_center[1] - self.Lvl_data.size[1] * 16 * self.scale_] | ||||||
|  |          | ||||||
|  |         # Загрузка змеи | ||||||
|  |         for body in self.snake.body: | ||||||
|  |             snake_sprite = arcade.Sprite(f"./DATA/Sprites/Snake/{body.type}.png", self.scale_) | ||||||
|  |             snake_sprite.angle = 90 | ||||||
|  |             snake_sprite.center_x = self.level_start[0] - 16 + ( body.x + 1 ) * 32 * self.scale_ | ||||||
|  |             snake_sprite.center_y = self.level_start[1] - 16 + ( body.y + 1 ) * 32 * self.scale_ | ||||||
|  |             self.player_list.append(snake_sprite) | ||||||
|  | 
 | ||||||
|  |         # Загрузка пола | ||||||
|  |         for floor in self.Lvl_data.floor: | ||||||
|  |             floor_sprite = arcade.Sprite(floor["sprite"], self.scale_) | ||||||
|  |             floor_sprite.center_x = self.level_start[0] - 16 + ( floor["x"] + 1 ) * 32 * self.scale_ | ||||||
|  |             floor_sprite.center_y = self.level_start[1] - 16 + ( floor["y"] + 1 ) * 32 * self.scale_ | ||||||
|  |             self.floor_list.append(floor_sprite) | ||||||
|  |          | ||||||
|  |         # Загрузка врагов | ||||||
|  |         # if "enemies" in self.level_data: | ||||||
|  |         #     for enemy in self.level_data["enemies"]: | ||||||
|  |         #         enemy_sprite = arcade.Sprite(enemy["sprite"], 1) | ||||||
|  |         #         enemy_sprite.center_x = self.level_start[0] - 16 + ( enemy["x"] + 1 ) * 32 * self.scale_ | ||||||
|  |         #         enemy_sprite.center_y = self.level_start[0] - 16 + ( enemy["y"] + 1 ) * 32 * self.scale_ | ||||||
|  |         #         self.enemies_list.append(enemy_sprite) | ||||||
|  |     def spawn_food(self): | ||||||
|  |         spawn = False | ||||||
|  |         while spawn == False: | ||||||
|  |             x = random.randint(0, 14) | ||||||
|  |             y = random.randint(0, 14) | ||||||
|  |             if self.floor_grid[y][x] == 1 and not(self.snake.check_contact(x,y)): | ||||||
|  |                 self.food.append(food(x,y)) | ||||||
|  |                 food_sprite = arcade.Sprite(f"./DATA/Sprites/Enemies/Tier 0/healthy_food.png", self.scale_) | ||||||
|  |                 food_sprite.angle = 0 | ||||||
|  |                 food_sprite.center_x = self.level_start[0] - 16 + ( x + 1 ) * 32 * self.scale_ | ||||||
|  |                 food_sprite.center_y = self.level_start[1] - 16 + ( y + 1 ) * 32 * self.scale_ | ||||||
|  |                 self.food_list.append(food_sprite) | ||||||
|  |                 spawn = True | ||||||
|  | 
 | ||||||
|  |     def update(self): | ||||||
|  |         if len(self.snake.body) > 0: | ||||||
|  |             i = 0 | ||||||
|  |             while i < len(self.snake.body): | ||||||
|  |                 self.player_list[i] = arcade.Sprite(f"./DATA/Sprites/Snake/{self.snake.body[i].type}.png", self.scale_) | ||||||
|  |                 self.player_list[i].angle = self.snake.body[i].rotate | ||||||
|  |                 self.player_list[i].center_x = self.level_start[0] - 16 + ( self.snake.body[i].x + 1 ) * 32 * self.scale_ | ||||||
|  |                 self.player_list[i].center_y = self.level_start[1] - 16 + ( self.snake.body[i].y + 1 ) * 32 * self.scale_ | ||||||
|  |                 i = i + 1 | ||||||
|  |         # Food | ||||||
|  |         self.food_sleep -= 1 | ||||||
|  |         if self.food_sleep <= 0: | ||||||
|  |             self.spawn_food() | ||||||
|  |             self.food_sleep = self.delay | ||||||
|  |         i = 0 | ||||||
|  |         while i < len(self.food_list): | ||||||
|  |             if self.snake.check_contact(self.food[i].x, self.food[i].y): | ||||||
|  |                 self.food_list[i].kill() | ||||||
|  |                 self.food.pop(i) | ||||||
|  |                 self.score += 1 | ||||||
|  |                 self.snake.add_dody() | ||||||
|  |                 self.player_list.append(arcade.Sprite()) | ||||||
|  |             i += 1 | ||||||
|  |         # Enemy_spawn | ||||||
|  |         for spawn in self.Lvl_data.enemy_spawns[0]: | ||||||
|  |             spawn["sleep"] -= 1 | ||||||
|  |             if spawn["sleep"] <= 0: | ||||||
|  |                 spawn["sleep"] = spawn["delay"] | ||||||
|  |                 self.spawn_enemy(spawn["y"], spawn["x"], spawn["tier"]) | ||||||
|  | 
 | ||||||
|  |     def spawn_enemy(self, y, x, tier): | ||||||
|  |         type = random.randint(0, len(self.Lvl_data.enemy_types[tier-1])) | ||||||
|  |         print_spawn("tier: " + str(type), x, y) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     def print_grid(self, grid): | ||||||
|  |         x = 0  | ||||||
|  |         y = 14 | ||||||
|  |         print_ = '' | ||||||
|  |         while y >= 0: | ||||||
|  |             while x < 15: | ||||||
|  |                 print_ += "  " if grid[y][x] == 0 else "1 " | ||||||
|  |                 x += 1  | ||||||
|  |             print(print_) | ||||||
|  |             print_ = '' | ||||||
|  |             y -= 1 | ||||||
|  |             x = 0 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     def arr2grid(self, arr, grid): | ||||||
|  |         for point in arr: | ||||||
|  |             grid[point["y"]][point["x"]] = 1 | ||||||
|  |         return grid | ||||||
|  |      | ||||||
|  |     # Обработка нажатий | ||||||
|  |     MOVEMENT_SPEED = 1 | ||||||
|  | 
 | ||||||
|  |     def on_key_press(self, key, modifiers): | ||||||
|  |         """Вызывается при нажатии пользователем клавиши""" | ||||||
|  | 
 | ||||||
|  |         # Get the first sprite (head) from the player list | ||||||
|  |         if len(self.player_list) > 0: | ||||||
|  |              | ||||||
|  |             if key in (arcade.key.UP, arcade.key.W): | ||||||
|  |                 if self.floor_grid[self.snake.body[0].y + 1][self.snake.body[0].x] == 1 and self.snake.body[0].rotate != 180 and not(self.snake.check_contact(self.snake.body[0].x ,self.snake.body[0].y+1)):    | ||||||
|  |                     self.snake.move(0) | ||||||
|  |                  | ||||||
|  |             elif key in (arcade.key.DOWN, arcade.key.S): | ||||||
|  |                 if self.floor_grid[self.snake.body[0].y - 1][self.snake.body[0].x] == 1 and self.snake.body[0].rotate != 0 and not(self.snake.check_contact(self.snake.body[0].x ,self.snake.body[0].y-1)):    | ||||||
|  |                     self.snake.move(2) | ||||||
|  | 
 | ||||||
|  |             elif key in (arcade.key.LEFT, arcade.key.A): | ||||||
|  |                 if self.floor_grid[self.snake.body[0].y][self.snake.body[0].x - 1] == 1 and self.snake.body[0].rotate != 90 and not(self.snake.check_contact(self.snake.body[0].x - 1,self.snake.body[0].y)):    | ||||||
|  |                     self.snake.move(3) | ||||||
|  | 
 | ||||||
|  |             elif key in (arcade.key.RIGHT, arcade.key.D): | ||||||
|  |                 if self.floor_grid[self.snake.body[0].y][self.snake.body[0].x + 1] == 1 and self.snake.body[0].rotate != 270 and not(self.snake.check_contact(self.snake.body[0].x + 1,self.snake.body[0].y)):    | ||||||
|  |                     self.snake.move(1) | ||||||
|  | 
 | ||||||
|  |     def on_key_release(self, key, modifiers): | ||||||
|  |         """Вызывается, когда пользователь отпускает клавишу""" | ||||||
|  |         if len(self.player_list) > 0: | ||||||
|  |             self.player_sprite = self.player_list[0] | ||||||
|  |              | ||||||
|  |             if key in (arcade.key.UP, arcade.key.DOWN, arcade.key.W, arcade.key.S): | ||||||
|  |                 self.player_sprite.change_y = 0 | ||||||
|  |             elif key in (arcade.key.LEFT, arcade.key.RIGHT, arcade.key.A, arcade.key.D): | ||||||
|  |                 self.player_sprite.change_x = 0 | ||||||
|  |     def on_draw(self): | ||||||
|  |         self.update() | ||||||
|  |         # Очищаем экран перед каждой отрисовкой | ||||||
|  |         self.clear() | ||||||
|  |         # Отрисовываем все спрайты | ||||||
|  |         self.floor_list.draw() | ||||||
|  |         self.enemies_list.draw() | ||||||
|  |         self.food_list.draw() | ||||||
|  |         self.player_list.draw() | ||||||
|  | 
 | ||||||
|  | def print_spawn(who, x, y): | ||||||
|  |     print(f"Spawn: {who}\nx: {x}\ny: {y}") | ||||||
|  | 
 | ||||||
|  | def fill_empty_grid(): | ||||||
|  |     grid = [] | ||||||
|  |     y = 0 | ||||||
|  |     x = 0 | ||||||
|  |     while y < 15: | ||||||
|  |         grid.append([]) | ||||||
|  |         while x < 15: | ||||||
|  |             grid[y].append([x]) | ||||||
|  |             grid[y][x] = 0 | ||||||
|  |             x = x + 1 | ||||||
|  |         y = y + 1 | ||||||
|  |         x = 0 | ||||||
|  |     return grid | ||||||
|  | 
 | ||||||
|  | def main(): | ||||||
|  |     filler_ = filler("Default") | ||||||
|  |     filler_.fill_level(filler_.floor_code) | ||||||
|  |     filler_.export2json() | ||||||
|  | 
 | ||||||
|  |     game = MYGAME(SCREEN_WIDTH, SCREEN_HEIGHT) | ||||||
|  |     game.setup( "Default" ) | ||||||
|  |     arcade.run() | ||||||
|  | 
 | ||||||
|  | if __name__ == "__main__": | ||||||
|  |     main() | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user