python简易版的飞机大战(图片资源请自找)

news2025/2/23 6:35:45
# 引入pygame工具包
import pygame
from pygame.locals import *
import time
import random
import sys
# 初始化pygame
pygame.init()
# 创建一个宽480高650的一个画布canvas
canvas = pygame.display.set_mode((480, 650))
# 加工图片资源
bg = pygame.image.load('bg.png')# 背景
enemy1 = pygame.image.load('enemy01.png')# 第一种敌机
bullet = pygame.image.load('b2.png')# 子弹
hero = pygame.image.load('hero1.png')# 英雄机
enemy2 = pygame.image.load('enemy02.png')# 第二种敌机
enemy3 = pygame.image.load('enemy03.png')# 第三种敌机

ex1 = pygame.image.load('effer2.png')# 爆炸1效果
ex2 = pygame.image.load('effer.png')# 爆炸2效果

gameover = pygame.image.load('gameover.png')
#爆炸效果动画,x,y指的是飞机爆炸时候的位置
def ex(x,y):
    canvas.blit(ex1,(x,y))
    canvas.blit(ex2,(x,y))
# 写一个方法:可以将文字传送到画布的相应位置上 words书写的内容,x,y表示将内容传送到画布的x,y位置

def writeCanvas(words,x,y,size=20):
    writer=pygame.font.SysFont('SimHei',size)
    myWrite=writer.render(words,True,(255,255,255))# red green blue0~255
    canvas.blit(myWrite,(x,y)) 

##############创建一个工厂(创建飞机)类################
class Plane():
    # 飞机->属性:x,y,skin,width,height,方法:飞行(从上往下飞)
    def __init__(self,x,y,skin,width,height,type):
        self.x = x
        self.y = y
        self.skin = skin
        self.width = width
        self.height = height
        self.type = type
    def fly(self):
        self.y = self.y + 2
        
############用工厂创建飞机####################
# 创建一个列表用来存储大批量飞机
ememys = []
# 让飞机产生的时间有一个间隔
creaeTime = 0
def createPlane():
    global creaeTime
    # 当这次创造敌飞机时间和上次创造敌飞机的是间隔2允许创造
    if time.time() - creaeTime > 0.5:
        creaeTime = time.time()
        # 因为敌飞机出现早画布时候,x坐标是随机的 飞机的宽高:100 x 68
        x = random.randint(0,480-100)
        y = -68
        # 红色飞机出现的概率是50% 蓝色的飞机出现概率是30% 另外一种飞机 20%
        # 随时产生一个数1-10之间的数,1-5之间红色的飞机 6-7蓝色的feiji 如果是8-10另外一种飞机
        planeType = random.randint(1,10)
        # 进行判断
        if planeType >= 1 and planeType <=8:
            ememys.append(Plane(x,y,enemy1,100,68,1))# 将创造红色的小飞机放到列表仓库中
        elif  planeType==9:
            ememys.append(Plane(x,y,enemy2,100,68,2))  
        else:
            ememys.append(Plane(x,y,enemy3,100,68,3))   
        #ememys.append(Plane(x,y,enemy1,100,68))
##########将批量飞机传送到画布上#################
def planeBlit():
    for e in ememys:
        if(e.y > 650):
            ememys.remove(e)
        else:
            canvas.blit(e.skin,(e.x,e.y))
# 让所有的敌飞机往下飞
def planeMove():
    for e in ememys:
        e.fly()
########################创建英雄机#######################
# heroPlane英雄机对象 480/2 - 80/2  650-62
heroPlane = Plane(200,550 ,hero,80,62,0)  # 80 x 62   
# 将英雄机传送到画布上
def heroBlit():
    canvas.blit(heroPlane.skin,(heroPlane.x,heroPlane.y))
##################子弹类################
mx = 0
my = 0
# 生产子弹的工厂创建完毕
class Bullet():
    def __init__(self,x,y,skin,width,height):
         self.x = x
         self.y = y
         self.skin = skin
         self.width = width
         self.height = height
 
# 批量创建子弹对象
cBTime = 0# 上次创造子弹的时间
bullets = []# 用来存储子弹的
def createBullet():
    global mx,my,cBTime
    if time.time()- cBTime > 1:
        cBTime = time.time()
        b = Bullet(mx-10,my-100,bullet,20,56)#20 x 56
        bullets.append(b)
