本文实例为大家分享了python实现简单的飞机大战的具体代码,供大家参考,具体内容如下

制作初衷

这几天闲来没事干,就想起来好长时间没做过游戏了,于是就想做一个游戏练练手,为了起到一个练习的目的就使用了自己不是太熟练的python这门语言来编写,代码都有备注,大家可以直接看代码,这个代码我是在python3.1的环境下写的,大家需要可以直接下载我这里的资源,图片和代码打包到了一起的,因为是第一次使用python做游戏,有什么不足的地方望大佬斧正。

游戏思路

首先我们分析飞机大战这个游戏属于一个平面的2d游戏,那这个游戏的所有都是建立在x,y的基础上进行的运算,为了加快我们的开发工作,秉承时间就是金钱的原则,我们采用的是python 的 pygame第三方库来实现的。
言归正传!!!

背景

仔细分析飞机大战我们不难发现,这个游戏的背景实际上就是一张图片一直循环滚动所造成的一种视觉上的效果,那布满我们一个场景并且让他无缝连接实际上我们只需要两张图片滚动,然后当第二张图片滚动完,再让他从第一张图片开始滚动如此循环便可以给用户视觉上一种无缝滚动的效果。

飞机

我们分析飞机的行为可以发现,不管是我方的飞机还是敌人的飞机都是有几种他们共有的动作。

1,运动,敌我双方都是在一直的运动。
2,发射子弹,双方都是在发射子弹,但具体的数量和速度我们可以通过类的属性来进行修改。
3,死亡,敌人和我们自身都会死亡,死亡会触发一个爆炸的动画,敌人死亡加分,我方死亡游戏结束。

子弹

为了节省时间此处的子弹都只会走直线,封装到自己的类方法里面,后期可以修改轨迹。

话不多说,直接上代码,每个重要的代码都是有注释。大家可以自己观看。

main.py

# -*- coding: UTF-8 -*-
# animation.py

