不得不承认《Python游戏编程入门》这本书翻译、排版非常之烂,但是里面的demo还是很好的,之前做了些改编放到这里。

先是素材:

背景

精灵

所有素材均取自此书

接下来就是精灵类的创建了:

class MySprite(pygame.sprite.Sprite):

def __init__(self, target):

pygame.sprite.Sprite.__init__(self)

self.master_image = None

self.frame = 0

self.old_frame = -1

self.frame_width = 1

self.frame_height = 1

self.first_frame = 0

self.last_frame = 0

self.columns = 1

self.last_time = 0

#  使用property方法,让精灵类对坐标操作更方便

def _getx(self):

return self.rect.x

def _setx(self, value):

self.rect.x = value

X = property(_getx, _setx)

def _gety(self):

return self.rect.y

def _sety(self, value):

self.rect.y = value

Y = property(_gety, _sety)

def _getpos(self):

return self.rect.topleft

def _setpos(self, pos):

self.rect.topleft = pos

position = property(_getpos, _setpos)

#  load方法中定义了图片位置,长宽和帧的列数,由此来将素材切成一帧一帧

def load(self, filename, width, height, columns):

self.master_image = pygame.image.load(filename).convert_alpha()

self.frame_width = width

self.frame_height = height

self.rect = Rect(0, 0, width, height)

self.columns = columns

rect = self.master_image.get_rect()