def bulletBlit():# 将子弹全部传送画布
    for b in bullets:
        if b.y < 0:
           bullets.remove(b)
        else:
            canvas.blit(b.skin,(b.x,b.y)) 
# 让子弹往上飞(y值减少x不变)
def bulletMove():
    for e in  bullets:
        e.y = e.y-2          
#################子弹和敌飞机碰撞############
redPlane = 0# 打掉红色小飞机的个数
bluePlane = 0# 打掉蓝色小飞机的个数
goldPlane = 0# 打掉金色小飞机的个数
def hit():
   global redPlane,bluePlane,goldPlane# 表明在这个函数里使用外边三个变量
   # 考虑子弹与敌飞机碰撞边界条件
   # 1.子弹x值+子弹的宽>飞机x值 
   # 2.飞机的x值+飞机宽度 > 子弹的x值
   # 3.飞机的y值+飞机的高度 > 子弹的y值
   # 4.子弹的y值+子弹的高度 > 飞机的y值
   for b in bullets:
       for e in ememys:
           if b.x-e.x>=0 and e.x+100-b.x>=0 and e.y-b.y>=0 and b.y>=e.y-20:
               # 将满足碰撞条件的子弹对象和满足条件的敌飞机一并从仓库中移出
               ex(b.x,b.y)
               # 记录打掉飞机的数量
               if e.type == 1:# 红色的小飞机
                   redPlane = redPlane+1
               elif e.type == 2: # 
                   goldPlane = goldPlane+1# 金色飞机
               else:
                   bluePlane = bluePlane+1 #蓝色的小飞机
               bullets.remove(b)
               ememys.remove(e)
              
# 将击落飞机数记录在画布上
def writeEnemy():
    global redPlane,goldPlane,bluePlane
    # 书写红色的敌飞机
    writeCanvas('击落红飞机:'+str(redPlane),0,0)  
    writeCanvas('击落黄飞机:'+str(goldPlane),0,20)  
    writeCanvas('击落蓝飞机:'+str(bluePlane),0,40)  
# 英雄机的初始生命值
heroLife = 8
# 将生命值写到画布上
def drawCanvas():
    global heroLife
    writeCanvas('生命值:'+str(heroLife),400,0)
GameStatus = True
# 英雄机和敌机的碰撞
def heroHitEnemy():
    global heroLife,GameStatus
    # 遍历每个敌飞机
    for e in ememys:
        if heroPlane.x <= e.x+e.width and\
           heroPlane.x + heroPlane.width >= e.x and\
           heroPlane.y <= e.y+e.height and\
           heroPlane.y + heroPlane.height > e.y:
            print('敌飞机和英雄机碰撞')  
            ex(heroPlane.x,heroPlane.y)# 烟花效果     
            # 减少英雄机的生命值
            heroLife = heroLife-1 
            if heroLife == 0:
                GameStatus = False
            #删除碰撞的敌机
            ememys.remove(e)
            
##############背景滚动播放处理###############
#设置两个背景图片的初始y坐标,x坐标不需要设置因为都是0
bg1Y = 0
bg2Y = -650
def bgSroll():
    global bg1Y,bg2Y# global表示全局的意思这样就能对bg2Y,bg1Y进行操作
    
    bg1Y = bg1Y+1
    canvas.blit(bg,(0,bg1Y))
    if bg1Y>=650:
        bg1Y = -650
        
    bg2Y = bg2Y+1
    canvas.blit(bg,(0,bg2Y))
    if bg2Y >=650:
        bg2Y = -650
    

def handleEvent():
    global mx,my
    # 事件监听
    for event in pygame.event.get():
        if event.type == QUIT or event.type == KEYDOWN and event.key == K_ESCAPE:
            pygame.quit()
            sys.exit() 
            
        # 判断鼠标是否有移动,如果有鼠标移动事件产生,获取鼠标的x,y
        if event.type == MOUSEMOTION: 
            # 获取此时鼠标的x坐标
            mx = event.pos[0]
            my = event.pos[1]
            # 将英雄机的x,y坐标
            heroPlane.x = mx-40
            heroPlane.y = my-31
               