# 导入需要的模块
import pygame, sys
from pygame.locals import *
import airplane
import random
class Game:
  def __init__(self):
    # 初始化pygame
    pygame.init()
    #初始化字体文件
    pygame.font.init()
    #初始化游戏分数
    self.mark=0
    # 设置帧率(屏幕每秒刷新的次数)
    self.FPS = 60

    # 获得pygame的时钟
    self.fpsClock = pygame.time.Clock()

    # 设置窗口大小
    self.screen = pygame.display.set_mode((500, 800), 0, 32)

    # 设置标题
    pygame.display.set_caption('飞机大战')

    # 定义颜色
    self.WHITE = (255, 255, 255)
    #用于存放爆炸图片
    self.boom=[pygame.image.load("boom_1.gif")
      ,pygame.image.load("boom_2.gif")
      ,pygame.image.load("boom_3.gif")
      ,pygame.image.load("boom_4.gif")
      ,pygame.image.load("boom_5.gif")
      ,pygame.image.load("boom_6.gif")
      , pygame.image.load("boom_7.gif")
      , pygame.image.load("boom_8.gif")
      , pygame.image.load("boom_9.gif")]
    # 加载一张背景图片
    self.img = pygame.image.load('bg.jpg')
    #加载开始游戏按钮
    self.startGameImage=pygame.image.load('start.png')

    # 初始化背景图片的位置
    self.imgx = 0
    self.imgy = 0
    # 全局的时间变量
    self.time = 0;
    #敌人子弹的图片数据
    self.allEnemyButtlueImg=[pygame.image.load('buttle3.png')]
    # 存放所有敌人图片数据的一个列表
    self.allEnemyImg = [pygame.image.load('em1.png'), pygame.image.load('em2.png')]
    # 存放所有敌人变量的一个列表
    self.allEnemy = [];
    #是否开始了游戏 开始游戏状态为0 死亡状态为1 为开始为2
    self.isStart=2
    #最后一个爆炸动画
    self.lastTime=0
    #开始执行动画
    self.run()
  def initGame(self):
    # 创建一个自己角色
    self.myself = airplane.airplane(self.screen, 30, pygame.image.load('airplane.png'), 250, 800,
                                    pygame.image.load('buttle.png'),
                                    0, 120, 79, self.boom)
    self.isStart=0
  def run(self):
    # 程序主循环
    while True:

      # 每次都要重新绘制背景白色
      self.screen.fill(self.WHITE)

      # 背景的循环滚动
      self.imgy  = 2
      if self.imgy == 854:
        self.imgy = 0
      # 背景的绘制,绘制两张图片实现循环滚动的效果
      self.screen.blit(self.img, (self.imgx, self.imgy))
      self.screen.blit(self.img, (self.imgx, self.imgy - 854))
      #如果游戏isstart为flase则游戏不会继续刷新
      if self.isStart==0:
        self.startGame();
      elif self.isStart == 1:
        self.clearAll();
      else:
        self.showstartGame()
      for event in pygame.event.get():
        if event.type == QUIT:
          pygame.quit()
          sys.exit()
        if event.type==MOUSEBUTTONDOWN:
          x, y = pygame.mouse.get_pos()
          if(x>170 and x<170 161and y>300 and y<300 43):
            self.isStart=0
            self.initGame();


      # 刷新屏幕
      pygame.display.update()

      # 设置pygame时钟的间隔时间
      self.fpsClock.tick(self.FPS)
  def showMark(self):
    a = pygame.font.SysFont('幼圆', 50)
    text = a.render(str(self.mark),True,(255,0,0))
    b=len(str(self.mark))
    self.screen.blit(text, [500-b*30,10])
  def showstartGame(self):
    self.screen.blit(self.startGameImage,(170,300))
  def addMark(self,m):
    self.mark =m;
  def clearMark(self):
    self.mark=0;
  def startGame(self):
    # 获取鼠标位置点
    x, y = pygame.mouse.get_pos()
    # 飞机的运行函数
    self.myself.run(x, y);
    # 所有子弹每一帧的位置
    for item in self.myself.allbullet:
      if item.y <= 0:
        # 当子弹行驶出地图边界之后移除列表中的当前元素并且销毁对象
        self.myself.allbullet.remove(item)
        del item
      else:
        # 如果没有行驶出边界范围则继续行驶
        item.advance()
        for enemy in self.allEnemy:
          try:
            # 判断我方子弹是否与敌人相撞,并且相撞的时候敌人还活着
            if (
                    item.x > enemy.x and item.x < enemy.x   enemy.width and item.y >= enemy.y and item.y < enemy.y   enemy.height and enemy.isDeath == 0):
              self.myself.allbullet.remove(item)
              del item
              enemy.death()
              self.addMark(enemy.myselfMark)
          except:
            continue;
    self.showMark()
    # 发射子弹的函数具体的射速由对象内部决定
    self.myself.attack();
    # 外部计算时间的一个变量没time % FPS == 0 时为1秒钟
    self.time  = 1
    if self.time==self.lastTime:
      self.isStart=1
    # 飞机随机生成时间
    if self.time % (self.FPS * 2) == 0:
      # 每过一秒钟新生成一架飞机,添加到allEnemy这个列表之中,y从0开始 x在窗口大小随机生成
      self.allEnemy.append(
        airplane.airplane(self.screen, 15, self.allEnemyImg[random.randint(0, 1)], random.randint(0, 500 - 179), -134,
                          self.allEnemyButtlueImg[0], 1, 179, 134, self.boom))
    # 循环执行该列表,敌人飞机的运动轨迹
    for item in self.allEnemy:
      # 飞机超出下边界后去除
      if item.y > 800   item.height:
        self.allEnemy.remove(item)
        del item
      # 飞机死亡并且存在子弹数为0后去除
      elif item.isDeath == 1 and len(item.allbullet) == 0:
        self.allEnemy.remove(item)
        del item
      # 否则飞机继续运行
      else:
        item.ai()
        item.attack()
        for i in item.allbullet:
          if i.y <= -96 or i.y >= 896:
            # 当子弹行驶出地图边界之后移除列表中的当前元素并且销毁对象
            item.allbullet.remove(i)
            del i
          else:
            # 如果没有行驶出边界范围则继续行驶
            if (
                    i.x > self.myself.x and i.x < self.myself.x   self.myself.width and i.y >= self.myself.y and i.y < self.myself.y   self.myself.height and self.myself.isDeath == 0):
              self.myself.death()
              self.lastTime=self.time 50;
            i.advance()

  def clearAll(self):
    self.mark=0
    for i in self.allEnemy:
      for j in i.allbullet:
        del j;
      del i;
    for j in self.myself.allbullet:
      del j
    del self.myself
    # 存放所有敌人变量的一个列表
    self.allEnemy = [];
    # 是否开始了游戏
    self.isStart = 2
    self.lastTime=0


