python手机脚本精灵使用教程_pygame 精灵的行走及二段跳的实现方法(必看篇)
不得不承认《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 精灵的行走及二段跳的实现方法(必看篇)相关推荐
- python新手入门总结_初学python的操作难点总结(新手必看篇)
如下所示: 1 在cmd下 盘与盘之间的切换 直接 D或d: 就好 2 查找当前盘或者文件下面的目录 直接 dir 3 想在一个盘下进去一个文件夹,用cd空格目标文件 cd p 4 写文件的第一个字母 ...
- 新手如何快速入门Python(菜鸟必看篇)
学习任何一门语言都是从入门(1年左右),通过不间断练习达到熟练水准(3到5年),少数人最终能精通语言,成为执牛耳者,他们是金字塔的最顶层.虽然万事开头难,但好的开始是成功的一半,今天这篇文章就来谈谈如 ...
- python编程数据处理_python数据处理实战(必看篇)
一.运行环境 1.python版本 2.7.13 博客代码均是这个版本 2.系统环境:win7 64位系统 二.需求 对杂乱文本数据进行处理 部分数据截图如下,第一个字段是原字段,后面3个是清洗出的字 ...
- python数据处理实例-python数据处理实战(必看篇)
一.运行环境 1.python版本 2.7.13 博客代码均是这个版本 2.系统环境:win7 64位系统 二.需求 对杂乱文本数据进行处理 部分数据截图如下,第一个字段是原字段,后面3个是清洗出的字 ...
- JavaScript基础教程——入门必看篇
JavaScript他是一种描述性语言,其实他并不难学,只要用心学,一定会学好,我相信大家在看这篇文章的时候,一定也学过HTML吧,使用JavaScript就是为了能和网页有更好的交互,下面切入主题. ...
- python生成器杨辉三角_python 生成器生成杨辉三角的方法(必看)
用Python写趣味程序感觉屌屌的,停不下来 #生成器生成展示杨辉三角 #原理是在一个2维数组里展示杨辉三角,空的地方用0,输出时,转化为' ' def yang(line): n,leng=0,2* ...
- python的难点_初学python的操作难点总结(新手必看篇)
如下所示: 1 在cmd下 盘与盘之间的切换 直接 D或d: 就好 2 查找当前盘或者文件下面的目录 直接 dir 3 想在一个盘下进去一个文件夹,用cd空格目标文件 cd p 4 写文件的第一个字母 ...
- 怎么安装python_零基础入门必看篇:浅析python,PyCharm,Anaconda三者之间关系
今天为大家带来的内容是:零基础入门必看篇:浅析python ,PyCharm,Anaconda三者之间关系 众所周知,Python是一种跨平台的计算机程序设计语言,简单来说,python就是类似于C, ...
- python 对象转字典及序列化对象相关问题,__dict__!!!!必看,多坑
目录 __dict__只能存储实例变量,不能存储类变量 情况一:(可以直接通过__dict__序列化对象) 情况二:(不能直接通过__dict__序列化对象) 情况三:(定义keys和__getite ...
最新文章
- php实现tcp连接esp8266,ESP8266之TCP透传
- 美特斯邦威java面试_在美特斯邦威工作一个月,我学到了什么
- Java基础篇:封装、继承、多态三大特性
- 【mysql】配置 选项文件
- (1)memcached应用
- python2.x环境下unicode乱码转中文显示的2种解决方案总结
- Git 实用操作 | 撤销 Commit 提交
- Java 9对可选的补充
- c语言与64位windows不兼容_微软发布可模拟 64 位 x86 程序的 ARM 版 Windows 10
- shell mysql awk_shell mysql 处理数据小结
- WORD如何一键转PPT
- 我究竟为什么要每天埋头写代码?
- 因严重缺陷,Rust 撤销所有 Crates 包的 API 令牌
- Atitit ide的艺术 与新特性搜集大纲 目录 1. Prj mana	2 2. 界面布局自定义	2 2.1. 自定义 perspectives	2 3. 代码编写	2 3.1. 自动提示	2
- 深入理解机器学习中的信息熵、KL散度、交叉熵
- (十:2020.08.28)CVPR 2018 追踪之论文纲要(译)
- TCP/IP-----协议号、端口号、ARP、icmp
- KIBA 和 Davis 数据集下载 以及部分学习笔记
- CQI原理及CQI指标优化
- 耗时5小时用纯HTML和CSS写成的博学谷
热门文章
- background and notification of local
- Linux下文件的读写
- rhel6的部分版本使用intel xeon处理器时的bug
- linux 动态库 软链接,Linux操作系统下动态库的生成及链接方法
- 2021年中国工业和商业LED照明市场趋势报告、技术动态创新及2027年市场预测
- 顺丰丰桥接口开发-java(下订单接口)
- 大疆Naza-LED模块---或许并不是最佳方案
- 计算机专业英语电池,“七号电池”英语不是 No.7 battery,而是这个!超有趣!...
- 计算机什么专业可以自学考试,自学考试,计算机专业哪个专业好?
- 严格模式、混杂模式与怪异模式