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版本的飞机大战游戏,你可能需要考虑以下几个方面: 游戏设计:确定游戏的基本规则,比如玩家控制的飞机…...
浏览器访问 AWS ECS 上部署的 Docker 容器(监听 80 端口)
✅ 一、ECS 服务配置 Dockerfile 确保监听 80 端口 EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]或 EXPOSE 80 CMD ["python3", "-m", "http.server", "80"]任务定义(Task Definition&…...

超短脉冲激光自聚焦效应
前言与目录 强激光引起自聚焦效应机理 超短脉冲激光在脆性材料内部加工时引起的自聚焦效应,这是一种非线性光学现象,主要涉及光学克尔效应和材料的非线性光学特性。 自聚焦效应可以产生局部的强光场,对材料产生非线性响应,可能…...
【杂谈】-递归进化:人工智能的自我改进与监管挑战
递归进化:人工智能的自我改进与监管挑战 文章目录 递归进化:人工智能的自我改进与监管挑战1、自我改进型人工智能的崛起2、人工智能如何挑战人类监管?3、确保人工智能受控的策略4、人类在人工智能发展中的角色5、平衡自主性与控制力6、总结与…...
QMC5883L的驱动
简介 本篇文章的代码已经上传到了github上面,开源代码 作为一个电子罗盘模块,我们可以通过I2C从中获取偏航角yaw,相对于六轴陀螺仪的yaw,qmc5883l几乎不会零飘并且成本较低。 参考资料 QMC5883L磁场传感器驱动 QMC5883L磁力计…...
多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验
一、多模态商品数据接口的技术架构 (一)多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如,当用户上传一张“蓝色连衣裙”的图片时,接口可自动提取图像中的颜色(RGB值&…...
在Ubuntu中设置开机自动运行(sudo)指令的指南
在Ubuntu系统中,有时需要在系统启动时自动执行某些命令,特别是需要 sudo权限的指令。为了实现这一功能,可以使用多种方法,包括编写Systemd服务、配置 rc.local文件或使用 cron任务计划。本文将详细介绍这些方法,并提供…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

(转)什么是DockerCompose?它有什么作用?
一、什么是DockerCompose? DockerCompose可以基于Compose文件帮我们快速的部署分布式应用,而无需手动一个个创建和运行容器。 Compose文件是一个文本文件,通过指令定义集群中的每个容器如何运行。 DockerCompose就是把DockerFile转换成指令去运行。 …...

【JavaWeb】Docker项目部署
引言 之前学习了Linux操作系统的常见命令,在Linux上安装软件,以及如何在Linux上部署一个单体项目,大多数同学都会有相同的感受,那就是麻烦。 核心体现在三点: 命令太多了,记不住 软件安装包名字复杂&…...

OPENCV形态学基础之二腐蚀
一.腐蚀的原理 (图1) 数学表达式:dst(x,y) erode(src(x,y)) min(x,y)src(xx,yy) 腐蚀也是图像形态学的基本功能之一,腐蚀跟膨胀属于反向操作,膨胀是把图像图像变大,而腐蚀就是把图像变小。腐蚀后的图像变小变暗淡。 腐蚀…...