热门标签 | 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中的volatile、内存屏障与CPU指令
    本文详细探讨了Java中volatile关键字的作用机制,以及其与内存屏障和CPU指令之间的关系。通过具体示例和专业解析,帮助读者更好地理解多线程编程中的同步问题。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 本文详细介绍了W3C标准盒模型和IE传统盒模型的区别,探讨了CSS3中box-sizing属性的使用方法及其在布局中的重要性。通过实例分析,帮助读者更好地理解和应用这一关键概念。 ... [详细]
  • 题库来源:安全生产模拟考试一点通公众号小程序G3锅炉水处理报名考试是安全生产模拟考试一点通生成的,G3锅炉水处理证模拟考试题库是根据G3锅炉水处理最新 ... [详细]
  • 本文详细探讨了Netty中Future及其子类的设计与实现,包括其在并发编程中的作用和具体应用场景。我们将介绍Future的继承体系、关键方法的实现细节,并讨论如何通过监听器和回调机制来处理异步任务的结果。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 本文介绍如何在 Unity 的 XML 配置文件中,将参数传递给自定义生命周期管理器的构造函数。我们将详细探讨 CustomLifetimeManager 类的实现及其配置方法。 ... [详细]
  • Ralph的Kubernetes进阶之旅:集群架构与对象解析
    本文深入探讨了Kubernetes集群的架构和核心对象,详细介绍了Pod、Service、Volume等基本组件,以及更高层次的抽象如Deployment、StatefulSet等,帮助读者全面理解Kubernetes的工作原理。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文详细探讨了Java中StringBuffer类在不同情况下的扩容规则,包括空参构造、带初始字符串和指定初始容量的构造方法。通过实例代码和理论分析,帮助读者更好地理解StringBuffer的内部工作原理。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 深入了解 Windows 窗体中的 SplitContainer 控件
    SplitContainer 控件是 Windows 窗体中的一种复合控件,由两个可调整大小的面板和一个可移动的拆分条组成。本文将详细介绍其功能、属性以及如何通过编程方式创建复杂的用户界面。 ... [详细]
  • 实体映射最强工具类:MapStruct真香 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文探讨了在Linux系统上使用Docker时,通过volume将主机上的HTML5文件挂载到容器内部指定目录时遇到的403错误,并提供了解决方案和详细的操作步骤。 ... [详细]
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社区 版权所有