【python】飞机大战

import pygame
import random
 
# 敌机出现事件
ENEMY_EVENT = pygame.USEREVENT
# 发射子弹事件
FIRE = pygame.USEREVENT + 1
 
 
class GameSprite(pygame.sprite.Sprite):
    def __init__(self, image_name, speed=1):
        super().__init__()
        # 定义对象的属性
        self.image = pygame.image.load(image_name)
        self.rect = self.image.get_rect()  # 获取图像数据的宽和高
        self.speed = speed
 
    def update(self):
        # 在屏幕的垂直向下方向移动
        self.rect.y += self.speed
 
 
# 背景精灵
class Background(GameSprite):
    def __init__(self, is_alt=False):
        # 调用父类方法实现精灵的创建
        super().__init__('./images/background.png')
        # 判断是否是第二张图,如果是,需要重新设置位置
        if is_alt:
            self.rect.y = -self.rect.height
 
    def update(self):
        # 调用父类方法实现垂直向下移动
        super(Background, self).update()
        # 判断是否飞出屏幕,如果飞出,
        # 将图像设置到屏幕上方
        if self.rect.y >= 700:
            self.rect.y = -self.rect.height
 
 
'''
敌机出场的实现
1.游戏启动后,每隔一秒钟出现一架
2.每架敌机向下飞行,飞行的速度各不相同
3.每架敌机出现的水平位置也不同
4.当敌机从屏幕下方飞出,不会飞回到屏幕
 
 
定时器:每隔一段时间执行某些操作
pygame.time.set_timer()
第一个参数是事件代号,需要基于常量pygame.USEREVENT来指定
(pygame.USEREVENT是一个整数,再增加的时间可以使用pygame.USEREVENT+1)
第二个参数是事件触发的毫秒
'''
 
 
# 敌机类
class Enemy(GameSprite):
    def __init__(self):
        # 调用父类方法,创建敌机精灵,同时指定敌机图片
        super().__init__('./images/enemy1.png')
        # 指定敌机的初始随机速度
        self.speed = random.randint(1, 2)
        # 指定敌机的初始随机位置
        self.rect.x = random.randint(0, 480 - self.rect.width)
 
    def update(self):
        # 调用父类方法,保持垂直向下飞行
        super().update()
        # 判断是否飞出屏幕,如果是,需要从精灵中删除
        if self.rect.y >= 700:
            print('飞出屏幕,需要删除')
            self.kill()
 
 
'''
英雄飞机和子类类
英雄飞机
    游戏启动后,英雄飞机出现在屏幕上默认的位置
    英雄飞机每隔0.5秒发射一次子弹,每次连续发射三颗子弹
    英雄飞机不会移动,需要通过方向键控制飞机在屏幕上移动
子弹类
    子弹从英雄飞机的正上方沿着直线向上飞行
    飞出屏幕后,需要从精灵组中删除
     
     
捕捉按键控制飞机的移动:
pygame.key.get_pressed()返回所有按键元组
通过键盘常量,判断元组中某一个键是否被按下
'''
 
 
# 英雄类
class Hero(GameSprite):
    def __init__(self):
        # 调用父类方法设置image和rect
        super().__init__('./images/me1.png', 0)
        # 设置初始位置
        self.rect.y = 700 - self.rect.height - 100
        self.rect.x = 240 - self.rect.width / 2
        self.upanddown = 0
        # 创建子弹精灵组
        self.bullets = pygame.sprite.Group()
 
    def update(self):
        # 左右移动
        self.rect.x += self.speed
        # 上下移动
        self.rect.y += self.upanddown
        # 控制英雄飞机不能离开屏幕
        if self.rect.x <= 0:
            self.rect.x = 0
        elif self.rect.x >= 480 - self.rect.width:
            self.rect.x = 480 - self.rect.width
        elif self.rect.y <= 0:
            self.rect.y = 0
        elif self.rect.y >= 700 - self.rect.height:
            self.rect.y = 700 - self.rect.height
        # 从左边出去后,从右边进来
        # if self.rect.x <= -self.rect.width:
        #     self.rect.x = 480
 
    def fire(self):
        print('发射子弹')
        for i in range(3):
            # 创建子弹精灵
            bullet = Bullet()
            # 设置子弹精灵的位置
            bullet.rect.y = self.rect.y - (i+1)*20
            # centerx:矩形区域中间x的位置
            bullet.rect.centerx = self.rect.centerx
            # 将精灵添加到精灵组
            self.bullets.add(bullet)
 
 