# 利用死循环的方式让窗口一直显示
while True:
    bgSroll()
    # 当游戏状态为关闭的时候
    if not GameStatus:
        writeCanvas('-战况统计-',50,100,size=50)
        writeCanvas('击落红飞机'+str(redPlane)+'架',50,150,size=25)
        writeCanvas('击落蓝飞机'+str(bluePlane)+'架',50,180,size=25)
        writeCanvas('击落黄飞机'+str(goldPlane)+'架',50,210,size=25)
        writeCanvas('GAME OVER',50,280,size=80)
        handleEvent()
        pygame.display.update()
        continue
    createPlane()# 创造飞机
    planeBlit()# 将全部飞机传送到画布上
    planeMove()# 让全部飞机移动起来
    heroBlit() # 将英雄机画到画布上
    createBullet()# 创在子弹
    bulletBlit()# 将子弹传送到画布上
    bulletMove()# 子弹移动
    hit()# 碰撞
    # 将击落飞机的数量记录在画布上
    writeEnemy()
    heroHitEnemy()
    drawCanvas() 
    handleEvent()
    # 更新窗口
    pygame.display.update()
    # 每次循环延迟15毫秒
    pygame.time.delay(15)
    
   
    
    

 

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

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

相关文章

Vue3之app.config.globalProperties(定义全局变量)

使用之因 一般我们在vue开发中&#xff0c;常用的功能&#xff0c;接口等等我们都会封装起来&#xff0c;如何每次创建一个组件&#xff0c;想要使用这些封装起来的功能、接口等等都需要先引入&#xff0c;再通过层层调用才可以得到结果&#xff0c;如果我现在一遍需要调用后端…

