热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

python实现滑雪者小游戏

这篇文章主要为大家详细介绍了python实现滑雪者小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

引言

这是一个用pygame写的滑雪者的游戏。

skier从上向下滑,途中会遇到树和旗子,捡起一个旗子得10分,碰到一颗树扣100分,可以用左右箭头控制skier方向。

安装pygame

pip install pygame

用pip或设置界面安装,可自行百度

以下是主界面代码,每一个类都是一个py文件,需要导包

import pygame
import random
from settings import Settings
from skier import Skier
from treeFlag import TreeFlagClass
# pygame.display.set_icon()
# background_image = pygame.image.load('timg.jpg').convert()#背景图
# 画图
# pygame.draw.circle(window,[0,0,0],[50,50],50,0)
my_set = Settings() # 用的是设置类 系统外观设置
skier_images = ['./skier_crash.png', './skier_down.png', './skier_left1.png', './skier_left2.png',
  './skier_right1.png', './skier_right2.png', ] #滑雪者的图

if __name__ == '__main__':
 # 初始化
 pygame.init()
 pygame.mixer.init()
 # 游戏窗口初始化
 window = pygame.display.set_mode((my_set.screen_width, my_set.screen_height)) # 窗口大小
 screen = pygame.display.get_surface()
 pygame.display.set_caption(my_set.name) # 窗口名字
 clock = pygame.time.Clock() # 帧率显示,先定义一个时间对象
 treeFlag_sprites = pygame.sprite.RenderUpdates() # 创建sprite容器 树
 # 添加树或旗子创建自定义事件
 AddEnemy = pygame.USEREVENT + 1
 pygame.time.set_timer(AddEnemy, 20)
 # 音乐
 # pygame.mixer.muisc.load('bg_music.mp3')
 skier = Skier(1) # 创建滑雪小人
 # 左上角计算分数
 # countObj = pygame.font.SysFont('方正兰亭超细黑简体',30)
 countObj = pygame.font.Font(None, 60)
 # countObj.set_bold(True) #加粗
 print(pygame.font.get_fonts())
 textObj = countObj.render('SCORE:0', True, (255, 0, 0))
 textRectObj = textObj.get_rect()
 # 这个是计算分数
 count_num = 0
 # 计算碰撞次数,10次场景加一次速度,最多叠加10次
 hit_count = 0
 # 显示当前速度
 speedObj = pygame.font.Font(None, 40)
 speed_text = speedObj.render('SPEED:1', True, (255, 0, 0))
 speedRectObj = speed_text.get_rect()
 speedRectObj.top = 60
 #运行游戏
 while True:
 # 先加载背景图
 clock.tick(60)
 window.fill(my_set.bg_color) # 填充,参数填写的是rgb值
 # window.blit(background_image,(0,0))
 ret = pygame.event.get() # 事件
 # 退出游戏判断
 for obj in ret:
  if obj.type == pygame.QUIT:
  print('关闭窗口')
  exit()
 # 获取键盘状态
 pressed_keys = pygame.key.get_pressed()
 #调用方法更新
 skier.update(pressed_keys)
 #判断事件,生成场景
 for event in pygame.event.get():
  if event.type == AddEnemy:
  if random.randint(1,10) %2:
   treeFlag_sprites.add(TreeFlagClass(1,1))
  else:
   treeFlag_sprites.add(TreeFlagClass(1,0))
 #判断与树或者旗子碰撞
 hit = pygame.sprite.spritecollide(skier, treeFlag_sprites, False)
 if hit:
  if hit[0].type == 'tree':
  count_num -= 100
  hit_count += 1
  hit[0].kill()
  skier.image = pygame.image.load(skier_images[0]).convert()
  # skier.image = pygame.image.load(skier_images[1]).convert()
  else:
  count_num += 10
  hit_count += 1
  hit[0].kill()
 #判断累计碰撞次数:
 if hit_count <50 and hit_count > 10:
  hit_num = hit_count//10
  for obj in treeFlag_sprites:
  obj.speed = hit_num
  skier.speed = hit_num
 elif hit_count >= 50:
  for obj in treeFlag_sprites:
  obj.speed = 5
  skier.speed = 5
 #场景动画更新
 treeFlag_sprites.update()
 tree_updates = treeFlag_sprites.draw(window)
 pygame.display.update(tree_updates)
 #添加画面以及帧率
 window.blit(skier.image, skier.rect) # 添加小人画面
 textObj = countObj.render('SCORE:%d' % count_num, False, (255, 0, 0)) #显示得分内容
 textRectObj = textObj.get_rect()
 window.blit(textObj, textRectObj) #这是得分
 speed_text = speedObj.render('SPEED:%d'%skier.speed, True, (255, 0, 0)) #显示速度内容
 speedRectObj = speed_text.get_rect()
 speedRectObj.top = 60
 window.blit(speed_text,speedRectObj) #显示速度
 pygame.display.update() # 必须要更新显示的内容

以下是滑雪者类代码

# 定义一个雪人类
import pygame
from settings import Settings

my_set = Settings()
skier_images = ['./skier_crash.png', './skier_down.png', './skier_left1.png', './skier_left2.png',
  './skier_right1.png', './skier_right2.png', ]
down_image = pygame.image.load(skier_images[1])
# 雪人初始位置
begin_top = 0
begin_left = my_set.screen_width / 2 - down_image.get_width() / 2

