Pygame框架实现飞机大战

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

飞机大战主游戏类

"""
项目名称:简单飞机大战游戏
基于框架:Pygame
开发日期:2020.07
开发人员:Y
版本:****
"""

import sys # 导入内置模块sys 调用sys.exit()
import pygame # 导入第三方模块pygame
from plane_sprites import * # 导入自定义模块内所有工具

class PlayGame(object): # 定义开始游戏主类 继承object基类
 def __init__(self): # 定义初始化方法
 self.srceen = pygame.display.set_mode(SRCEEN_SIZE.size) # 设置游戏主窗口
 self.clock = pygame.time.Clock() # 设置游戏时钟 用于刷新屏幕帧率
 self.__creat_sprites() # 调用私有方法实现添加精灵类内容
 pygame.display.set_caption('飞机大战') # 设置窗口标题
 pygame.time.set_timer(CREAT_ENEMY_EVENT, 1000) # 设置事件定时器 用于每隔一段时间执行一次事件
 pygame.time.set_timer(FIRE_BULLTE, 300) # 设置事件定时器 用于每隔一段时间执行一次事件

 def start_game(self): # 定义开始游戏方法
 while True: # 游戏循环
  self.clock.tick(CLOCK_TICK) # 利用时钟设置刷新帧率
  self.__event_hander() # 调用私有方法实现监听事件
  self.__check_collide() # 调用私有方法检测碰撞
  self.__update_sprites() # 调用私有方法更新和绘制精灵组
  pygame.display.flip() # 更新窗口显示
  # pygame.display.update() # 更新窗口显示

 def __creat_sprites(self): # 定义添加精灵组方法
 bj1 = Background() # 利用背景类创建背景对象1 默认参数Flase 表示第一张图像,需要与屏幕重合
 bj2 = Background(True) # 利用背景类创建背景对象2 参数True 表示另一张图像, 在屏幕的正上方
 self.bj_group = pygame.sprite.Group(bj1, bj2) # 设置背景精灵组
 self.emeny_group = pygame.sprite.Group() # 提前设置敌机精灵组 但并不设置敌机对象
 # 敌机类对象是定时被创建的,因此在初始化方法中,不需要创建敌机对象
 self.hero = Hero() # 利用英雄类创建英雄对象 注意:后续对英雄做碰撞检测及发射操作,所有需要单独设置为属性
 self.hero_group = pygame.sprite.Group(self.hero) # 设置英雄精灵组

 def __event_hander(self): # 定义监听事件方法
 for event in pygame.event.get(): # 循环监听所有事件
  if event.type == pygame.QUIT: # 如果是单击退出按钮事件
  PlayGame.__game_over() # 调用私有方法实现结束游戏
  elif event.type == CREAT_ENEMY_EVENT: # 如果是执行自定义事件创建敌机
  emeny1 = Enemy("./images/enemy1.png") # 利用敌机类创建敌机1
  emeny2 = Enemy("./images/enemy2.png") # 利用敌机类创建敌机2
  emeny3 = Enemy("./images/enemy3_n1.png")
  self.emeny_group.add(emeny1, emeny2, emeny3) # 对之前设置好的敌机精灵组进行添加精灵对象
  elif event.type == FIRE_BULLTE: # 如果是执行自定义事件发射子弹
  self.hero.fire() # 调用英雄对象的发射子弹方法
 key_tuple = pygame.key.get_pressed() # 捕获键盘按键返回值为元组
 if key_tuple[pygame.K_RIGHT]: # 判断捕获键盘按键为右键
  self.hero.speed = 4 # 设置英雄类对象的速度为4 向右移动
 elif key_tuple[pygame.K_LEFT]: # 判断捕获键盘按键为左键
  self.hero.speed = -4 # 设置英雄类对象的速度为-4 向左移动
 else:   # 否则
  self.hero.speed = 0 # 捕获其余任何按键英雄类对象速度不变 不移动

 def __check_collide(self): # 定义检测碰撞方法
 pygame.sprite.groupcollide(self.hero.bullet_group, self.emeny_group, True, True)
 # 两个精灵组中所有的精灵的碰撞检测 属性True, 则发生碰撞的精灵将被自动移除
 enemies = pygame.sprite.spritecollide(self.hero, self.emeny_group, True)
 # 判断某个精灵和指定精灵组中的精灵的碰撞 属性True,则指定精灵组中发生碰撞的精灵将被自动移除
 # 返回精灵组中跟精灵发生碰撞的精灵列表
 if len(enemies) > 0: # 判断敌机精灵组内精灵是否存在 若存在
  self.hero.kill() # 碰撞导致英雄销毁
  PlayGame.game_over() # 调用类中结束游戏方法 退出游戏

 def __update_sprites(self): # 定义精灵组更新和绘制方法
 self.bj_group.update() # 更新背景类精灵
 self.bj_group.draw(self.srceen) # 绘制背景类精灵
 self.emeny_group.update() # 更新敌机类精灵
 self.emeny_group.draw(self.srceen) # 绘制敌机类精灵
 self.hero_group.update() # 更新英雄类精灵
 self.hero_group.draw(self.srceen) # 绘制英雄类精灵
 self.hero.bullet_group.update() # 更新英雄子弹类精灵
 self.hero.bullet_group.draw(self.srceen) # 绘制英雄子弹类精灵

 @staticmethod # 声明定义静态方法
 def __game_over(): # 定义静态方法
 print("游戏结束") # 控制台打印游戏结束
 pygame.quit() # 卸载所有pygame模块工具
 sys.exit() # 退出程序

