Compare commits
No commits in common. "1476163e4e745b04251fca622117d8983e440165" and "d4b99804f16e3a9c7a0c24535782165aca409c2f" have entirely different histories.
1476163e4e
...
d4b99804f1
|
@ -2,7 +2,7 @@
|
||||||
<module type="PYTHON_MODULE" version="4">
|
<module type="PYTHON_MODULE" version="4">
|
||||||
<component name="NewModuleRootManager">
|
<component name="NewModuleRootManager">
|
||||||
<content url="file://$MODULE_DIR$" />
|
<content url="file://$MODULE_DIR$" />
|
||||||
<orderEntry type="jdk" jdkName="Python 3.11" jdkType="Python SDK" />
|
<orderEntry type="jdk" jdkName="Python 3.12" jdkType="Python SDK" />
|
||||||
<orderEntry type="sourceFolder" forTests="false" />
|
<orderEntry type="sourceFolder" forTests="false" />
|
||||||
</component>
|
</component>
|
||||||
</module>
|
</module>
|
|
@ -3,5 +3,5 @@
|
||||||
<component name="Black">
|
<component name="Black">
|
||||||
<option name="sdkName" value="Python 3.11" />
|
<option name="sdkName" value="Python 3.11" />
|
||||||
</component>
|
</component>
|
||||||
<component name="ProjectRootManager" version="2" project-jdk-name="Python 3.11" project-jdk-type="Python SDK" />
|
<component name="ProjectRootManager" version="2" project-jdk-name="Python 3.12" project-jdk-type="Python SDK" />
|
||||||
</project>
|
</project>
|
14
main.py
14
main.py
|
@ -18,9 +18,6 @@ FIRE_DELAY = 1000 # Задержка между выстрелами в мил
|
||||||
WHITE = (255, 255, 255)
|
WHITE = (255, 255, 255)
|
||||||
BLACK = (0, 0, 0)
|
BLACK = (0, 0, 0)
|
||||||
|
|
||||||
#Определение переменных
|
|
||||||
score = 0
|
|
||||||
|
|
||||||
# Инициализация Pygame
|
# Инициализация Pygame
|
||||||
pygame.init()
|
pygame.init()
|
||||||
|
|
||||||
|
@ -405,8 +402,6 @@ while running:
|
||||||
bullet.kill() # Удаляем пулю
|
bullet.kill() # Удаляем пулю
|
||||||
tank_hit.kill() # Удаляем бота
|
tank_hit.kill() # Удаляем бота
|
||||||
respawn_bot() # Создаем нового бота
|
respawn_bot() # Создаем нового бота
|
||||||
score += 1
|
|
||||||
|
|
||||||
elif isinstance(bullet, BotBullet):
|
elif isinstance(bullet, BotBullet):
|
||||||
# Проверяем столкновение пули бота с стенами
|
# Проверяем столкновение пули бота с стенами
|
||||||
if pygame.sprite.spritecollideany(bullet, walls):
|
if pygame.sprite.spritecollideany(bullet, walls):
|
||||||
|
@ -415,7 +410,6 @@ while running:
|
||||||
all_sprites.add(explosion) # Добавление взрыва камня в группу спрайтов
|
all_sprites.add(explosion) # Добавление взрыва камня в группу спрайтов
|
||||||
bullet.kill() # Удаляем пулю бота
|
bullet.kill() # Удаляем пулю бота
|
||||||
|
|
||||||
|
|
||||||
# Отрисовка фона
|
# Отрисовка фона
|
||||||
for i in range(2):
|
for i in range(2):
|
||||||
for j in range(2):
|
for j in range(2):
|
||||||
|
@ -500,14 +494,6 @@ while running:
|
||||||
screen.blit(stenki, (1600, 1030))
|
screen.blit(stenki, (1600, 1030))
|
||||||
screen.blit(stenki, (1800, 1030))
|
screen.blit(stenki, (1800, 1030))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
font = pygame.font.Font(None, 36)
|
|
||||||
score_text = font.render(f'Score: {score}', True, WHITE)
|
|
||||||
screen.blit(score_text, (10, 10))
|
|
||||||
score_rect = score_text.get_rect(topleft=(10, 10))
|
|
||||||
pygame.draw.rect(screen, (0, 255, 0), (score_rect.topleft, (score_rect.width, score_rect.height))) # Draw a green rectangle behind the score
|
|
||||||
screen.blit(score_text, score_rect.topleft)
|
|
||||||
pygame.display.flip()
|
pygame.display.flip()
|
||||||
clock.tick(FPS)
|
clock.tick(FPS)
|
||||||
|
|
||||||
|
|
Binary file not shown.
129
test.py
129
test.py
|
@ -18,9 +18,6 @@ FIRE_DELAY = 1000 # Задержка между выстрелами в мил
|
||||||
WHITE = (255, 255, 255)
|
WHITE = (255, 255, 255)
|
||||||
BLACK = (0, 0, 0)
|
BLACK = (0, 0, 0)
|
||||||
|
|
||||||
#Определение переменных
|
|
||||||
score = 0
|
|
||||||
|
|
||||||
# Инициализация Pygame
|
# Инициализация Pygame
|
||||||
pygame.init()
|
pygame.init()
|
||||||
|
|
||||||
|
@ -33,8 +30,8 @@ pygame.mixer.music.load('music.mp3')
|
||||||
pygame.mixer.music.play(-1) # Параметр -1 означает зацикливание музыки
|
pygame.mixer.music.play(-1) # Параметр -1 означает зацикливание музыки
|
||||||
shot_sound = pygame.mixer.Sound('shot.wav')
|
shot_sound = pygame.mixer.Sound('shot.wav')
|
||||||
meme_sound = pygame.mixer.Sound("meme_sound.wav")
|
meme_sound = pygame.mixer.Sound("meme_sound.wav")
|
||||||
explosion_sound = pygame.mixer.Sound("explosion_sound.wav")
|
|
||||||
stoneexplosion_sound = pygame.mixer.Sound("stoneexplosion_sound.wav")
|
|
||||||
|
|
||||||
# Загрузка изображений
|
# Загрузка изображений
|
||||||
background_image = pygame.transform.scale(pygame.image.load("travka_pol.jpeg"), (960, 540))
|
background_image = pygame.transform.scale(pygame.image.load("travka_pol.jpeg"), (960, 540))
|
||||||
|
@ -43,73 +40,10 @@ stenki = pygame.transform.scale(pygame.image.load("stena.jpeg").convert(), (200,
|
||||||
tank_image = pygame.transform.scale(pygame.image.load("ntank-removebg-preview.png"), (PLAYER_WIDTH, PLAYER_HEIGHT))
|
tank_image = pygame.transform.scale(pygame.image.load("ntank-removebg-preview.png"), (PLAYER_WIDTH, PLAYER_HEIGHT))
|
||||||
loh_image = pygame.transform.scale(pygame.image.load("loh.png"), (LOH_WIDTH, LOH_HEIGHT))
|
loh_image = pygame.transform.scale(pygame.image.load("loh.png"), (LOH_WIDTH, LOH_HEIGHT))
|
||||||
bullet_image = pygame.transform.scale(pygame.image.load("bullet.png"), (BULLET_SIZE, BULLET_SIZE))
|
bullet_image = pygame.transform.scale(pygame.image.load("bullet.png"), (BULLET_SIZE, BULLET_SIZE))
|
||||||
explosion_images = [pygame.image.load(f"explosion_{i}.png") for i in range(1, 48)]
|
|
||||||
stoneexplosion_images = [pygame.image.load(f"stoneexplosion_{i}.png") for i in range(1, 6)]
|
|
||||||
|
|
||||||
menu_background = pygame.transform.scale(pygame.image.load("menu_background.jpg"), (SCREEN_WIDTH, SCREEN_HEIGHT))
|
menu_background = pygame.transform.scale(pygame.image.load("menu_background.jpg"), (SCREEN_WIDTH, SCREEN_HEIGHT))
|
||||||
|
|
||||||
|
|
||||||
class Explosion(pygame.sprite.Sprite):
|
|
||||||
def __init__(self, x, y):
|
|
||||||
super().__init__()
|
|
||||||
self.image = explosion_images[0]
|
|
||||||
self.rect = self.image.get_rect(center=(x, y))
|
|
||||||
self.frame = 0
|
|
||||||
self.last_update = pygame.time.get_ticks()
|
|
||||||
self.frame_rate = 50
|
|
||||||
|
|
||||||
def update(self):
|
|
||||||
now = pygame.time.get_ticks()
|
|
||||||
if now - self.last_update > self.frame_rate:
|
|
||||||
self.last_update = now
|
|
||||||
self.frame += 1
|
|
||||||
if self.frame == 6:
|
|
||||||
self.kill()
|
|
||||||
else:
|
|
||||||
center = self.rect.center
|
|
||||||
self.image = explosion_images[self.frame]
|
|
||||||
self.rect = self.image.get_rect()
|
|
||||||
self.rect.center = center
|
|
||||||
|
|
||||||
# Добавление класса для анимации удара о каменную стену
|
|
||||||
class StoneExplosion(pygame.sprite.Sprite):
|
|
||||||
def __init__(self, x, y):
|
|
||||||
super().__init__()
|
|
||||||
self.images = stoneexplosion_images
|
|
||||||
self.image = self.images[0]
|
|
||||||
self.rect = self.image.get_rect(center=(x, y))
|
|
||||||
self.frame = 0
|
|
||||||
self.last_update = pygame.time.get_ticks()
|
|
||||||
self.frame_rate = 50
|
|
||||||
stoneexplosion_sound.play() # Воспроизведение звука удара о стену
|
|
||||||
|
|
||||||
def update(self):
|
|
||||||
now = pygame.time.get_ticks()
|
|
||||||
if now - self.last_update > self.frame_rate:
|
|
||||||
self.last_update = now
|
|
||||||
self.frame += 1
|
|
||||||
if self.frame == len(self.images):
|
|
||||||
self.kill()
|
|
||||||
else:
|
|
||||||
center = self.rect.center
|
|
||||||
self.image = self.images[self.frame]
|
|
||||||
self.rect = self.image.get_rect()
|
|
||||||
self.rect.center = center
|
|
||||||
|
|
||||||
|
|
||||||
def update(self):
|
|
||||||
now = pygame.time.get_ticks()
|
|
||||||
if now - self.last_update > self.frame_rate:
|
|
||||||
self.last_update = now
|
|
||||||
self.frame += 1
|
|
||||||
if self.frame == len(self.images):
|
|
||||||
self.kill()
|
|
||||||
else:
|
|
||||||
center = self.rect.center
|
|
||||||
self.image = self.images[self.frame]
|
|
||||||
self.rect = self.image.get_rect()
|
|
||||||
self.rect.center = center
|
|
||||||
|
|
||||||
# Определение класса танка
|
# Определение класса танка
|
||||||
class Tank(pygame.sprite.Sprite):
|
class Tank(pygame.sprite.Sprite):
|
||||||
def __init__(self, x, y):
|
def __init__(self, x, y):
|
||||||
|
@ -162,14 +96,8 @@ class Tank(pygame.sprite.Sprite):
|
||||||
bullets.add(bullet)
|
bullets.add(bullet)
|
||||||
self.last_fire_time = current_time # Обновление времени последнего выстрела
|
self.last_fire_time = current_time # Обновление времени последнего выстрела
|
||||||
|
|
||||||
# Проверяем столкновение пули с каменными стенами
|
|
||||||
if pygame.sprite.spritecollideany(bullet, walls):
|
|
||||||
stoneexplosion_sound.play() # Воспроизведение звука столкновения с каменной стеной
|
|
||||||
explosion = StoneExplosion(bullet.rect.centerx, bullet.rect.centery) # Создание анимации удара о стену
|
|
||||||
all_sprites.add(explosion) # Добавление анимации удара о стену в группу спрайтов
|
|
||||||
bullet.kill() # Удаление пули
|
|
||||||
|
|
||||||
|
|
||||||
|
# Определение класса снаряда игрока
|
||||||
class PlayerBullet(pygame.sprite.Sprite):
|
class PlayerBullet(pygame.sprite.Sprite):
|
||||||
def __init__(self, x, y, angle):
|
def __init__(self, x, y, angle):
|
||||||
super().__init__()
|
super().__init__()
|
||||||
|
@ -186,7 +114,6 @@ class PlayerBullet(pygame.sprite.Sprite):
|
||||||
if pygame.sprite.spritecollideany(self, walls):
|
if pygame.sprite.spritecollideany(self, walls):
|
||||||
self.kill() # Удаляем снаряд, если он столкнулся со стеной
|
self.kill() # Удаляем снаряд, если он столкнулся со стеной
|
||||||
|
|
||||||
|
|
||||||
# Определение класса снаряда бота
|
# Определение класса снаряда бота
|
||||||
class BotBullet(pygame.sprite.Sprite):
|
class BotBullet(pygame.sprite.Sprite):
|
||||||
def __init__(self, x, y, angle):
|
def __init__(self, x, y, angle):
|
||||||
|
@ -204,7 +131,6 @@ class BotBullet(pygame.sprite.Sprite):
|
||||||
if pygame.sprite.spritecollideany(self, walls):
|
if pygame.sprite.spritecollideany(self, walls):
|
||||||
self.kill() # Удаляем снаряд, если он столкнулся со стеной
|
self.kill() # Удаляем снаряд, если он столкнулся со стеной
|
||||||
|
|
||||||
|
|
||||||
# Определение класса для бота
|
# Определение класса для бота
|
||||||
class Bot(pygame.sprite.Sprite):
|
class Bot(pygame.sprite.Sprite):
|
||||||
def __init__(self, x, y):
|
def __init__(self, x, y):
|
||||||
|
@ -258,6 +184,7 @@ class Bot(pygame.sprite.Sprite):
|
||||||
#self.last_fire_time = current_time
|
#self.last_fire_time = current_time
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class Wall(pygame.sprite.Sprite):
|
class Wall(pygame.sprite.Sprite):
|
||||||
def __init__(self, x, y, image):
|
def __init__(self, x, y, image):
|
||||||
super().__init__()
|
super().__init__()
|
||||||
|
@ -271,6 +198,7 @@ tanks = pygame.sprite.Group()
|
||||||
bullets = pygame.sprite.Group()
|
bullets = pygame.sprite.Group()
|
||||||
walls = pygame.sprite.Group() # Группа для всех стен
|
walls = pygame.sprite.Group() # Группа для всех стен
|
||||||
|
|
||||||
|
|
||||||
# Создание стен
|
# Создание стен
|
||||||
wall_positions = [
|
wall_positions = [
|
||||||
(360, 40), (460, 730), (460, 830), (460, 930),
|
(360, 40), (460, 730), (460, 830), (460, 930),
|
||||||
|
@ -305,6 +233,9 @@ for pos in wall_stenki_positions:
|
||||||
all_sprites.add(wall_stenki)
|
all_sprites.add(wall_stenki)
|
||||||
walls.add(wall_stenki)
|
walls.add(wall_stenki)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Создание групп спрайтов
|
# Создание групп спрайтов
|
||||||
all_sprites = pygame.sprite.Group()
|
all_sprites = pygame.sprite.Group()
|
||||||
tanks = pygame.sprite.Group()
|
tanks = pygame.sprite.Group()
|
||||||
|
@ -315,6 +246,8 @@ player = Tank(SCREEN_WIDTH // 8, SCREEN_HEIGHT // 7)
|
||||||
all_sprites.add(player)
|
all_sprites.add(player)
|
||||||
tanks.add(player)
|
tanks.add(player)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bot = Bot(3 * SCREEN_WIDTH // 4, SCREEN_HEIGHT // 2)
|
bot = Bot(3 * SCREEN_WIDTH // 4, SCREEN_HEIGHT // 2)
|
||||||
all_sprites.add(bot)
|
all_sprites.add(bot)
|
||||||
tanks.add(bot)
|
tanks.add(bot)
|
||||||
|
@ -327,7 +260,6 @@ bot = Bot(3 * SCREEN_WIDTH // 4, SCREEN_HEIGHT // 2)
|
||||||
all_sprites.add(bot)
|
all_sprites.add(bot)
|
||||||
tanks.add(bot)
|
tanks.add(bot)
|
||||||
|
|
||||||
|
|
||||||
def draw_menu():
|
def draw_menu():
|
||||||
screen.blit(menu_background, (0, 0))
|
screen.blit(menu_background, (0, 0))
|
||||||
# Рисуем текст меню
|
# Рисуем текст меню
|
||||||
|
@ -352,10 +284,11 @@ def respawn_bot():
|
||||||
all_sprites.add(new_bot)
|
all_sprites.add(new_bot)
|
||||||
tanks.add(new_bot)
|
tanks.add(new_bot)
|
||||||
|
|
||||||
|
|
||||||
last_meme_time = 0
|
last_meme_time = 0
|
||||||
meme_delay = 2000 # Задержка в миллисекундах (2 секунды)
|
meme_delay = 2000 # Задержка в миллисекундах (2 секунды)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Главный цикл программы
|
# Главный цикл программы
|
||||||
menu_active = True
|
menu_active = True
|
||||||
while menu_active:
|
while menu_active:
|
||||||
|
@ -369,22 +302,27 @@ while menu_active:
|
||||||
else:
|
else:
|
||||||
menu_active = False # Нажата кнопка "Старт"
|
menu_active = False # Нажата кнопка "Старт"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Основной игровой цикл
|
# Основной игровой цикл
|
||||||
clock = pygame.time.Clock()
|
clock = pygame.time.Clock()
|
||||||
running = True
|
running = True
|
||||||
|
|
||||||
|
|
||||||
while running:
|
while running:
|
||||||
player_bullets = []
|
player_bullets = []
|
||||||
bot_bullets = []
|
bot_bullets = []
|
||||||
|
|
||||||
current_time = pygame.time.get_ticks()
|
current_time = pygame.time.get_ticks()
|
||||||
|
|
||||||
|
|
||||||
for event in pygame.event.get():
|
for event in pygame.event.get():
|
||||||
if event.type == pygame.QUIT:
|
if event.type == pygame.QUIT:
|
||||||
running = False
|
running = False
|
||||||
elif event.type == pygame.MOUSEBUTTONDOWN and event.button == 1: # Обработка левой кнопки мыши
|
elif event.type == pygame.MOUSEBUTTONDOWN and event.button == 1: # Обработка левой кнопки мыши
|
||||||
player.shoot()
|
player.shoot()
|
||||||
|
|
||||||
|
|
||||||
if event.type == pygame.KEYDOWN:
|
if event.type == pygame.KEYDOWN:
|
||||||
if event.key == pygame.K_k:
|
if event.key == pygame.K_k:
|
||||||
if current_time - last_meme_time > meme_delay: # Проверка задержки
|
if current_time - last_meme_time > meme_delay: # Проверка задержки
|
||||||
|
@ -399,22 +337,19 @@ while running:
|
||||||
if isinstance(bullet, PlayerBullet):
|
if isinstance(bullet, PlayerBullet):
|
||||||
tank_hit = pygame.sprite.spritecollideany(bullet, tanks, pygame.sprite.collide_mask)
|
tank_hit = pygame.sprite.spritecollideany(bullet, tanks, pygame.sprite.collide_mask)
|
||||||
if tank_hit and isinstance(tank_hit, Bot):
|
if tank_hit and isinstance(tank_hit, Bot):
|
||||||
explosion_sound.play() # Воспроизведение звука взрыва
|
tank_hit.kill() # Удаляем бота, если попал игрок
|
||||||
explosion = Explosion(tank_hit.rect.centerx, tank_hit.rect.centery) # Создание взрыва
|
|
||||||
all_sprites.add(explosion) # Добавление взрыва в группу спрайтов
|
|
||||||
bullet.kill() # Удаляем пулю
|
bullet.kill() # Удаляем пулю
|
||||||
tank_hit.kill() # Удаляем бота
|
|
||||||
respawn_bot() # Создаем нового бота
|
|
||||||
score += 1
|
|
||||||
|
|
||||||
elif isinstance(bullet, BotBullet):
|
elif isinstance(bullet, BotBullet):
|
||||||
# Проверяем столкновение пули бота с стенами
|
tank_hit = pygame.sprite.spritecollideany(bullet, tanks, pygame.sprite.collide_mask)
|
||||||
if pygame.sprite.spritecollideany(bullet, walls):
|
if tank_hit and isinstance(tank_hit, Tank):
|
||||||
stoneexplosion_sound.play() # Воспроизведение звука взрыва камня
|
tank_hit.kill() # Удаляем игрока, если попал бот
|
||||||
explosion = Explosion(bullet.rect.centerx, bullet.rect.centery) # Создание взрыва камня
|
bullet.kill() # Удаляем пулю
|
||||||
all_sprites.add(explosion) # Добавление взрыва камня в группу спрайтов
|
if tank_hit and isinstance(tank_hit, Bot):
|
||||||
bullet.kill() # Удаляем пулю бота
|
tank_hit.kill() # Удаляем бота, если попал игрок
|
||||||
|
bullet.kill() # Удаляем пулю
|
||||||
|
respawn_bot() # Пересоздаем бота в случайном месте карты
|
||||||
|
|
||||||
|
bullet.update()
|
||||||
|
|
||||||
# Отрисовка фона
|
# Отрисовка фона
|
||||||
for i in range(2):
|
for i in range(2):
|
||||||
|
@ -500,16 +435,10 @@ while running:
|
||||||
screen.blit(stenki, (1600, 1030))
|
screen.blit(stenki, (1600, 1030))
|
||||||
screen.blit(stenki, (1800, 1030))
|
screen.blit(stenki, (1800, 1030))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
font = pygame.font.Font(None, 36)
|
|
||||||
score_text = font.render(f'Score: {score}', True, WHITE)
|
|
||||||
screen.blit(score_text, (10, 10))
|
|
||||||
score_rect = score_text.get_rect(topleft=(10, 10))
|
|
||||||
pygame.draw.rect(screen, (0, 255, 0), (score_rect.topleft, (score_rect.width, score_rect.height))) # Draw a green rectangle behind the score
|
|
||||||
screen.blit(score_text, score_rect.topleft)
|
|
||||||
pygame.display.flip()
|
pygame.display.flip()
|
||||||
clock.tick(FPS)
|
clock.tick(FPS)
|
||||||
|
|
||||||
# Завершение работы Pygame
|
# Завершение работы Pygame
|
||||||
pygame.quit()
|
pygame.quit()
|
||||||
|
|
||||||
|
# token: 8f195a885b18a96da6577884cc731f850f33a9e2
|
Loading…
Reference in New Issue