# 子弹类
class Bullet(GameSprite):
    def __init__(self):
        super().__init__('./images/bullet1.png', -2)
 
    def update(self):
        # 调用父类方法,让子弹沿垂直向上飞行
        super().update()
        # 判断子弹是否飞出屏幕
        if self.rect.y <= -self.rect.height:
            self.kill()

import pygame
from day6.plane_sprite import *
 
 
class PlaneGame:
    def __init__(self):
        # 1.创建游戏屏幕
        self.screen = pygame.display.set_mode((480, 700))
        # 2.创建时钟对象
        self.clock = pygame.time.Clock()
        # 3.调用创建精灵和精灵组的私有方法
        self.__create_sprites()
        # 设定一个定时器,每隔1000毫秒产生一个ENEMY_EVENT事件
        pygame.time.set_timer(ENEMY_EVENT, 1000)
        # 设定一个定时器,每隔500毫秒产生一个FIRE事件
        pygame.time.set_timer(FIRE, 500)
 
    # 创建精灵和精灵组
    def __create_sprites(self):
        # 创建背景精灵和精灵组
        # bg1 = Background('./images/background.png')
        # bg2 = Background('./images/background.png')
        # bg2.rect.y = -bg2.rect.height
        bg1 = Background()
        bg2 = Background(True)
        self.back_group = pygame.sprite.Group(bg1, bg2)
        # 创建敌机精灵组
        self.enemy_group = pygame.sprite.Group()
        # 创建英雄精灵和精灵组
        self.hero = Hero()
        self.hero_group = pygame.sprite.Group(self.hero)
 
    # 事件监听
    def __event_handler(self):
        # 获取按键
        keypressed = pygame.key.get_pressed()
        if keypressed[pygame.K_RIGHT]:  # 右键
            self.hero.speed = 2
        elif keypressed[pygame.K_LEFT]:  # 左键
            self.hero.speed = -2
        elif keypressed[pygame.K_UP]:  # 上键
            self.hero.upanddown = -2
        elif keypressed[pygame.K_DOWN]:  # 下键
            self.hero.upanddown = 2
        else:
            self.hero.speed = 0
            self.hero.upanddown = 0
 
        for event in pygame.event.get():
            if event.type == ENEMY_EVENT:
                print('敌机出场')
                # 创建敌机对象
                enemy = Enemy()
                self.enemy_group.add(enemy)
 
            elif event.type == pygame.QUIT:
                pygame.quit()
 
            elif event.type == FIRE:
                self.hero.fire()
 
    # 碰撞检测
    '''
    子弹碰撞敌机:发生碰撞的精灵将自动移除
    敌机碰撞英雄飞机:发生碰撞的精灵将自动移除,同时游戏结束
    groupcollide(group1, group2, dokill1, dokill2, collided=None)
    group1:精灵组1,group2:精灵组2
    dokill:如果将值设置为True,发生碰撞的精灵将自动移除
    collided:用于计算碰撞的回调函数,如果没有指定,则每个精灵都需要有一个rect属性
    返回值:不发生碰撞则返回空字典,发生碰撞返回有值的字典(键为组1,值为组2)
    '''
    def __check_collide(self):
        # 子弹碰撞敌机(都会消失)
        ret1 = pygame.sprite.groupcollide(self.hero.bullets,self.enemy_group, True, True)
        print(ret1)
        # 敌机碰撞英雄飞机
        ret = pygame.sprite.groupcollide(self.enemy_group,self.hero_group, True, True)
        if ret:
            pygame.quit()
 
    # 更新绘制精灵组
    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_group.update()
        self.hero_group.draw(self.screen)
        # 更新子弹
        self.hero.bullets.update()
        self.hero.bullets.draw(self.screen)
 
    def start_game(self):
        print('游戏开始')
        while True:
            # 1.设置刷新帧率
            self.clock.tick(60)
            # 2.事件监听
            self.__event_handler()
            # 3.碰撞检测
            self.__check_collide()
            # 4.更新绘制精灵组
            self.__update_sprites()
            # 5.更新屏幕显示
            pygame.display.update()
 **加粗样式**
 
if __name__ == '__main__':
    # 创建游戏对象
    game = PlaneGame()
    # 启动游戏
    game.start_game()

飞机大战游戏打包成exe文件
python程序打包工具:pyinstaller
下载:
pip install pyinstaller -i https://pypi.tuna.tsinghua.edu.cn/simple