if __name__ == '__main__': # 判断当前执行
 playgame = PlayGame() # 创建开始游戏对象
 playgame.start_game() # 调用开始游戏对象的开始方法

游戏工具类

"""
项目名称:简单飞机大战游戏
基于框架:Pygame
开发日期:2020.07
开发人员:Y
版本:****
"""

import random # 导入内置模块 random 调用randint方法
import pygame # 导入第三方模块pygame

SRCEEN_SIZE = pygame.Rect(0, 0, 480, 700) # 利用Rect方法定义窗口大小常量
CLOCK_TICK = 60 # 定义时钟帧率常量
CREAT_ENEMY_EVENT = pygame.USEREVENT # 自定义创建敌机事件
FIRE_BULLTE = pygame.USEREVENT + 1 # 自定义发射子弹事件

class GameSprites(pygame.sprite.Sprite): # 定义游戏精灵类 继承pygame.sprite.Sprite
 def __init__(self, image_name, speed=1): # 定义初始化方法
 super().__init__() # 因未继承object基类 定义初始化方法需要先super()下父类的 __init_方法
 self.image = pygame.image.load(image_name) # 定义实例属性image为加载图片至内存中
 self.rect = self.image.get_rect() # 定义实例属性rect为获取图片的矩形区域(0, 0, image.width, image.height)
 self.speed = speed # 定义实例属性speed为运动速度 实质为移动的幅度,幅度大则速度快

 def update(self): # 定义更新数据方法实现移动image
 self.rect.y += self.speed # 移动image的Y轴距离为向下speed距离

class Background(GameSprites): # 定义背景精灵类 继承游戏精灵类
 def __init__(self, is_alt=False): # 在父类(游戏精灵类)基础上定义初始化方法 is_alt缺省参数用于判断是否为第二张image
 super().__init__("./images/background.png")
 # 因未继承object基类 定义初始化方法需要先super()下父类的 __init_方法 并以背景图为image为参数
 if is_alt: # 判断是否为第二张image 如果是
  self.rect.y = -self.rect.height
  # 将第二张image的Y轴坐标设置为本身image.height的负值 用来实现将第二张image置于第一张image上方

 def update(self): # 在父类(游戏精灵类)基础上修改 更新数据方法实现移动background_image
 super().update() # 继承父类(游戏精灵类)的移动方式 按照speed向下移动
 if self.rect.y >= SRCEEN_SIZE.height:
  # 判断background_image在Y轴距离是否大于等于窗口高度 如果是
  # 表示第一张image全部下滑出窗口
  self.rect.y = -self.rect.height # 需要重新将该image置于第二张image上方

class Enemy(GameSprites): # 定义敌机精灵类 继承游戏精灵类
 def __init__(self, image): # 在父类(游戏精灵类)基础上修改定义初始化方法 自定义参数image用于实现多种形式敌机
 super().__init__(image)
 # 因未继承object基类 定义初始化方法需要先super()下父类的 __init_方法 并以自定义背景图为image为参数
 self.speed = random.randint(1, 5) # 修改敌机类image移动幅度(速度)为1--5随机值
 self.rect.bottom = 0 # 定义敌机类image的底部为0 表示每次从窗口最顶部驶入 美化效果
 MAX_WIDTH = SRCEEN_SIZE.width - self.rect.width
 # 定义常量为敌机对象出现时的image.x最大值 防止跑出窗口界面或只有敌机部分驶入窗口
 # 最大宽度 = 窗口宽度 - 敌机image的宽度
 self.rect.x = random.randint(0, MAX_WIDTH)
 # 设置敌机image的出现范围为限制在窗口内

 def update(self): # 在父类(游戏精灵类)基础上修改 更新数据方法实现移动emeny_image
 super().update() # 继承父类(游戏精灵类)的移动方式 按照speed向下移动
 if self.rect.y >= SRCEEN_SIZE.height: # 判断敌机对象的Y轴距离是否超过窗口高度 如果是 表示敌机对象驶出窗口
  # print("敌机销毁")
  self.kill() # 敌机对象驶出窗口后进行销毁 从内存中释放敌机image 减轻计算机内存压力

 def __del__(self): # 定义敌机对象销毁前的动作,如爆炸动画,碰撞音频等等
 pass # pass语句占位 待开发。。