self.last_frame = (rect.width // width) * (rect.height // height) - 1

def update(self, current_time, rate=30):

#  更新帧数

if current_time > self.last_time + rate:

self.frame += 1

if self.frame > self.last_frame:

self.frame = self.first_frame

self.last_time = current_time

#  当帧数发生改变时,创建新的图片

if self.frame != self.old_frame:

frame_x = (self.frame % self.columns) * self.frame_width

frame_y = (self.frame // self.columns) * self.frame_height

rect = Rect(frame_x, frame_y, self.frame_width, self.frame_height)

self.image = self.master_image.subsurface(rect)

self.old_frame = self.frame

将精灵类“放置”到游戏屏幕上,并加上背景

pygame.init()

screen = pygame.display.set_mode((800, 600))

font = pygame.font.Font(None, 24)

framerate = pygame.time.Clock()

bg = pygame.image.load("background.png").convert_alpha()

pl = pygame.image.load('caveman.png').convert_alpha()

# 创建精灵组

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)

while True:

for event in pygame.event.get():

if event.type == QUIT:

sys.exit()

# 设置帧数

framerate.tick(30)

ticks = pygame.time.get_ticks()

这样的话精灵就在画布上了,我们得让它能左右移动:

keys = pygame.key.get_pressed()

if keys[K_ESCAPE]:

sys.exit()

if keys[K_RIGHT]:

player.X += 8

if keys[K_LEFT]:

if player.X > 0:

player.X -= 8

然后实现跳跃及二段跳跃

这里需要说下二段跳跃的注意点:

1.直到落地前,只能跳两次,也就是说精灵进行二次跳跃后不能再跳了

2.按下空格后,精灵的加速度重置

这需要修改前面的代码:

jump_vel = 0.0

# 设置一个记录跳跃次数的变量

space_number = 0

# 跳跃判断

player_jumping = False

player_start_y = player.Y

while True:

for event in pygame.event.get():

if event.type == QUIT:

sys.exit()

if event.type == KEYDOWN:

if event.key == K_SPACE:

# 跳跃次数小于2次时,

if space_number < 2:

jump_vel = -15.0

space_number += 1

player_jumping = True

keys = pygame.key.get_pressed()

if keys[K_ESCAPE]:

sys.exit()

if keys[K_RIGHT]:

player.X += 8

if keys[K_LEFT]:

if player.X > 0:

player.X -= 8

# 设置帧数

framerate.tick(30)

ticks = pygame.time.get_ticks()

# 当按下空格后,jump_vel变量不断变大,直到接触地面

if player_jumping:

player.Y += jump_vel

jump_vel += 2

# 落地后,重置跳跃速度和其他判断变量

if player.Y >= player_start_y:

player_jumping = False

player.Y = player_start_y

jump_vel = 0

space_number = 0

# 创建背景

screen.blit(bg, (0, 0))

# 精灵组更新

group.update(ticks, 50)

group.draw(screen)

pygame.display.update()

所有代码:

import sys, time, random, math, pygame

from pygame.locals import *

class MySprite(pygame.sprite.Sprite):

def __init__(self, target):

pygame.sprite.Sprite.__init__(self)

self.master_image = None

self.frame = 0

self.old_frame = -1

self.frame_width = 1

self.frame_height = 1

self.first_frame = 0

self.last_frame = 0

self.columns = 1

self.last_time = 0

#   使用property方法,让精灵类对坐标操作更方便

def _getx(self):

return self.rect.x

def _setx(self, value):

self.rect.x = value

X = property(_getx, _setx)

def _gety(self):

return self.rect.y

def _sety(self, value):

self.rect.y = value

Y = property(_gety, _sety)

def _getpos(self):

return self.rect.topleft

def _setpos(self, pos):

self.rect.topleft = pos

position = property(_getpos, _setpos)

def load(self, filename, width, height, columns):

self.master_image = pygame.image.load(filename).convert_alpha()

self.frame_width = width

self.frame_height = height

self.rect = Rect(0, 0, width, height)

self.columns = columns

rect = self.master_image.get_rect()

self.last_frame = (rect.width // width) * (rect.height // height) - 1

def update(self, current_time, rate=30):

#   更新帧数

if current_time > self.last_time + rate:

self.frame += 1

if self.frame > self.last_frame:

self.frame = self.first_frame

self.last_time = current_time

# 当帧数发生改变时,创建新的图片

if self.frame != self.old_frame:

frame_x = (self.frame % self.columns) * self.frame_width

frame_y = (self.frame // self.columns) * self.frame_height

rect = Rect(frame_x, frame_y, self.frame_width, self.frame_height)

self.image = self.master_image.subsurface(rect)

self.old_frame = self.frame

pygame.init()

screen = pygame.display.set_mode((800, 600))

font = pygame.font.Font(None, 24)

framerate = pygame.time.Clock()

bg = pygame.image.load("background.png").convert_alpha()

pl = pygame.image.load('caveman.png').convert_alpha()

# 创建精灵组

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)

jump_vel = 0.0

# 设置一个记录跳跃次数的变量

space_number = 0

# 跳跃判断

player_jumping = False

player_start_y = player.Y

while True:

for event in pygame.event.get():

if event.type == QUIT:

sys.exit()

if event.type == KEYDOWN:

if event.key == K_SPACE:

# 跳跃次数小于2次时,

if space_number < 2:

jump_vel = -15.0

space_number += 1

player_jumping = True

keys = pygame.key.get_pressed()

if keys[K_ESCAPE]:

sys.exit()

if keys[K_RIGHT]:

player.X += 8

if keys[K_LEFT]:

if player.X > 0:

player.X -= 8

# 设置帧数

framerate.tick(30)

ticks = pygame.time.get_ticks()

# 当按下空格后,jump_vel变量不断变大,直到接触地面

if player_jumping:

player.Y += jump_vel

jump_vel += 2

# 落地后

if player.Y >= player_start_y:

player_jumping = False

player.Y = player_start_y

jump_vel = 0

space_number = 0

rush_number = 0

# 创建背景

screen.blit(bg, (0, 0))

# 精灵组更新

group.update(ticks, 50)

group.draw(screen)

pygame.display.update()

这样,一个粗糙的、会二段跳的精灵就完成了。

很感谢这本书提供单次跳跃的思路,让我有思考二段跳的想法。其实像二段跳这类看上去容易,但实现其实还是需要思考一番的。

以上这篇pygame 精灵的行走及二段跳的实现方法(必看篇)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

本文标题: pygame 精灵的行走及二段跳的实现方法(必看篇)

本文地址: http://www.cppcns.com/jiaoben/python/196025.html

python手机脚本精灵使用教程_pygame 精灵的行走及二段跳的实现方法(必看篇)相关推荐

  1. python新手入门总结_初学python的操作难点总结(新手必看篇)

    如下所示: 1 在cmd下 盘与盘之间的切换 直接 D或d: 就好 2 查找当前盘或者文件下面的目录 直接 dir 3 想在一个盘下进去一个文件夹,用cd空格目标文件 cd p 4 写文件的第一个字母 ...

  2. 新手如何快速入门Python(菜鸟必看篇)

    学习任何一门语言都是从入门(1年左右),通过不间断练习达到熟练水准(3到5年),少数人最终能精通语言,成为执牛耳者,他们是金字塔的最顶层.虽然万事开头难,但好的开始是成功的一半,今天这篇文章就来谈谈如 ...

  3. python编程数据处理_python数据处理实战(必看篇)

    一.运行环境 1.python版本 2.7.13 博客代码均是这个版本 2.系统环境:win7 64位系统 二.需求 对杂乱文本数据进行处理 部分数据截图如下,第一个字段是原字段,后面3个是清洗出的字 ...

  4. python数据处理实例-python数据处理实战(必看篇)

    一.运行环境 1.python版本 2.7.13 博客代码均是这个版本 2.系统环境:win7 64位系统 二.需求 对杂乱文本数据进行处理 部分数据截图如下,第一个字段是原字段,后面3个是清洗出的字 ...

  5. JavaScript基础教程——入门必看篇

    JavaScript他是一种描述性语言,其实他并不难学,只要用心学,一定会学好,我相信大家在看这篇文章的时候,一定也学过HTML吧,使用JavaScript就是为了能和网页有更好的交互,下面切入主题. ...

  6. python生成器杨辉三角_python 生成器生成杨辉三角的方法(必看)

    用Python写趣味程序感觉屌屌的,停不下来 #生成器生成展示杨辉三角 #原理是在一个2维数组里展示杨辉三角,空的地方用0,输出时,转化为' ' def yang(line): n,leng=0,2* ...

  7. python的难点_初学python的操作难点总结(新手必看篇)

    如下所示: 1 在cmd下 盘与盘之间的切换 直接 D或d: 就好 2 查找当前盘或者文件下面的目录 直接 dir 3 想在一个盘下进去一个文件夹,用cd空格目标文件 cd p 4 写文件的第一个字母 ...

  8. 怎么安装python_零基础入门必看篇:浅析python,PyCharm,Anaconda三者之间关系

    今天为大家带来的内容是:零基础入门必看篇:浅析python ,PyCharm,Anaconda三者之间关系 众所周知,Python是一种跨平台的计算机程序设计语言,简单来说,python就是类似于C, ...

  9. python 对象转字典及序列化对象相关问题,__dict__!!!!必看,多坑

    目录 __dict__只能存储实例变量,不能存储类变量 情况一:(可以直接通过__dict__序列化对象) 情况二:(不能直接通过__dict__序列化对象) 情况三:(定义keys和__getite ...

最新文章

  1. php实现tcp连接esp8266,ESP8266之TCP透传
  2. 美特斯邦威java面试_在美特斯邦威工作一个月,我学到了什么
  3. Java基础篇:封装、继承、多态三大特性
  4. 【mysql】配置 选项文件
  5. (1)memcached应用
  6. python2.x环境下unicode乱码转中文显示的2种解决方案总结
  7. Git 实用操作 | 撤销 Commit 提交
  8. Java 9对可选的补充
  9. c语言与64位windows不兼容_微软发布可模拟 64 位 x86 程序的 ARM 版 Windows 10
  10. shell mysql awk_shell mysql 处理数据小结
  11. WORD如何一键转PPT
  12. 我究竟为什么要每天埋头写代码?
  13. 因严重缺陷,Rust 撤销所有 Crates 包的 API 令牌
  14. Atitit ide的艺术 与新特性搜集大纲 目录 1. Prj mana 2 2. 界面布局自定义 2 2.1. 自定义 perspectives 2 3. 代码编写 2 3.1. 自动提示 2
  15. 深入理解机器学习中的信息熵、KL散度、交叉熵
  16. (十:2020.08.28)CVPR 2018 追踪之论文纲要(译)
  17. TCP/IP-----协议号、端口号、ARP、icmp
  18. KIBA 和 Davis 数据集下载 以及部分学习笔记
  19. CQI原理及CQI指标优化
  20. 耗时5小时用纯HTML和CSS写成的博学谷

热门文章

  1. background and notification of local
  2. Linux下文件的读写
  3. rhel6的部分版本使用intel xeon处理器时的bug
  4. linux 动态库 软链接,Linux操作系统下动态库的生成及链接方法
  5. 2021年中国工业和商业LED照明市场趋势报告、技术动态创新及2027年市场预测
  6. 顺丰丰桥接口开发-java(下订单接口)
  7. 大疆Naza-LED模块---或许并不是最佳方案
  8. 计算机专业英语电池,“七号电池”英语不是 No.7 battery,而是这个!超有趣!...
  9. 计算机什么专业可以自学考试,自学考试,计算机专业哪个专业好?
  10. 严格模式、混杂模式与怪异模式