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("子弹销毁")

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

南卡、漫步者和Oladance开放式哪家强?无广避坑测评!

现在市面上的开放式耳机种类非常多&#xff0c;在购买的时候大多数人都没有非常确定的目标&#xff0c;这主要是因为大多数人对开放式耳机的认识程度不够。 作为一个有着多年数码产品测评经验的测评员&#xff0c;我刚好对开放式耳机也有比较深刻的理解&#xff0c;也借着大家…

策略模式:applicationContext.getBeansOfType()方法

applicationContext.getBeansOfType() 一般用来获取某个接口的所有实例Bean 方法定义如下&#xff1a; 入参一般是接口&#xff0c;即interface。响应是个Map结构&#xff0c;key bean在容器中的名称&#xff0c;value bean实列 开发步骤&#xff1a; 1.定义接口 2.定义…

智汇云舟成为中煤集团中煤智能创新联盟成员单位

6月21日&#xff0c;第八届世界智能产业博览会平行会议暨中煤智能创新联盟交流会在天津水游城丽筠酒店顺利举行。智汇云舟受邀参与&#xff0c;并由中国中煤能源集团授予荣誉证书&#xff0c;正式成为中煤智能创新联盟成员单位。会议上&#xff0c;清华大学、中国矿业大学&…

【SkiaSharp绘图08】SKPaint方法:自动换行、是否乱码、字符偏移、边界、截距、文本轮廓、测量文本

文章目录 SKPaint方法BreakText 计算指定宽度内可绘制的字符个数ContainsGlyphs字体是否包含文本字符(是否会乱码)GetGlyphOffsets 字符偏移量GetGlyphPositions 偏移坐标GetGlyphWidths 每个字符的宽度与边界GetHorizontalTextIntercepts 轮廓截距GetPositionedTextIntercepts…

CVPR 2024第三弹:李飞飞教授惊喜亮相,CVPR之家乐队火爆演奏惊艳全场

CVPR 2024第三弹&#xff1a;小编与李飞飞教授惊喜同框&#xff0c;"CVPR之家"乐队火爆演奏惊艳全场&#xff01; 会议之眼 快讯 2024 年 CVPR &#xff08;Computer Vision and Pattern Recogntion Conference) 即国际计算机视觉与模式识别会议&#xff0c;于6月1…

电脑ai写作软件,4款实用的软件!

在数字化时代&#xff0c;AI写作软件已经成为创作者们不可或缺的工具。它们利用先进的自然语言处理技术和大数据分析&#xff0c;能够快速生成高质量的文章&#xff0c;大大提升了创作效率。那么&#xff0c;市面上有哪些值得一试的电脑AI写作软件呢&#xff1f;让我们一起来盘…

mongodb嵌套聚合

