python项目(课设)——飞机大战小游戏项目源码(pygame)

2024-06-21 18:04

本文主要是介绍python项目(课设)——飞机大战小游戏项目源码(pygame),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 主程序


import pygame

from plane_sprites import *

class PlaneGame:
    """
    游戏类
    """
    def __init__(self):
        print("游戏初始化")
        # 初始化字体模块
        pygame.font.init()
        # 创建游戏窗口
        self.screen = pygame.display.set_mode(SCREEN_RECT.size)
        # 常见游戏时钟
        self.clock = pygame.time.Clock()
        # 调用私有创建精灵的方法,创建精灵和精灵组
        self.__create_sprites()
        # 设置定时器事件,创建敌机,时间1s
        pygame.time.set_timer(CREATE_ENEMY_EVENT,1000)
        # 设置定时器事件,发射子弹
        pygame.time.set_timer(HERO_FIRE_EVENT,500)

    def __create_sprites(self):
        # 创建精灵和精灵组
        bg1 = Background()
        bg2 = Background(True)
        # bg2.rect.y = -SCREEN_RECT.height
        self.back_group = pygame.sprite.Group(bg1, bg2)
        # 创建敌机的精灵组
        self.enemy_group = pygame.sprite.Group()
        # 建立英雄飞机精灵和精灵组
        self.hero = Hero()
        self.hero_groups = pygame.sprite.Group(self.hero)

    def start_game(self):
        print("游戏开始")
        while True:
            # 1.设置刷新帧率
            self.clock.tick(FRAME_PER_SECTION)
            # 2.事件监听
            self.__event_handle()
            # 3.碰撞检测
            self.__check_collide()
            # 4.更新/绘制精灵组
            self.__update_sprites()
            # 5.更新显示
            pygame.display.update()

    def __event_handle(self):
        for event in pygame.event.get():
            if event.type == pygame.QUIT:
                PlaneGame.__game_over()
            elif event.type == CREATE_ENEMY_EVENT:
                print("敌机出现")
                # 创建敌机精灵
                enemy = Enemy()
                # 将精灵添加到精灵组中
                self.enemy_group.add(enemy)
            # elif event.type == pygame.KEYDOWN and event.key == pygame.K_RIGHT:
            #     self.hero.rect.x += 5
            # elif event.type == pygame.KEYDOWN and event.key == pygame.K_LEFT:
            #     self.hero.rect.x -= 5
            elif event.type == HERO_FIRE_EVENT:
                self.hero.fire()
        # 使用键盘的方法获取按键
        key_pressed = pygame.key.get_pressed() # 获取按键元组
        # 判断元组中对应按键索引
        if key_pressed[pygame.K_RIGHT]:
            self.hero.speed_x = 2
            self.hero.update()
            self.hero.speed_x = 0
        if key_pressed[pygame.K_LEFT]:
            self.hero.speed_x = -2
            self.hero.update()
            self.hero.speed_x = 0
        if key_pressed[pygame.K_UP]:
            self.hero.speed_y = -3
            self.hero.update()
            self.hero.speed_y = 0
        if key_pressed[pygame.K_DOWN]:
            self.hero.speed_y = 3
            self.hero.update()
            self.hero.speed_y = 0

    def __check_collide(self):
        # 1.子弹打飞机
        pygame.sprite.groupcollide(self.hero.bullets, self.enemy_group, True, True)
        # 2.英雄飞机撞敌机
        enemies = pygame.sprite.spritecollide(self.hero, self.enemy_group, True)
        # 3.判断列表内容
        if len(enemies) > 0:
            #self.hero.kill()
            # 结束游戏
            PlaneGame.__game_over()

    def __update_sprites(self):
        self.back_group.update()
        self.back_group.draw(self.screen)
        self.enemy_group.update()
        self.enemy_group.draw(self.screen)
        self.hero_groups.update()
        self.hero_groups.draw(self.screen)
        self.hero.bullets.update()
        self.hero.bullets.draw(self.screen)

    @staticmethod
    def __game_over():
        print("游戏结束")
        # 清屏
        pygame.display.get_surface().fill((0, 0, 0))
        # 设置字体
        font = pygame.font.SysFont("arial", 72)  # 字体和字号
        # 渲染文本
        text_surface = font.render("GAME_OVER", True, (255, 0, 0))
        # 获取文本矩形
        text_rect = text_surface.get_rect(center=(SCREEN_RECT.width // 2, SCREEN_RECT.height // 2))
        # 将文本绘制到窗口
        pygame.display.get_surface().blit(text_surface, text_rect)
        # 更新显示
        pygame.display.update()
        # 等3秒
        pygame.time.delay(3000)
        pygame.quit()  # 卸载所有模块
        exit()

if __name__ == "__main__":
    print("游戏开始")
    # 创建游戏对象
    game = PlaneGame()
    # 启动游戏
    game.start_game()

辅助程序

import pygame
import random
# 屏幕大小的常量
SCREEN_RECT = pygame.Rect(0, 0, 480, 700)
FRAME_PER_SECTION = 60
# 创建敌机定时器常量
CREATE_ENEMY_EVENT = pygame.USEREVENT
# 英雄发射子弹的事件
HERO_FIRE_EVENT = pygame.USEREVENT + 1class GameSprite(pygame.sprite.Sprite):"""游戏精灵类"""def __init__(self, image_name, speed=1):# 调用父类的初始化方法super().__init__()self.image = pygame.image.load(image_name)self.speed = speedself.rect = self.image.get_rect() # 默认位置(0,0)def update(self):# 屏幕垂直方向移动self.rect.y += self.speedclass Background(GameSprite):"""游戏背景"""def __init__(self, is_alt = False):# 1.调用父类的初始方法,指定图片super().__init__("images/background.png")# 2.判断是否为第二张图片,如果是需要指定.if is_alt:self.rect.y = -self.rect.heightdef update(self):# 1.调用父类方法super().update()# 2.判断背景是否移出屏幕,如果移出屏幕则移动到屏幕的上方if self.rect.y >= SCREEN_RECT.height:self.rect.y = -SCREEN_RECT.heightclass Enemy(GameSprite):"""创建敌机类"""def __init__(self):# 1.调用父类的初始方法,指定图片super().__init__("images/enemy1.png")# 2.指定敌机的初始随机速度self.speed = random.randint(1,3)# 3.指定敌机的初始随机位置self.rect.bottom = 0max_x = SCREEN_RECT.width - self.rect.widthself.rect.x = random.randint(0,max_x)def update(self):# 1.调用父类方法,保证垂直移动super().update()# 2.判断是否飞出屏幕,飞出则从敌机精灵组删除if self.rect.y >= SCREEN_RECT.height:# print("飞出屏幕")# 飞出屏幕,kill来删除self.kill()def __del__(self):# print("飞机坠机了")passclass Hero(GameSprite):"""英雄飞机"""def __init__(self):# 1.调用父类方法,竖直方向上不移动super().__init__("images/me1.png",speed = 0)# 2.设置初始位置self.rect.centerx = SCREEN_RECT.centerxself.rect.bottom = SCREEN_RECT.bottom - 120# 3.创建子弹精灵组self.bullets = pygame.sprite.Group()self.speed_x = 0self.speed_y = 0def update(self):# 水平移动self.rect.x += self.speed_x# 垂直移动self.rect.y += self.speed_y# 控制飞机飞出边界if self.rect.x <= 0 or self.rect.right >= SCREEN_RECT.width:self.rect.x -= self.speed_xself.rect.y -= self.speed_ydef fire(self):print("发射子弹")for i in range(0, 3):# 1.创建子弹精灵bullet = Bullet()# 2.设置子弹精灵的位置bullet.rect.bottom = self.rect.y - i * 20bullet.rect.centerx = self.rect.centerx# 3.子弹加入到子弹精灵组self.bullets.add(bullet)class Bullet(GameSprite):"""子弹类"""def __init__(self):# 调用父类方法设置子弹图片和位置super().__init__("images/bullet1.png", speed=-2)def update(self):# 调用父类方法,垂直飞行super().update()# 判断子弹是否飞出屏幕if self.rect.bottom < 0:self.kill()def __del__(self):print("子弹销毁")

这篇关于python项目(课设)——飞机大战小游戏项目源码(pygame)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1081933

相关文章

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、