game=Game()

airplane.py

#飞机子弹的图片路径
        self.bullet=bullet;
        #飞机的类型,0代表自己,1代表敌人
        self.type=type;
        #飞机的宽度
        self.width=w;
        #飞机的高度
        self.height=h;
        #存放子弹的数组
        self.allbullet=[];
        #用于判断子弹多长时间发射一次和fps相关
        self.time=0;
        #当前这个飞机的速度
        self.speedx=1;
        self.speedy=1;
        # 攻击速度,值越小攻击越快最小为1
        self.advancespeed = advancespeed;
        #每个飞机自己携带的分数,目前随机
        self.myselfMark=random.randint(1,3)
        #运动轨迹
        self.runType=random.randint(0, 3)
        #是否死亡 1表示死亡 0表示活着
        self.isDeath=0
        #爆炸图片播放那一张
        self.showboomTime=0
        #爆炸数据
        self.boom=boom
        #开始攻击
        self.attack();
    def death(self):
        #死亡状态
        self.isDeath=1;
    def showboom(self):
        #显示boom的动画
        if self.showboomTime==len(self.boom)-1:
            return ;
        if self.time%5==0:
            self.showboomTime =1;
        self.screen.blit(self.boom[self.showboomTime], (self.x, self.y))
    def run(self,x,y):
        if self.isDeath==1:
            self.showboom();
            return 1;
        self.x = x - self.width / 2;
        self.y = y - self.height / 2;
        self.screen.blit(self.img, (self.x, self.y))
    def attack(self):
        #飞机发射子弹的函数
        if self.time%self.advancespeed==0 and self.isDeath==0:
            self.allbullet.append(bullet(self.screen,self.bullet,self.x-self.width/2,self.y,self.width,self.height,128,128,self.type))
        self.time =1
    def ai(self):
        if self.isDeath==1:
            self.showboom();
            return
        #这里分为四种的运动轨迹随机决定
        if self.type==1:
            if self.runType==0:
                self.y =self.speedy*2;
            elif self.runType==1:
                self.y =self.speedy;
                if self.x<=0-self.width/2 or self.x>=500-self.width/2:
                    self.speedx=0-self.speedx
                self.x =self.speedx
            elif self.runType==2:
                self.y  = self.speedy;
                if self.x<=0-self.width/2 or self.x>=500-self.width/2:
                    self.speedx = 0 - self.speedx
                self.x -= self.speedx
            elif self.runType==3:
                self.y  = self.speedy;
                if self.x<=0-self.width/2 or self.x>=500-self.width/2:
                    self.speedx = 0 - self.speedx
                    self.speedy=0-self.speedy
                self.x -= self.speedx
            self.screen.blit(self.img, (self.x, self.y))
            self.attack()
    def __del__(self):
        return

class bullet:
    def __init__(self,screen,img,x,y,airplanex,airplaney,w,h,type):
        #游戏场景传参
        self.screen=screen;
        #子弹的图片的路径
        self.img=img;
        if type==0:
            # 子弹的y坐标
            self.y=y-airplaney;
            # 子弹的x坐标
            self.x = x   airplanex / 2;
        else:
            self.y=y airplaney-20;
            self.x = x airplanex/2 w/2-12;
        #子弹图片的宽度
        self.width=w
        #子弹图片的高度
        self.height=h
        #子弹需要一直往前飞
        self.run()
        #子子弹是谁的
        self.type = type
        if self.type==0:
            self.speed=5
        else:
            self.speed=3
    def advance(self):
        if self.type==0:
            self.y-=self.speed;
        else:
            self.y =self.speed;
        self.run();

    def run(self):
        self.screen.blit(self.img, (self.x, self.y))
    def __del__(self):
        return

给大家看看游戏运行的效果

一个简单的开始按钮,死亡后又返回这个界面

上方有一个简洁明了的计分板,游戏结束归零

敌人有四种运动,随机产生!!!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持Devmax。