打包命令:(直接在cmd执行,不需要进入python环境)
pyinstaller -F 路径/主程序名.py

注意:最好将所有需要运行的py文件放到一个空文件下,同时将plane_start.py
中导入模块的前缀删掉.
在这里插入图片描述

打包成功后将会出现很多文件:
在这里插入图片描述

需要将使用到的图片,音频等等资源按照程序的路径放到dist文件夹中

在这里插入图片描述

如果打包成功之后,不能运行exe文件,则可以在终端运行该exe文件,会得到报错信息
关于Python飞机大战的介绍今天就到这里啦,后续我会为大家介绍并发编程的相关知识哦~
关注我,带你领略Python的风采~😍😍😍

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/256877.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

使用IDEA创建springboot依赖下载很慢,解决方法

显示一直在resolving dependencies&#xff0c;速度很慢 原因&#xff1a;maven会使用远程仓库来加载依赖&#xff0c;是一个国外的网站&#xff0c;所以会很慢。应该使用阿里云的镜像&#xff0c;这样速度会提升很多。 步骤&#xff1a;1.右击pom.xml&#xff0c;选择"m…

MFC 窗口创建过程与消息处理

目录 钩子简介 代码编写 窗口创建过程分析 消息处理 钩子简介 介绍几个钩子函数&#xff0c;因为它们与窗口创建工程有关 安装钩子函数 HHOOK SetWindowsHookExA([in] int idHook,[in] HOOKPROC lpfn,[in] HINSTANCE hmod,[in] DWORD dwThreadId ); 参数说明…

前端常见面试题之html和css篇

文章目录 一、html1. 如何理解html语义化2. 说说块级元素和内联元素的区别 二、css1. 盒模型的宽度offsetWidth如何计算2. box-sizing:border-box有什么用3. margin的纵向重叠问题4. 谈谈你对BFC的理解和应用5. 清除浮动有哪些方式6. 使用flex布局实现骰子37.position的absolut…

喜报!巨蟹数科荣获国家“高新技术企业”认定!

根据《高新技术企业认定管理办法》&#xff08;国科发火〔2016〕32 号&#xff09;和《高新技术企业认定管理工作指引》&#xff08;国科发火〔 2016〕195号&#xff09;有关规定&#xff0c;经省高新技术企业认定管理机构组织企业申请、专家评审等程序&#xff0c;并经全国高新…

Linux汇编语言编程-机器语言

机器语言是处理器看到的语言。 在获取-执行周期【fetch-execute cycle 】中获取的字节是机器码的字节。汇编语言可以定义为一种使程序员能够控制机器码的语言。汇编语言指定机器码。如果不熟悉机器语言&#xff0c;汇编语言的这一特性是不明显的。本章介绍 x86 机器码的主要特征…

一句话木马是什么?代码实例及绕过方法

一句话木马是指一种短小的、通常只有一行代码的恶意软件&#xff0c;它被用来在目标系统中执行攻击者的命令或代码。这种类型的木马通常通过各种途径被注入到目标系统中&#xff0c;一旦成功运行&#xff0c;攻击者就可以远程控制受感染的系统。一句话木马的目的包括窃取敏感信…

RPC(3):HttpClient实现RPC之GET请求

1HttpClient简介 在JDK中java.net包下提供了用户HTTP访问的基本功能&#xff0c;但是它缺少灵活性或许多应用所需要的功能。 HttpClient起初是Apache Jakarta Common 的子项目。用来提供高效的、最新的、功能丰富的支持 HTTP 协议的客户端编程工具包&#xff0c;并且它支持 H…

关于“Python”的核心知识点整理大全27

目录 10.5 小结 第&#xff11;1 章 测试代码 11.1 测试函数 name_function.py 函数get_formatted_name()将名和姓合并成姓名&#xff0c;在名和姓之间加上一个空格&#xff0c;并将它们的 首字母都大写&#xff0c;再返回结果。为核实get_formatted_name()像期望的那样工…

【超图】SuperMap iClient3D for WebGL/WebGPU ——地形影像

作者&#xff1a;taco 号外&#xff01;号外&#xff01;开新坑了&#xff01;开新坑了&#xff01;对于一个代码小白来讲&#xff0c;设置可能是刚接触开发的人&#xff08;还没接触准备接触&#xff09;的人来说。对于读代码或是在对产品的使用上会存在许许多多的疑惑。接下来…

