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)
主程序 import pygame from plane_sprites import * class PlaneGame: """ 游戏类 """ def __init__(self): print("游戏初始化") # 初始化字体模块 pygame.font.init() # 创建游戏…...
Chatgpt教我打游戏攻略
宝可梦朱 我在玩宝可梦朱的时候,我的同行队伍里有黏美儿,等级为65,遇到了下雨天但是没有进化,为什么呢? 黏美儿(Goomy)要进化为黏美龙(Goodra),需要满足以下…...
最全信息收集工具集
吉祥学安全知识星球🔗除了包含技术干货:Java代码审计、web安全、应急响应等,还包含了安全中常见的售前护网案例、售前方案、ppt等,同时也有面向学生的网络安全面试、护网面试等。 所有的攻防、渗透第一步肯定是信息收集了…...
redis类型解析汇总
redis类型解析汇总 介绍数据类型简介主要数据类型:衍生类型: 字符串(String)底层设计原理图例设计优势字符串使用方法设置字符串值获取字符串值获取和设置部分字符串获取字符串长度追加字符串设置新值并返回旧值递增/递减同时设置…...
Unity3d自定义TCP消息替代UNet实现网络连接
以前使用UNet实现网络连接,Unity2018以后被弃用了。要将以前的老程序升到高版本,最开始打算使用Mirro,结果发现并不好用。那就只能自己写连接了。 1.TCP消息结构 (1). TCP消息是按流传输的,会发生粘包。那么在发射和接收消息时就需要对消息进行打包和解包。如果接收的消息…...
git fetch 和 git pull区别
git branch //查看本地所有分支 git branch -r //查看远程所有分支 git branch -a //查看本地和远程的所有分支 git branch <branchname> //新建分支 git branch -d <branchname> //删除本地分支 git branch -d -r <branchname> //删除远程分支&#x…...
冲击2024年CSDN博客之星TOP1:CSDN文章质量分查询在哪里?
文章目录 一,2023年博客之星规则1,不高的入围门槛2,[CSDN博文质量分测评地址](https://www.csdn.net/qc) 二,高分秘籍1,要有目录2,文章长度要足够,我的经验是汉字加代码至少1000字。3࿰…...
高性能并行计算华为云实验一:MPI矩阵运算
目录 一、实验目的 二、实验说明 三、实验过程 3.1 创建矩阵乘法源码 3.1.1 实验说明 3.1.2 实验步骤 3.2 创建卷积和池化操作源码 3.2.1 实验说明 3.2.2 实验步骤 3.3 创建Makefile文件并完成编译 3.4 建立主机配置文件与运行监测 四、实验结果与分析 4.1 矩阵乘法…...
库卡机器人减速机维修齿轮磨损故障
一、KUKA机器人减速器齿轮磨损故障的原因 1. 润滑不足:润滑油不足或质量不佳可能导致齿轮磨损。 2. 负载过重:超过库卡机械臂减速器额定负载可能导致齿轮磨损。 3. 操作不当:未按照说明书操作可能导致KUKA机器人减速器齿轮磨损。 4. 维护不足…...
【C/C++】我自己提出的数组探针的概念,快来围观吧
数组探针 在许多编程语言中如果涉及到数组那么就可以使用这个东西,便于遍历数组 中文名 数组探针 外文名 arrProbe 适用领域 大数据 所属学科 软件技术、编程 提出者 董翔 目录 1 概述2 工作原理3 应用场景 ▪ 数据处理和分析▪ 图像处理▪ 游戏开发▪…...
ArcGIS图斑分区(组)排序—从上到下从左到右
点击下方全系列课程学习 点击学习—>ArcGIS全系列实战视频教程——9个单一课程组合系列直播回放 ArcGIS图斑分区(组)从上到下从左到右排序 是之前的内容的升级 GIS技巧100例——12ArcGIS图斑空间排序 关于今天的内容 我们在19年已经和大家分…...
React useRef 组件内及组件传参使用
保存变量, 改变不引起渲染 import { useRef} from react; const dataRef useRef(null) ... dataRef.current setTimeout(()>console.log(...),1000)绑定dom const inputRef useRef(null) <input ref {inputRef} />绑定dom列表 - ref 回调 const ite…...
Intelij IDEA中Mapper.xml无法构建到资源目录的问题
问题场景: 在尝试把原本在eclipse上的Java Web项目转移至Intelij idea上时,在配置文件均与eclipse一致的情况下出现了如下报错: org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): cn.umbrella.crm_core.…...
2024.6.23周报
目录 摘要 ABSTRACT 一、文献阅读 一、题目 二、摘要 三、网络架构 四、创新点 五、文章解读 1、Introduction 2、Method 3、实验 4、结论 二、代码实验 总结 摘要 本周阅读了一篇题目为NAS-PINN: NEURAL ARCHITECTURE SEARCH-GUIDED PHYSICS-INFORMED NEURAL N…...
鸿蒙实战开发:网络层的艺术——优雅封装与搭建指南(中)
前言 在鸿蒙开发的广袤天地中,网络层的搭建与封装无疑是构建高效、稳定应用的基石。继上篇的探索之后,本文将继续深入网络层的优化之旅,揭秘如何通过类型转换器、请求查询附加器以及丰富的常量参数,将网络层的构建艺术推向一个新…...
docker in docker 连私有仓库时报错 https
背景 jenkins 是使用 docker 方式部署的, 在 jenkins中又配置了 docker 的命令, 使用的宿主机的 docker 环境, 在jenkins 中执行 docker 相关命令的时候报错 jenkinse0e7b943b6e4:/$ docker login -u admin -p Harbor12345 172.16.100.15:80 WARNING! Using --password via t…...
mac怎么压缩pdf文件,苹果电脑怎么压缩pdf文件大小
在当今数字化时代,PDF文件已成为广泛使用的文档格式之一。然而,PDF 文件可能会因其包含的图像、图形和其他元素而导致文件较大,这可能会影响文件的传输、存储和共享。因此,对 PDF 文件进行压缩以减小其文件大小是很有必要的。今天…...
兴顺物流管理系统的设计
管理员账户功能包括:系统首页,个人中心,管理员管理,驾驶员管理,物流资讯管理,车辆管理,基础数据管理 员工账户功能包括:系统首页,个人中心,物流资讯管理&…...
力扣(2024.06.21)
1. 54——螺旋矩阵 给你一个 m 行 n 列的矩阵 matrix ,请按照顺时针螺旋顺序 ,返回矩阵中的所有元素。 标签:数组,矩阵,模拟 代码: class Solution:def spiralOrder(self, matrix: List[List[int]]) -&…...
飞机大战java
"飞机大战"是一种经典的射击游戏,通常在各种平台上都有实现,包括Java。如果你想要开发一个Java版本的飞机大战游戏,你可能需要考虑以下几个方面: 游戏设计:确定游戏的基本规则,比如玩家控制的飞机…...
手游刚开服就被攻击怎么办?如何防御DDoS?
开服初期是手游最脆弱的阶段,极易成为DDoS攻击的目标。一旦遭遇攻击,可能导致服务器瘫痪、玩家流失,甚至造成巨大经济损失。本文为开发者提供一套简洁有效的应急与防御方案,帮助快速应对并构建长期防护体系。 一、遭遇攻击的紧急应…...
前端导出带有合并单元格的列表
// 导出async function exportExcel(fileName "共识调整.xlsx") {// 所有数据const exportData await getAllMainData();// 表头内容let fitstTitleList [];const secondTitleList [];allColumns.value.forEach(column > {if (!column.children) {fitstTitleL…...
高频面试之3Zookeeper
高频面试之3Zookeeper 文章目录 高频面试之3Zookeeper3.1 常用命令3.2 选举机制3.3 Zookeeper符合法则中哪两个?3.4 Zookeeper脑裂3.5 Zookeeper用来干嘛了 3.1 常用命令 ls、get、create、delete、deleteall3.2 选举机制 半数机制(过半机制࿰…...
vue3+vite项目中使用.env文件环境变量方法
vue3vite项目中使用.env文件环境变量方法 .env文件作用命名规则常用的配置项示例使用方法注意事项在vite.config.js文件中读取环境变量方法 .env文件作用 .env 文件用于定义环境变量,这些变量可以在项目中通过 import.meta.env 进行访问。Vite 会自动加载这些环境变…...
什么是Ansible Jinja2
理解 Ansible Jinja2 模板 Ansible 是一款功能强大的开源自动化工具,可让您无缝地管理和配置系统。Ansible 的一大亮点是它使用 Jinja2 模板,允许您根据变量数据动态生成文件、配置设置和脚本。本文将向您介绍 Ansible 中的 Jinja2 模板,并通…...
鸿蒙DevEco Studio HarmonyOS 5跑酷小游戏实现指南
1. 项目概述 本跑酷小游戏基于鸿蒙HarmonyOS 5开发,使用DevEco Studio作为开发工具,采用Java语言实现,包含角色控制、障碍物生成和分数计算系统。 2. 项目结构 /src/main/java/com/example/runner/├── MainAbilitySlice.java // 主界…...
Linux C语言网络编程详细入门教程:如何一步步实现TCP服务端与客户端通信
文章目录 Linux C语言网络编程详细入门教程:如何一步步实现TCP服务端与客户端通信前言一、网络通信基础概念二、服务端与客户端的完整流程图解三、每一步的详细讲解和代码示例1. 创建Socket(服务端和客户端都要)2. 绑定本地地址和端口&#x…...
Java + Spring Boot + Mybatis 实现批量插入
在 Java 中使用 Spring Boot 和 MyBatis 实现批量插入可以通过以下步骤完成。这里提供两种常用方法:使用 MyBatis 的 <foreach> 标签和批处理模式(ExecutorType.BATCH)。 方法一:使用 XML 的 <foreach> 标签ÿ…...
深度学习水论文:mamba+图像增强
🧀当前视觉领域对高效长序列建模需求激增,对Mamba图像增强这方向的研究自然也逐渐火热。原因在于其高效长程建模,以及动态计算优势,在图像质量提升和细节恢复方面有难以替代的作用。 🧀因此短时间内,就有不…...
django blank 与 null的区别
1.blank blank控制表单验证时是否允许字段为空 2.null null控制数据库层面是否为空 但是,要注意以下几点: Django的表单验证与null无关:null参数控制的是数据库层面字段是否可以为NULL,而blank参数控制的是Django表单验证时字…...