多旋翼物流无人机节能轨迹规划(Python代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

海外品牌推广:谷歌没收录?这些常见错误你可别犯!

你们是否曾经遇到过这样的情况&#xff1a;你在海外市场努力推广你的品牌&#xff0c;但是发现谷歌搜索结果中竟然找不到你的网站或品牌&#xff1f;别担心&#xff0c;你可能犯了一些常见的错误&#xff0c;让谷歌把你的品牌忽略掉了。让我们来看看这些错误&#xff0c;确保你…

3dsmax图纸怎么加密?

对设计行业来说&#xff0c;公司重要的设计图纸是一个企业非常重要的核心数据是命脉&#xff0c;那么具有如此重要性的3Dmax设计文件怎么才能确保文件的安全&#xff0c;避免竞争对手骗方案或者内部人员有意无意的泄密呢&#xff1f; 相信有很多老板或许都会遇到这样的问题。很…

❤️创意网页:有趣的文字冒险游戏(可以无限拓展)

✨博主&#xff1a;命运之光 &#x1f338;专栏&#xff1a;Python星辰秘典 &#x1f433;专栏&#xff1a;web开发&#xff08;简单好用又好看&#xff09; ❤️专栏&#xff1a;Java经典程序设计 ☀️博主的其他文章&#xff1a;点击进入博主的主页 前言&#xff1a;欢迎踏入…

图片转pdf怎么在线转?看看这几种在线转方法

图片转pdf怎么在线转&#xff1f;图片转PDF是一个非常常见的需求&#xff0c;因为在很多情况下&#xff0c;我们需要将一些图片文件转换为PDF文件格式&#xff0c;以便于传输、打印或者共享。如果你想在线转换图片为PDF文件&#xff0c;下面就给大家推荐几种简单实用的转换方法…

Hadoop集群运行Spark应用程序

启动Spark集群 先启动hadoop,再启动Spark,具体参考链接 对Linux系统对Spark开发环境配置_Matrix70的博客-CSDN博客 运行Spark安装好以后自带的样例程序SparkPi spark-submit --class org.apache.spark.examples.SparkPi --master spark://master:7077 examples/jars/spark…

路径规划算法:基于蛇优化优化的路径规划算法- 附代码

路径规划算法&#xff1a;基于蛇优化优化的路径规划算法- 附代码 文章目录 路径规划算法&#xff1a;基于蛇优化优化的路径规划算法- 附代码1.算法原理1.1 环境设定1.2 约束条件1.3 适应度函数 2.算法结果3.MATLAB代码4.参考文献 摘要&#xff1a;本文主要介绍利用智能优化算法…

嵌入式软件测试笔记10 | 嵌入式软件测试中如何进行安全性分析?

10 | 嵌入式软件测试中如何进行安全性分析&#xff1f; 1 简介2 故障模型及后果分析&#xff08;FMEA&#xff09;2.1 三个步骤2.2 带来的结果优势2.3 FMEA分析过程2.3.1 描述系统及其功能2.3.2 识别潜在的故障模式2.3.3 故障模式对功能的影响2.3.4 风险导致后果的原因2.3.5 风…

Prompt本质解密及Evaluation实战与源码解析(三)

9.5 Evaluation for QA源码解析 如图9-4所示,我们看一下LangChain框架对问答评估的(Evaluation for QA)的源代码。 图9- 5 LangChain的evaluation qa目录 在eval_prompt.py文件里面,主要定义了三个类 PromptTemplate,它们都是用于生成题目的模板。 Gavin大咖微信:NLP_Mat…

跨端技术栈综合考察:深入剖析 UniApp、Flutter、Taro 和 React Native 的优势与限制

文章目录 &#x1f4c8;UniApp⚡概念⚡优势⚡限制 &#x1f4c8;Flutter⚡概念⚡优势⚡限制 &#x1f4c8;Taro⚡概念⚡优势⚡限制 &#x1f4c8;React Native⚡概念⚡优势⚡限制 &#x1f4c8;跨端技术栈对比附录&#xff1a;「简历必备」前后端实战项目&#xff08;推荐&…

强化学习快速复习笔记--待更新

目录 蒙特卡洛方法动态规划算法策略迭代 时序差分方法Sarsa算法Q-learning算法如何区分在线学习和离线学习DQN深度强化Q学习概念介绍代码解析 DQN改进算法Double DQN网络 蒙特卡洛方法 求解价值函数和状态价值函数&#xff0c;可以使用蒙特卡洛方法和动态规划。首先介绍一下蒙…

25-分布式事务----Seate

1、seate 官网:Seata Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务。Seata 将为用户提供了 AT、TCC、SAGA 和 XA 事务模式,为用户打造一站式的分布式解决方案。 1.1、Seata术语 TC (Transaction Coordinator) - 事务协调者…

mysql 执行sql开启事务

SHOW VARIABLES LIKE autocommit;SET autocommit 0; INSERT INTO sugar.realmauctiondatum(Id, Name) VALUES (3, A); INSERT INTO sugar.realmauctiondatum(Id, Name) VALUES (1, A); COMMIT;如果没有调用COMMIT;退出session时会执行回滚

python 面向对象之继承

文章目录 前言继承的概念单继承多继承子类重写父类的同名方法和属性子类调用父类同名的方法和属性多层继承私有权限 前言 前面我们已经学习了 python 面向对象的类和对象&#xff0c;那么今天我将为大家分享面向对象的三大特性之一&#xff1a;继承。 继承具有以下特性&#…

怎么使用文件高速传输,推荐镭速高速文件传输解决方案

​​随着互联网的发展&#xff0c;文件传输越来越频繁&#xff0c;如何实现文件高速传输已经越来越成为企业发展过程中需要解决的问题&#xff0c;在当今的业务中&#xff0c;随着与客户和供应商以及内部系统的所有通信的数据量不断增加&#xff0c;对 高速文件传输解决方案的需…

全网最新项目:会说话的汤姆猫直播搭建教程(附教学流程)

今天为大家分享一个 汤姆猫直播搭建项目 &#xff0c;这个项目最近可以说在圈内爆火&#xff0c;我相信很多朋友以前应该都玩过&#xff0c;或者说给自己家小孩子玩过。 -------------------------------------------------------------------- 课程获取:www.yn521.cn/160852…

RabbitMQ【笔记整理+代码案例】

1. 消息队列 1.1. MQ 的相关概念 1.1.1. 什么是 MQ MQ(message queue)&#xff0c;从字面意思上看&#xff0c;本质是个队列&#xff0c;FIFO 先入先出&#xff0c;只不过队列中存放的内容是message 而已&#xff0c;还是一种跨进程的通信机制&#xff0c;用于上下游传递消息…

Python应用:什么是爬虫?

文章目录 什么是爬虫虫之初&#xff0c;性本善&#xff1f;出行社交电商搜索引擎政府部门总结 面向监狱编程爬虫的君子协议什么是君子协议君子协议是怎么产生的&#xff1f;君子协议是什么内容&#xff1f;如何查看一个网站的robots协议违反君子协议的案例 参考文献 2022年初的…

装饰器模式:灵活扩展功能的设计利器

装饰器模式是一种结构型设计模式&#xff0c;它允许我们在不改变现有对象结构的情况下&#xff0c;动态地将新功能附加到对象上。本文将深入探讨装饰器模式的原理、结构和使用方法&#xff0c;并通过详细的 Java 示例代码来说明。 1. 装饰器模式的定义 装饰器模式是一种允许我…