当前位置: 首页 > news >正文

Pygame中Sprite实现逃亡游戏2

在《Pygame中Sprite实现逃亡游戏1》中实现了奔跑的玩家,接下来实现显示追赶玩家的飞龙以及对面过来的飞火。

1 显示飞龙

显示飞龙的代码如图1所示。

图1 显示飞龙的代码

其中,第93行代码创建了精灵类MySprite的实例dragon;第94行代码导入飞龙图片,第二和三个参数分别表示飞龙帧图片的宽度和高度,第四个参数表示飞龙帧图片有3列;第95行代码指定了飞龙显示的位置;第96行代码将dragon加入到精灵组中。

相关链接1:精灵类load()方法的详细用法请参考《Pygame中Sprite类实现多帧动画3-1》

相关链接2:精灵类的position属性请参考《Pygame中Sprite实现逃亡游戏1》

2 显示飞火

显示飞火的代码如图2所示。

图2 显示飞火的代码

显示飞火的代码与显示飞龙的代码类似。

3 让飞火动起来

在显示了飞火之后,接下来要让飞火能够动起来。

3.1 确定飞火的起始高度

首先要确定飞火的高度,这个高度是随机产生的,通过自定义函数reset_arrow()实现,代码如图3所示。

图3 确定飞火的起始高度的代码

其中,第73行代码随机创建了一个250-350之间的数字,在这个区间内保证飞火能够射中飞龙或者玩家;第74行代码将飞火的position属性设置为(800,y),800是屏幕的宽度,保证了飞火每次是在屏幕最右侧出现。

3.2 改变飞火的横坐标让飞火动起来

在while True循环中改变飞火的横坐标,这样飞火就能够动起来了,代码如图4所示。

图4 改变飞火的横坐标让飞火动起来的代码

其中,第120行代码中的game_over是游戏是否结束的标志,初始值为False;第121行代码改变飞火的横坐标,使其值变小,这样就可以使得飞火向左飞行,每次减少的量为arrow_vel,该变量初始值是8.0;通过arrow.X可以修改arrow的横坐标,在MySprite类中有如图5所示的定义。

图5  MySprite类中关于X定义的代码

在图4第121行修改X实际上就是修改了rect.x,也就是显示精灵的横坐标;图4第122-123行代码表示当飞火向左飞出了屏幕,则调用reset_arrow()在屏幕的右侧重新显示飞火。

相关链接3 通过X修改rect.x的原理,请参考《Pygame中Sprite实现逃亡游戏1》

3.3 飞火速度的控制

在游戏中,需要把飞火的速度控制到玩家可以反应的范围中。可以通过设置刷新率来控制飞火速度,在while True循环中有如图6所示的代码。

图6 控制飞火速度的代码

其中,framerate在while True循环之前定义,代码如图7所示。

图7 定义framerate

从图7中可以看出,framerate是pygame.time模块中Clock类的实例,通过framerate可以将屏幕刷新率控制到每秒30次,如图6所示。

4 代码运行效果

通过添加以上代码,程序运行效果如图8所示。

图8 程序运行效果

5 完整代码