class Hero(GameSprites): # 定义英雄精灵类 继承游戏精灵类
 def __init__(self): # 在父类(游戏精灵类)基础上修改定义初始化方法 实现英雄类image初始位置以及移动限制
 super().__init__("./images/me1.png", 0)
 # 因未继承object基类 定义初始化方法需要先super()下父类的 __init_方法 并以自定义英雄类image
 self.rect.centerx = SRCEEN_SIZE.centerx # 限制英雄类对象只可以在X轴(水平方向)移动
 self.rect.bottom = SRCEEN_SIZE.bottom - 120 # 设置英雄类对象出现时底部位置为窗口底部上120px
 self.bullet_group = pygame.sprite.Group() # 注意:内置子弹类精灵组为英雄类实例属性 提前设置子弹精灵组

 def update(self, *args): # 注意:此方法不是在父类(游戏精灵类)基础上修改 更新数据方法实现移动hero_image
 # 因为英雄类对象不需要从上向下移动,无需继承父类(游戏精灵类)的update方法
 self.rect.x += self.speed # 设置移动实例属性 在X轴水平方向以speed速度(幅度)移动
 if self.rect.x < 0: # 判断英雄类实例在X轴坐标是否小于0 即是否移出窗口左侧 如果是
  self.rect.x = 0 # 重置(限制)英雄实例在X轴方向坐标为0 即窗口最左侧
 elif self.rect.right > SRCEEN_SIZE.right: # 判断英雄类实例在X轴坐标是否大于窗口最右侧 即是否移除窗口右侧 如果是
  self.rect.right = SRCEEN_SIZE.right # 重置(限制)英雄实例在X轴方向坐标为窗口最右侧 即窗口最右侧

 def fire(self): # 英雄类精灵实例定义发射子弹方法
 print("发射子弹。。。") # 控制台打印发射子弹。。。字样
 for i in (0, 1, 2): # for计次循环用于实现子弹连发
  bullte = Bullet() # 利用子弹精灵类创建子弹实例
  bullte.rect.bottom = self.rect.y - i * 20 # 设置子弹初始位置的最底部为英雄类对象Y轴方向的上方 i*20 px的距离
  bullte.rect.centerx = self.rect.centerx # 限制子弹类对象位置始终为英雄类对象的X轴中间
  self.bullet_group.add(bullte) # 对之前设置好的子弹精灵组进行添加精灵对象

class Bullet(GameSprites): # 定义子弹精灵类 继承游戏精灵类
 def __init__(self): # 在父类(游戏精灵类)基础上修改定义初始化方法 实现子弹类image以及speed为-x 即向上移动speed
 super().__init__("./images/bullet1.png", -2)

 def update(self, *args): # 在父类(游戏精灵类)基础上 更新数据方法实现移动bullet_image
 super().update() # 继承父类(游戏精灵类)的移动方式 按照speed向上移动
 if self.rect.bottom < 0: # 判断子弹对象的Y轴距离是否超过窗口高度 如果是 表示子弹对象驶出窗口
  self.kill() # 子弹对象驶出窗口后进行销毁 从内存中释放子弹image 减轻计算机内存压力

游戏截图

更多有趣的经典小游戏实现专题,分享给大家:

C++经典小游戏汇总

python经典小游戏汇总

python俄罗斯方块游戏集合

JavaScript经典游戏 玩不停

java经典小游戏汇总

javascript经典小游戏汇总

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

(0)