db.order.aggregate([{$match: {// 下单时间"createTime": {$gte: ISODate("2024-05-01T00:00:00Z"),$lte: ISODate("2024-05-31T23:59:59Z")}// 商品名称,"goods.productName": /美国皓齿/,//订单状态 2:待发货 3:已发货 4:交易成功…

“神刊”CA再回巅峰!2024年JCR正式发布,共21848本期刊,附完整版EXCEL版下载!

2024 年 6 月 20 日&#xff0c;科睿唯安&#xff08;Clarivate Analytics&#xff09;发布了最新的《期刊引证报告》(Journal Citation Reports&#xff0c;JCR&#xff09;&#xff0c;以下简要介绍最新影响因子&#xff08;IF&#xff09;情况&#xff1a; 2023年完整版JCR…

容器之工具栏构件演示

代码; #include <gtk-2.0/gtk/gtk.h> #include <glib-2.0/glib.h> #include <gtk-2.0/gdk/gdkkeysyms.h> #include <stdio.h>int main(int argc, char *argv[]) {gtk_init(&argc, &argv);GtkWidget *window;window gtk_window_new(GTK_WINDO…

[Qt]Qt框架解析:从入门到精通,探索平台开发的无限可能

一、Qt的概述 Qt是一个跨平台的C图形用户界面应用程序框架&#xff08;GUI&#xff09;。它为应用程序开发者提供建立艺术级图形界面所需的所有功能。它是完全面向对象的&#xff0c;很容易扩展&#xff0c;并且允许真正的组件编程。开发环境为Qt creator5.8.0&#xff0c;下载…

项目经验——交通行业数据可视化大屏、HMI设计

交通行业数据大屏、HMI设计时要的注意点&#xff1a;清晰可读、简洁直观、适配性强。颜色对比度满足WCAG标准&#xff0c;深色背景减少干扰&#xff0c;实时展示交通数据&#xff0c;支持有线网络控制内容更新&#xff0c;保障驾驶安全与决策效率。

通过“BOSS”精通比特币,深入认识私钥、账户和钱包

来源:币界原创 作者:636Marx 无论当今数字货币技术如何发展&#xff0c;认识区块链技术幕后的关键机制至关重要。无论您是新手还是经验丰富的数字货币从业者&#xff0c;掌握钱包地址、公钥和私钥的复杂性都有无可替代重要性。进入 BOSS Wallet&#xff0c;这是一款尖端的 Web…

ICMAN触摸芯片——防水触摸

ICMAN触摸芯片之防水触摸触摸按键控制开关和调节挡位和切换不同模式 淋水状态下&#xff0c;触摸按键反应灵敏&#xff0c;不误触发&#xff0c; ICMAN触摸芯片稳定性与抗干扰能力强&#xff0c; 可以轻松解决家电触摸感应不灵敏和有水误触发的问题&#xff0c; 从而有效实…

Linux_文件IO

目录 一、库函数进行文件操作 1、fopen/fclose 2、fwrite 3、追加方式-“a” 4、fread 5、三个默认文件流 二、系统函数进行文件操作 1、open/close 2、write 3、追加方式-“O_APPEND” 4、read 5、struct file结构体 6、文件描述符 6.1 struct file的引用…

中学理化生实验室建设及配置要求

在中学物理、化学、生物等学科教学中&#xff0c;实验占据了非常重要的地位&#xff0c;是整个教学过程中不可或缺的部分。很多理科教学需要在实验室完成演示和学习任务&#xff0c;实验室也是保证教学计划得以实施的物质基础。因此&#xff0c;中学理化生实验室建设标准与否&a…

【C++ | const成员】类的 const数据成员、const成员函数、const对象、mutable 数据成员

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; ⏰发布时间⏰&#xff1a;2024-06-14 2…

win10修改远程桌面端口号,在Windows 10中修改远程桌面端口号的步骤

在Windows 10中&#xff0c;远程桌面服务&#xff08;Remote Desktop Services, RDS&#xff09;允许用户从远程位置访问和操作计算机。默认情况下&#xff0c;远程桌面协议&#xff08;RDP&#xff09;使用端口3389进行通信。然而&#xff0c;出于安全考虑&#xff0c;管理员可…

VScode创建ROS项目 ROS集成开发环境

ROS使用VScode创建项目步骤 1.创建ROS工作空间2.启动VScode3.VScode编译ROS4.创建ROS功能包C语言开发Python语言开发 本文章介绍了如何在Ubuntu18.04系统下搭建VScode 的ROS项目 搭建项目分为一下几个步骤&#xff1a; 1.创建ROS工作空间 创建一个demo的ROS工作空间&#xff0…

大数据学习-Hadoop

介绍 是 Apache 的顶级开源项目&#xff0c;一个分布式框架&#xff0c;主要功能&#xff1a; 分布式大数据存储——HDFS 组件分布式大数据计算——MapReduce 组件分布式资源调度——YARN 组件 可以通过它来构建集群&#xff0c;完成大数据的存储和计算 学习起来相对简单&…

怎么看电脑实时充电功率

因为我想测试不同的充电器给电脑充电的速度&#xff0c;所以就想找一款软件可以看电脑当前充电功率的软件&#xff0c;我给一个图 直接搜索就可以下载了&#xff0c;charge rate就是功率&#xff0c;这里是毫瓦&#xff0c;换算单位是 1000mw1w 所以我这里充电功率是65w&…