import pygame
import os
import time
import random
from pygame.locals import *class MySprite(pygame.sprite.Sprite):def __init__(self, target):pygame.sprite.Sprite.__init__(self) #extend the base Sprite classself.master_image = Noneself.frame = 0self.old_frame = -1self.frame_width = 1self.frame_height = 1self.first_frame = 0self.last_frame = 0self.columns = 1self.last_time = 0#X propertydef _getx(self):return self.rect.xdef _setx(self,value):self.rect.x = valueX = property(_getx,_setx)#Y propertydef _gety(self):return self.rect.ydef _sety(self,value):self.rect.y = valueY = property(_gety,_sety)#position propertydef _getpos(self):return self.rect.topleftdef _setpos(self,pos):self.rect.topleft = posposition = property(_getpos,_setpos)def load(self, filename, width, height, columns):self.master_image = pygame.image.load(filename).convert_alpha()self.frame_width = widthself.frame_height = heightself.rect = Rect(0,0,width,height)self.columns = columns#try to auto-calculate total framesrect = self.master_image.get_rect()self.last_frame = (rect.width // width) * (rect.height // height) - 1def update(self, current_time, rate=30):#update animation frame numberif current_time > self.last_time + rate:self.frame += 1if self.frame > self.last_frame:self.frame = self.first_frameself.last_time = current_time#build current frame only if it changedif self.frame != self.old_frame:frame_x = (self.frame % self.columns) * self.frame_widthframe_y = (self.frame // self.columns) * self.frame_heightrect = Rect(frame_x, frame_y, self.frame_width, self.frame_height)self.image = self.master_image.subsurface(rect)self.old_frame = self.framedef __str__(self):return str(self.frame) + "," + str(self.first_frame) + \"," + str(self.last_frame) + "," + str(self.frame_width) + \"," + str(self.frame_height) + "," + str(self.columns) + \"," + str(self.rect)def reset_arrow():y = random.randint(250,350)arrow.position = 800,ypygame.init()
screen = pygame.display.set_mode((800,600))
pygame.display.set_caption('Escape The Dragon Game')
font = pygame.font.Font('1.ttf', 18)
framerate = pygame.time.Clock()group = pygame.sprite.Group()
player = MySprite(screen)
player.load('caveman.png', 50, 64, 8)
player.first_frame = 1
player.last_frame = 7
player.position = 400, 303
group.add(player)bg = pygame.image.load('background.png').convert_alpha()#create the dragon sprite
dragon = MySprite(screen)
dragon.load("dragon.png", 260, 150, 3)
dragon.position = 100, 230
group.add(dragon)#create the arrow sprite
arrow = MySprite(screen)
arrow.load("flame.png", 40, 16, 1)
arrow.position = 800,320
group.add(arrow)game_over = False
arrow_vel = 8.0
while True:framerate.tick(30)ticks = pygame.time.get_ticks()for event in pygame.event.get():if event.type == QUIT:pygame.quit()os.sys.exit()keys = pygame.key.get_pressed()if keys[K_ESCAPE]:pygame.quit()os.sys.exit()elif keys[K_SPACE]:print('Jump')#update the arrowif not game_over:arrow.X -= arrow_velif arrow.X < 0:reset_arrow()screen.blit(bg, (0,0))group.update(ticks, 50)group.draw(screen)pygame.display.update()

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 一,初始 MyBatis-Plus
  • (11)iptables-仅开放指定ip访问指定端口
  • 深度学习自编码器 - 去噪自编码器篇
  • python画图|3D bar进阶探索
  • mozilla/pdf.js view.html加载指定页码
  • 【大模型实战篇】关于Bert的一些实操回顾以及clip-as-service的介绍
  • Π-系上的最小 d-系等于 Π-系上的最小集代数
  • git学习报告
  • 成都睿明智科技有限公司电商服务引领品牌跃升
  • [leetcode]64_最小路径和
  • 持续学习与创新能力的双重提升
  • SDKMAN!软件开发工具包管理器
  • 828华为云征文|使用Flexus X实例集成ES搜索引擎
  • 应用层 II(文件传输协议FTP)【★★】
  • 16.3 k8s容器cpu内存告警指标与资源request和limit
  • 【译】JS基础算法脚本:字符串结尾
  • java8 Stream Pipelines 浅析
  • MySQL的数据类型
  • ReactNativeweexDeviceOne对比
  • Spark in action on Kubernetes - Playground搭建与架构浅析
  • Webpack入门之遇到的那些坑,系列示例Demo
  • WebSocket使用
  • 闭包--闭包之tab栏切换(四)
  • 后端_MYSQL
  • 基于 Babel 的 npm 包最小化设置
  • 技术:超级实用的电脑小技巧
  • 力扣(LeetCode)56
  • 收藏好这篇,别再只说“数据劫持”了
  • 小程序测试方案初探
  • 验证码识别技术——15分钟带你突破各种复杂不定长验证码
  • 一、python与pycharm的安装
  • MiKTeX could not find the script engine ‘perl.exe‘ which is required to execute ‘latexmk‘.
  • mysql 慢查询分析工具:pt-query-digest 在mac 上的安装使用 ...
  • RDS-Mysql 物理备份恢复到本地数据库上
  • ​​​【收录 Hello 算法】10.4 哈希优化策略
  • ​configparser --- 配置文件解析器​
  • ​马来语翻译中文去哪比较好?
  • ​如何使用QGIS制作三维建筑
  • ​学习笔记——动态路由——IS-IS中间系统到中间系统(报文/TLV)​
  • # windows 安装 mysql 显示 no packages found 解决方法
  • (C#)获取字符编码的类
  • (javascript)再说document.body.scrollTop的使用问题
  • (Matalb分类预测)GA-BP遗传算法优化BP神经网络的多维分类预测
  • (二)延时任务篇——通过redis的key监听,实现延迟任务实战
  • (附源码)ssm航空客运订票系统 毕业设计 141612
  • (附源码)ssm考生评分系统 毕业设计 071114
  • (含笔试题)深度解析数据在内存中的存储
  • (六)vue-router+UI组件库
  • (南京观海微电子)——COF介绍
  • (数据大屏)(Hadoop)基于SSM框架的学院校友管理系统的设计与实现+文档
  • (算法)硬币问题
  • (一一四)第九章编程练习
  • (原创) cocos2dx使用Curl连接网络(客户端)
  • (转)Android学习笔记 --- android任务栈和启动模式
  • (轉貼) 寄發紅帖基本原則(教育部禮儀司頒布) (雜項)