python实现简单的飞机大战的更多相关文章

  1. XCode 3.2 Ruby和Python模板

    在xcode3.2下,我的ObjectiveCPython/Ruby项目仍然可以打开更新和编译,但是你无法创建新项目.鉴于xcode3.2中缺少ruby和python的所有痕迹(即创建项目并添加新的ruby/python文件),是否有一种简单的方法可以再次安装模板?我发现了一些关于将它们复制到某个文件夹的信息,但我似乎无法让它工作,我怀疑文件夹的位置已经改变为3.2.解决方法3.2中的应用程序模板

  2. Swift基本使用-函数和闭包(三)

    声明函数和其他脚本语言有相似的地方,比较明显的地方是声明函数的关键字swift也出现了Python中的组元,可以通过一个组元返回多个值。传递可变参数,函数以数组的形式获取参数swift中函数可以嵌套,被嵌套的函数可以访问外部函数的变量。可以通过函数的潜逃来重构过长或者太复杂的函数。

  3. Swift coreAnimation 加计时器写的游戏《飞机大战》

    最近在学习swift的动画和图层,就用现学的东西写了个游戏,基本思想基本功能都实现了,图片都是在网上找得。希望能帮助大家更好的理解动画和图层、声明下,我是初学者,代码写的不好。大家应该都能看懂。游戏所有代码都是swift加动画加计时器,没有用任何游戏引擎框架。效果图源代码地址:点击打开链接地址失效了的话我可以补上

  4. 10 个Python中Pip的使用技巧分享

    众所周知,pip 可以安装、更新、卸载 Python 的第三方库,非常方便。本文小编为大家总结了Python中Pip的使用技巧,需要的可以参考一下

  5. Swift、Go、Julia与R能否挑战 Python 的王者地位

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  6. 红薯因 Swift 重写开源中国失败,貌似欲改用 Python

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  7. 你没看错:Swift可以直接调用Python函数库

    上周Perfect又推出了新一轮服务器端Swift增强函数库:Perfect-Python。对,你没看错,在服务器端Swift其实可以轻松从其他语种的函数库中直接拿来调用,不需要修改任何内容。以如下python脚本为例:Perfect-Python可以用下列方法封装并调用以上函数,您所需要注意的仅仅是其函数名称以及参数。

  8. Swift中的列表解析

    在Swift中完成这个的最简单的方法是什么?我在寻找类似的东西:从Swift2.x开始,有一些与你的Python样式列表解析相当的东西。(在这个意义上,它更像是Python的xrange。如果你想保持集合懒惰一路通过,只是这样说:与Python中的列表解析语法不同,Swift中的这些操作遵循与其他操作相同的语法。

  9. swift抛出终端的python错误

    每当我尝试启动与python相关的swift时,我都会收到错误.我该如何解决?

  10. 在Android上用Java嵌入Python

    解决方法看看this,它适用于J2SE,你可以尝试在Android上运行.

随机推荐

  1. 10 个Python中Pip的使用技巧分享

    众所周知,pip 可以安装、更新、卸载 Python 的第三方库,非常方便。本文小编为大家总结了Python中Pip的使用技巧,需要的可以参考一下

  2. python数学建模之三大模型与十大常用算法详情

    这篇文章主要介绍了python数学建模之三大模型与十大常用算法详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感想取得小伙伴可以参考一下

  3. Python爬取奶茶店数据分析哪家最好喝以及性价比

    这篇文章主要介绍了用Python告诉你奶茶哪家最好喝性价比最高,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧

  4. 使用pyinstaller打包.exe文件的详细教程

    PyInstaller是一个跨平台的Python应用打包工具,能够把 Python 脚本及其所在的 Python 解释器打包成可执行文件,下面这篇文章主要给大家介绍了关于使用pyinstaller打包.exe文件的相关资料,需要的朋友可以参考下

  5. 基于Python实现射击小游戏的制作

    这篇文章主要介绍了如何利用Python制作一个自己专属的第一人称射击小游戏,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起动手试一试

  6. Python list append方法之给列表追加元素

    这篇文章主要介绍了Python list append方法如何给列表追加元素,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  7. Pytest+Request+Allure+Jenkins实现接口自动化

    这篇文章介绍了Pytest+Request+Allure+Jenkins实现接口自动化的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  8. 利用python实现简单的情感分析实例教程

    商品评论挖掘、电影推荐、股市预测……情感分析大有用武之地,下面这篇文章主要给大家介绍了关于利用python实现简单的情感分析的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下

  9. 利用Python上传日志并监控告警的方法详解

    这篇文章将详细为大家介绍如何通过阿里云日志服务搭建一套通过Python上传日志、配置日志告警的监控服务,感兴趣的小伙伴可以了解一下

  10. Pycharm中运行程序在Python console中执行,不是直接Run问题

    这篇文章主要介绍了Pycharm中运行程序在Python console中执行,不是直接Run问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

返回
顶部