相关推荐

  • python飞机大战pygame游戏背景设计详解

    本文实例讲述了python飞机大战pygame游戏背景设计.分享给大家供大家参考,具体如下: 目标 背景交替滚动的思路确定 显示游戏背景 01. 背景交替滚动的思路确定 运行 备课代码,观察 背景图像的显示效果: 游戏启动后,背景图像 会 连续不断地 向下方 移动 在 视觉上 产生英雄的飞机不断向上方飞行的 错觉 -- 在很多跑酷类游戏中常用的套路 游戏的背景 不断变化 游戏的主角 位置保持不变 1.1 实现思路分析 解决办法 创建两张背景图像精灵 第 1 张 完全和屏幕重合 第 2 张在 屏幕

  • python飞机大战 pygame游戏创建快速入门详解

    本文实例讲述了python飞机大战 pygame游戏创建.分享给大家供大家参考,具体如下: 目标 项目准备 使用 pygame 创建图形窗口 理解 图像 并实现图像绘制 理解 游戏循环 和 游戏时钟 理解 精灵 和 精灵组 项目准备 新建 飞机大战 项目 新建一个 hm_01_pygame入门.py 导入 游戏素材图片 游戏的第一印象 把一些 静止的图像 绘制到 游戏窗口 中 根据 用户的交互 或其他情况,移动 这些图像,产生动画效果 根据 图像之间 是否发生重叠,判断 敌机是否被摧毁 等其他情

  • pygame实现简易飞机大战

    利用pygame实现了简易版飞机大战.源代码如下: # -*- coding:utf-8 -*- import pygame import sys from pygame.locals import * from pygame.font import * import time import random class Hero(object): #玩家 英雄类 def __init__(self, screen_temp): self.x = 210 self.y = 700 self.life

  • python飞机大战pygame游戏框架搭建操作详解

    本文实例讲述了python飞机大战pygame游戏框架搭建操作.分享给大家供大家参考,具体如下: 目标 明确主程序职责 实现主程序类 准备游戏精灵组 01. 明确主程序职责 回顾 快速入门案例,一个游戏主程序的 职责 可以分为两个部分: 游戏初始化 游戏循环 根据明确的职责,设计 PlaneGame 类如下: 提示 根据 职责 封装私有方法,可以避免某一个方法的代码写得太过冗长 如果某一个方法编写的太长,既不好阅读,也不好维护! 游戏初始化 -- init() 会调用以下方法: 游戏循环 --

  • python pygame模块编写飞机大战

    本文实例为大家分享了python pygame模块编写飞机大战的具体代码,供大家参考,具体内容如下 该程序没有使用精灵组,而是用列表存储对象来替代精灵组的动画效果.用矩形对象的重叠来判断相撞事件.该程序可以流畅运行,注释较为详细,希望可以帮助大家. import pygame from pygame.locals import * from sys import exit import time import random # 创建子弹类,把子弹的图片转化为图像对象,设定固定的移动速度 clas

  • pygame实现飞机大战

    本文实例为大家分享了pygame实现飞机大战的具体代码,供大家参考,具体内容如下 运行效果图: import pygame import random import time import os from os import path WIDTH = 480 HEIGHT = 600 FPS = 60#每秒显示多少帧 POWERUP_TIME = 5000 COLOR = (255,174,200) WHITE = (255,255,255) BLACK = (0,0,0) GREEN = (0

  • python飞机大战pygame碰撞检测实现方法分析

    本文实例讲述了python飞机大战pygame碰撞检测实现方法.分享给大家供大家参考,具体如下: 目标 了解碰撞检测方法 碰撞实现 01. 了解碰撞检测方法 pygame 提供了 两个非常方便 的方法可以实现碰撞检测: pygame.sprite.groupcollide() 两个精灵组 中 所有的精灵 的碰撞检测 groupcollide(group1, group2, dokill1, dokill2, collided = None) -> Sprite_dict 如果将 dokill 设

  • python实现飞机大战游戏(pygame版)

    简介 使用python实现pygame版的飞机大战游戏: 环境:Windows系统+python3.8.0 游戏规则: 1.点击"PLAY"或者按键"P"开始游戏: 2.敌机根据设置频率从顶部随机位置生成,生成后向下移动: 3.飞船在底部中间生成,玩家使用上下左右键控制飞船移动,敲击空格键发射子弹: 4.子弹打到敌机,该敌机产生爆炸效果并累计分数到右上角: 5.消灭10只飞机后,等级升高,敌机生成频率变快,下落速度也变快: 6.当三条命都消失了,游戏结束. 游戏运行

  • 用Python写飞机大战游戏之pygame入门(4):获取鼠标的位置及运动

    目标是拷贝微信的飞机大战,当然拷贝完以后大家就具备自己添加不同内容的能力了. 首先是要拿到一些图片素材,熟悉使用图像处理软件和绘画的人可以自己制作,并没有这项技能的同学只能和我一样从网上下载相应的素材了. 网上可以找到相应的这样的图片,注意,所有的元件图片要是png类型的图片,那样可以有透明的背景,否则会有白色的边框露出来. 找到素材以后我们就要开始搭建我们的飞机大战了. 微信上的飞机大战是由手指控制的,在电脑上,我们就先用鼠标代替了. 按照之前我们在天空上移动云的那个程序,我们可以知道该怎么做

  • python飞机大战pygame游戏之敌机出场实现方法详解

    本文实例讲述了python飞机大战pygame游戏之敌机出场实现方法.分享给大家供大家参考,具体如下: 目标 使用 定时器 添加敌机 设计 Enemy 类 01. 使用定时器添加敌机 运行 备课代码,观察 敌机的 出现规律: 游戏启动后,每隔 1 秒 会 出现一架敌机 每架敌机 向屏幕下方飞行,飞行 速度各不相同 每架敌机出现的 水平位置 也不尽相同 当敌机 从屏幕下方飞出,不会再飞回到屏幕中 1.1 定时器 在 pygame 中可以使用 pygame.time.set_timer() 来添加

随机推荐