From ac35c098af7f6c034bf00e1a7cf440609f43bccd Mon Sep 17 00:00:00 2001 From: Genagie Date: Thu, 6 Mar 2025 23:27:44 +0300 Subject: [PATCH 1/6] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=20gitignore?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 1 + README.md | 36 +----------------------------------- 2 files changed, 2 insertions(+), 35 deletions(-) create mode 100644 .gitignore diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..21d0b89 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +.venv/ diff --git a/README.md b/README.md index 3946739..8c2fb2d 100644 --- a/README.md +++ b/README.md @@ -1,35 +1 @@ -Билькевич Дмитрий Михайлович - stud178867@vyatsu.ru - -Буланов Владислав Денисович - stud178869@vyatsu.ru - -Бушуев Григорий Владимирович - stud178870@vyatsu.ru - -Виноградова Вера Владимировна - stud178857@vyatsu.ru - -Катков Максим Игоревич - stud178694@vyatsu.ru - -Кобыльников Александр Эдуардович - stud178872@vyatsu.ru - -Лусников Егор Сергеевич - stud178862@vyatsu.ru - -Лямин Никита Викторович - stud178858@vyatsu.ru - -Матвеев Дмитрий Сергеевич - stud178860@vyatsu.ru - -Никитин Алексей Павлович - stud178863@vyatsu.ru - -Пастухов Алексей Игоревич - stud178873@vyatsu.ru - -Петухов Егор Алексеевич - stud178856@vyatsu.ru - -Писцов Александр Григорьевич - stud178879@vyatsu.ru - -Плужников Артём Александрович - stud181545@vyatsu.ru - -Русских Данил Дмитриевич - stud180728@vyatsu.ru - -Савиных Станислав Максимович - stud209105@vyatsu.ru - -Скобелев Максим Владимирович - stud159357@vyatsu.ru - -ТЕРЕХОВ ПАВЕЛ СЕРГЕЕВИЧ -stud178861@vyatsu.ru \ No newline at end of file +Создание игры-головоломки, схожей с классической змейкой \ No newline at end of file From 7011efc4e6ee76146e30a62b649c054213d1c1b6 Mon Sep 17 00:00:00 2001 From: Genagie Date: Thu, 6 Mar 2025 23:52:51 +0300 Subject: [PATCH 2/6] =?UTF-8?q?=D0=97=D0=B0=D0=B4=D0=B0=D0=BD=D0=B8=D0=B5?= =?UTF-8?q?=203=20=D0=B2=D1=8B=D0=BF=D0=BE=D0=BB=D0=BD=D0=B5=D0=BD=D0=BE?= =?UTF-8?q?=20=D0=B2=20=D1=84=D0=B0=D0=B9=D0=BB=D0=B5=20data.txt?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- data.txt | 3 +++ main.py | 9 +++++++++ requirements.txt | 6 ++++++ 3 files changed, 18 insertions(+) create mode 100644 data.txt create mode 100644 requirements.txt diff --git a/data.txt b/data.txt new file mode 100644 index 0000000..0fbbcba --- /dev/null +++ b/data.txt @@ -0,0 +1,3 @@ +Hello, World! +This is a test file. +12345 \ No newline at end of file diff --git a/main.py b/main.py index e69de29..7d0fcf7 100644 --- a/main.py +++ b/main.py @@ -0,0 +1,9 @@ +with open('data.txt', 'r') as file: + lines = file.readlines() + +transformed_lines = [line.upper() for line in lines] + +with open('output.txt', 'w') as output_file: + output_file.writelines(transformed_lines) + +print("Данные успешно преобразованы и записаны в файл output.txt") \ No newline at end of file diff --git a/requirements.txt b/requirements.txt new file mode 100644 index 0000000..de6c89b --- /dev/null +++ b/requirements.txt @@ -0,0 +1,6 @@ +numpy==2.2.3 +pandas==2.2.3 +python-dateutil==2.9.0.post0 +pytz==2025.1 +six==1.17.0 +tzdata==2025.1 From 93acd8784456d2f59486ce19407fd4473b0d759f Mon Sep 17 00:00:00 2001 From: Genagie Date: Sat, 15 Mar 2025 13:19:59 +0300 Subject: [PATCH 3/6] fix: README --- README.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/README.md b/README.md index 8c2fb2d..b586e2c 100644 --- a/README.md +++ b/README.md @@ -1 +1,3 @@ +Терехов Павел Сергеевич +Глеб Создание игры-головоломки, схожей с классической змейкой \ No newline at end of file From fc73bf8c80e274e93e1fe005579e3fb501bd52ca Mon Sep 17 00:00:00 2001 From: 3xploit1 Date: Sat, 15 Mar 2025 13:22:50 +0300 Subject: [PATCH 4/6] =?UTF-8?q?=D0=98=D1=81=D0=BF=D1=80=D0=B0=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD=D0=BE=20=D0=B8=D0=BC=D1=8F=20=D0=BD=D0=B0=20=D0=A4?= =?UTF-8?q?=D0=98=D0=9E=20=D0=B2=20=D1=84=D0=BE=D1=80=D0=BA=D0=B5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index b586e2c..4e875d3 100644 --- a/README.md +++ b/README.md @@ -1,3 +1,3 @@ Терехов Павел Сергеевич -Глеб +Новицкий Глеб Павлович Создание игры-головоломки, схожей с классической змейкой \ No newline at end of file From 840a6fa783b570b31dfc622d6c0f5d88e39fc44e Mon Sep 17 00:00:00 2001 From: Genagie Date: Mon, 17 Mar 2025 22:39:27 +0300 Subject: [PATCH 5/6] fix --- README.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/README.md b/README.md index 4e875d3..9ff415e 100644 --- a/README.md +++ b/README.md @@ -1,3 +1,5 @@ Терехов Павел Сергеевич + Новицкий Глеб Павлович + Создание игры-головоломки, схожей с классической змейкой \ No newline at end of file From ecdd0c59ca5da98a5ffaab7d9ec33b3f41a6c997 Mon Sep 17 00:00:00 2001 From: Doom-JSlayer Date: Tue, 6 May 2025 15:32:31 +0300 Subject: [PATCH 6/6] update: master --- main.py | 276 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 276 insertions(+) diff --git a/main.py b/main.py index e69de29..d9e7cfb 100644 --- a/main.py +++ b/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() \ No newline at end of file