class Skier(pygame.sprite.Sprite):
 def __init__(self,speed):
 pygame.sprite.Sprite.__init__(self)
 '''
 :param image:指的是图片路径
 :param rect:位置
 :param down_speed:是往下的速度
 '''
 self.image = pygame.image.load(skier_images[1])
 self.rect = self.image.get_rect()
 self.rect.top = begin_top # 雪人初始位置
 self.rect.left = begin_left
 # 移动速度
 self.speed = speed
 #场景生成时间 也就是速度
 self.time_set = 40
 #根据按键事件来移动
 def update(self, pressed_keys):
 # 按键事件
 if pressed_keys[pygame.K_LEFT] or pressed_keys[pygame.K_a]:
  if self.rect.left > 0:
  self.image = pygame.image.load(skier_images[2]).convert()
  self.rect.left -= self.speed
 elif pressed_keys[pygame.K_RIGHT] or pressed_keys[pygame.K_d]:
  if self.rect.left  0 :
  self.image = pygame.image.load(skier_images[1]).convert()
  self.rect.top -= self.speed
 elif pressed_keys[pygame.K_DOWN] or pressed_keys[pygame.K_s]:
  if self.rect.top 

树和旗子类

import pygame
from random import randrange
from settings import Settings

my_set = Settings()
# 定义一个场景类
class TreeFlagClass(pygame.sprite.Sprite):

 def __init__(self,speed,treeFlag): #传入两个参数,初始速度和bool值树或旗子
 pygame.sprite.Sprite.__init__(self) #父类的初始化方法要调用
 '''
 :param image =图片
 :param type 判断是树还是旗子
 :param speed 速度
 '''
 if treeFlag:
  self.image = pygame.image.load('./skier_tree.png')
  self.type = 'tree'
 else:
  self.image = pygame.image.load('./skier_flag.png')
  self.type = 'flag'
 self.rect = self.image.get_rect()
 self.rect.top = self.rect.height + my_set.screen_height
 self.rect.centerx = randrange(my_set.screen_width - self.rect.width) + self.rect.width / 2
 self.speed = speed

 def update(self, *args):
 self.rect.top -= self.speed
 if self.rect.top <-self.rect.height:
  self.kill()

设置类

class Settings(object):
 def __init__(self):
 #这是一个设置类,用来管理游戏的外观
 self.screen_width = 600
 self.screen_height = 800
 self.bg_color = [255,255,255]
 self.name = 'skier'

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


推荐阅读
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • docker增加restart=always, docker重启后自动启动容器的方法
    本文介绍了在运行docker容器时如何添加参数来保证每次docker服务重启后容器也自动重启的方法,以及如何使用命令来更新已启动的容器。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
  • 处理docker容器时间和宿主机时间不一致问题的方法
    本文介绍了处理docker容器时间和宿主机时间不一致问题的方法,包括复制主机的localtime到容器、处理报错情况以及重启容器的步骤。通过这些方法,可以解决docker容器时间和宿主机时间不一致的问题。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
  • 本文介绍了Java的集合及其实现类,包括数据结构、抽象类和具体实现类的关系,详细介绍了List接口及其实现类ArrayList的基本操作和特点。文章通过提供相关参考文档和链接,帮助读者更好地理解和使用Java的集合类。 ... [详细]
  • 本文介绍了电流源并联合并的方法,以及谐振电路的原理。谐振电路具有很强的选频能力,通过将电感和电容连接在一起,电流和电压会产生震荡。谐振频率的大小取决于电感和电容的大小,而电路中的电阻会逐渐降低震荡的幅度。电阻和电容组成的电路中,当电容放完电后,电阻两端的电压为0,电流不再流过电容。然而,电感是一种特殊的器件,当有电流流过时,线圈会产生感应磁场,阻止电流的流动,从而使电流不会减小。 ... [详细]
  • 标题: ... [详细]
  • 单点登录原理及实现方案详解
    本文详细介绍了单点登录的原理及实现方案,其中包括共享Session的方式,以及基于Redis的Session共享方案。同时,还分享了作者在应用环境中所遇到的问题和经验,希望对读者有所帮助。 ... [详细]
  • 本文介绍了在Docker容器技术中限制容器对CPU的使用的方法,包括使用-c参数设置容器的内存限额,以及通过设置工作线程数量来充分利用CPU资源。同时,还介绍了容器权重分配的情况,以及如何通过top命令查看容器在CPU资源紧张情况下的使用情况。 ... [详细]
  • 集合的遍历方式及其局限性
    本文介绍了Java中集合的遍历方式,重点介绍了for-each语句的用法和优势。同时指出了for-each语句无法引用数组或集合的索引的局限性。通过示例代码展示了for-each语句的使用方法,并提供了改写为for语句版本的方法。 ... [详细]
  • Python SQLAlchemy库的使用方法详解
    本文详细介绍了Python中使用SQLAlchemy库的方法。首先对SQLAlchemy进行了简介,包括其定义、适用的数据库类型等。然后讨论了SQLAlchemy提供的两种主要使用模式,即SQL表达式语言和ORM。针对不同的需求,给出了选择哪种模式的建议。最后,介绍了连接数据库的方法,包括创建SQLAlchemy引擎和执行SQL语句的接口。 ... [详细]
author-avatar
小桃爱学PHP
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有