uniapp笔记

/pages/component/swiper/swiper /pages/component/button/button navigator image 设置界面标题 页面跳转 设置TabBar 发起一个请求 网络请求

计算机组成原理——中央处理器cpu1-20

1、中央处理器&#xff08;CPU&#xff09;是指什么。C A、 运算器 B、 控制器 C、 运算器和控制器 D、 运算器、控制器和主存储器 2、在CPU中跟踪指令后继地址的寄存器是什么。B A、 主存地址寄存器 B、 程序计数器 C、 指令寄存器 D、 状态条件寄存器 3、操作控制器的…

VR党建:VR全景技术如何助力党建知识传播

导语&#xff1a; 随着科技的不断发展&#xff0c;虚拟现实技术逐渐深入人们生活的方方面面。VR全景技术作为一种全新的沉浸式体验方式&#xff0c;被广泛应用于娱乐、教育、医疗等领域。而在党建学习中&#xff0c;VR全景技术也展现出了巨大的潜力&#xff0c;成为了一种创新…

项目中webpack优化配置(持续更新)

项目中webpack优化配置 1. 开发效率&#xff0c; 体验 DLL&#xff08;开发过程中减少构建时间和增加应用程序的性能&#xff09; 使用 DllPlugin 进行分包&#xff0c;使用 DllReferencePlugin(索引链接) 对 manifest.json 引用&#xff0c;让一些基本不会改动的代码先打包…

java-sec-code中的文件上传

java-sec-code中的文件上传 这里仅讨论文件上传&#xff0c;不讨论后续利用(中间件解析漏洞等不做讨论) 任意文件伤害上传 any-->uploada.html-->upload访问any路由时&#xff0c;会出现upload.html的上传文件界面&#xff0c;指向upload路由 GetMapping("/any&qu…

java SSM教师业绩管理系统myeclipse开发mysql数据库springMVC模式java编程计算机网页设计

一、源码特点 java SSM教师业绩管理系统是一套完善的web设计系统&#xff08;系统采用SSM框架进行设计开发&#xff0c;springspringMVCmybatis&#xff09;&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代 码和数据库&#xff0c;系统主要采…

谷歌发布Gemini 1.0,开启生成式AI模型新时代!

&#x1f3a5; 屿小夏 &#xff1a; 个人主页 &#x1f525;个人专栏 &#xff1a; IT杂谈 &#x1f304; 莫道桑榆晚&#xff0c;为霞尚满天&#xff01; 文章目录 &#x1f4d1;前言一. Gemini的发布前期1.1 Gemini的准备1.2 DeepMnid 二. Gemini的三大杀手锏2.1 多模态能力2…

Linux 音视频SDK开发实践

一、兼容性适配处理 为什么需要兼容处理&#xff1f; 1、c兼容处理 主要有ABI兼容性问题&#xff0c;不同ubuntu系统依赖的ABI版本如下&#xff1a; ubuntu 18.04ubuntu 16.04ubuntu 14.04g7.55.44.8stdc版本libstdc.so.6.0.25libstdc.so.6.0.21libstdc.so.6.0.19GLIBCXXG…

详解YOLOv5网络结构/数据集获取/环境搭建/训练/推理/验证/导出/部署

一、本文介绍 本文给大家带来的教程是利用YOLOv5训练自己的数据集&#xff0c;以及有关YOLOv5的网络结构讲解/数据集获取/环境搭建/训练/推理/验证/导出/部署相关的教程&#xff0c;同时通过示例的方式让大家来了解具体的操作流程&#xff0c;过程中还分享给大家一些好用的资源…

电脑备忘录小工具怎么添加?怎么在电脑桌面添加备忘录?

作为一名天天用电脑办公的上班族&#xff0c;如果你需要对某个项目或问题进入深入思考&#xff0c;想要快速记录想法和思路&#xff0c;这时候会选择什么样的记事方式呢&#xff1f;如果你需要记录常用的工作文字内容、工作注意事项、项目流程、待办的工作安排等&#xff0c;用…

vue 将后端返回的二进制流进行处理并实现下载

什么是二进制流文件&#xff1f; 二进制文件是一种计算机文件格式&#xff0c;它的数据以二进制形式存储&#xff0c;与文本文件不同。二进制文件可以包含任意类型的数据&#xff0c;例如图像、音频、视频、可执行文件、压缩文件等&#xff0c;而文本文件则仅仅包含 ASCII 码或…