利用Pygame制作简单动画的示例详解
作者:我的天才女友 发布时间:2022-10-11 21:22:12
标签:Pygame,动画
前言
实现一个帧动画,使用的一个图,根据不同的时间显示不同的图。
使用的就是如下所示的一张图,宽度780 * 300 ,使用加载图片 260 * 150来实现。
pygame.init()
screen = pygame.display.set_mode((400, 300), 0, 32)
pygame.display.set_caption("动画")
while True:
for event in pygame.event.get():
if event.type == pygame.QUIT:
sys.exit()
key = pygame.key.get_pressed()
if key[pygame.K_ESCAPE]:
sys.exit()
screen.fill((154, 205, 255))
pygame.display.update()
首先实现最简单的图形
计时器
首先根据时间的不同,去改变当前的图像。
使用 pygame.time.Clock() 实现时间定时。get_ticks()获取一个不断增减的时间。
framerate = pygame.time.Clock()
frametate.tick(30)
ticks = pygame.time.get_ticks()
pygame.init()
screen = pygame.display.set_mode((400, 300), 0, 32)
pygame.display.set_caption("动画")
framerate = pygame.time.Clock()
while True:
framerate.tick(30)
ticks = pygame.time.get_ticks()
print(ticks)
for event in pygame.event.get():
if event.type == pygame.QUIT:
sys.exit()
key = pygame.key.get_pressed()
if key[pygame.K_ESCAPE]:
sys.exit()
screen.fill((154, 205, 255))
pygame.display.update()
758
791
824
858
891
924
958
992
1025
1058
输出如上所示,30帧每秒,所以时间每次增加大约34 - 33之间,如上所示我们获取到了一个随时间改变的量。
绘制精灵
这里使用精灵绘制图,为了方便操作。
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 # 保存之间的时间
def load(self, filename, width, height, columns):
self.master_image = pygame.image.load(filename).convert_alpha() # 载入图片
self.frame_width = width # 260
self.frame_height = height # 150
self.rect = 0, 0, width, height
self.columns = columns # 列宽的数量 是 3
# try to auto-calculate total frames
rect = self.master_image.get_rect() # 获取到对应的图片的大小 780 * 300
self.last_frame = (rect.width // width) * (rect.height // height) - 1 # 5
def update(self, current_time, rate = 30): # current_time 更新频率 为30
# update animation frame number
if current_time > self.last_time + rate: # 如果当前事件 大于 最后的时间 + 当前的节奏
self.frame += 1 # 当前的帧数加一
if self.frame > self.last_frame: # 当前最后一帧 则从第一帧开始
self.frame = self.first_frame # 从0开始
self.last_time = current_time # 将最后帧值为30
# build current frame only if it changed
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 = (frame_x, frame_y, self.frame_width, self.frame_height) # 更新对应的位置
self.image = self.master_image.subsurface(rect) # 循环箱已有的方向
self.old_frame = self.frame
加载精灵
pygame.sprite.Group()创建精灵组,之后使用对应的update draw 绘制对应的精灵
# create the sprite
dragon = MySprite(screen)
dragon.load("Fig07-02.png", 260, 150, 3)
group = pygame.sprite.Group()
group.add(dragon)
group.update(ticks)
group.draw(screen)
完整代码
import sys
import pygame
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
def load(self, filename, width, height, columns):
# 载入图片
# 780 * 300
self.master_image = pygame.image.load(filename).convert_alpha() # 载入图片
self.frame_width = width # 260
self.frame_height = height # 150
self.rect = 0, 0, width, height
self.columns = columns # 列宽的数量 是 3
# try to auto-calculate total frames
rect = self.master_image.get_rect() # 获取到对应的图片的大小 780 * 300
self.last_frame = (rect.width // width) * (rect.height // height) - 1 # 5
def update(self, current_time, rate=30): # current_time 更新频率 为30
# update animation frame number
if current_time > self.last_time + rate: # 如果当前事件 大于 最后的时间 + 当前的节奏
self.frame += 1 # 当前的帧数加一
if self.frame > self.last_frame: # 当前最后一帧 则从第一帧开始
self.frame = self.first_frame # 从0开始
self.last_time = current_time # 将最后帧值为30
# build current frame only if it changed
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 = (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((400, 300), 0, 32)
pygame.display.set_caption("动画")
framerate = pygame.time.Clock()
# 创建精灵
dragon = MySprite(screen)
dragon.load("Fig07-02.png", 260, 150, 3)
group = pygame.sprite.Group()
group.add(dragon)
while True:
framerate.tick(30)
ticks = pygame.time.get_ticks()
print(ticks)
for event in pygame.event.get():
if event.type == pygame.QUIT:
sys.exit()
key = pygame.key.get_pressed()
if key[pygame.K_ESCAPE]:
sys.exit()
screen.fill((154, 205, 255))
group.update(ticks)
group.draw(screen)
pygame.display.update()
来源:https://blog.csdn.net/qq_40801987/article/details/124809480


猜你喜欢
- 首先下载源tar包可利用linux自带下载工具wget下载,如下所示:wget http://www.python.org/ftp/pyth
- 自动求导机制从后向中排除子图每个变量都有两个标志:requires_grad和volatile。它们都允许从梯度计算中精细地排除子图,并可以
- 最终效果展示实现思路在绘图区域插入一个嵌入图,嵌入图与原图的绘画保持一致,通过限制嵌入图的x轴和y轴的显示范围,达到缩放的效果,并在原图上绘
- 本文实例为大家分享了python实现人机对战井字棋的具体代码,供大家参考,具体内容如下游戏简介:在九宫格内进行,如果一方抢先于另一方向(横、
- 前言之前写pandas和matplotlib的时候说到了想要出一期Pyechart系列数据可视化的文章。比起matplotlib,pyeac
- 1. 创建一个图import networkx as nxg = nx.Graph()g.clear() #将图上元素清空所有的构建复杂网络
- Asyncore模块提供了以异步的方式写入套接字服务客户端和服务器的基础结构。只有两种方式使一个程序在单处理器上实现“同时做不止一件事”。多
- Django 中,html 页面通过 form 标签来传递表单数据。对于复选框信息,即 checkbox 类型,点击 submit 后,数据
- ES6(ECMAScript 6)是即将到来的新版本JavaScript语言的标准,代号harmony(和谐之意,显然没有跟上我国的步伐,我
- 一:建立对象引用计数1. 相关代码void_Py_NewReference(PyObject *op){ if (
- 在已经发表的系列文章中我们已经讨论了两个ASP对象:Application对象和Session对象,因此能够访问Application对象和
- 1. 序列__getitem__如果没有 __iter__ 和 __contains__ 方法,Python 会调用 __getitem__
- 可以压缩文件和目录。package mainimport ( "archive/zip" &qu
- 概述ABP框架作为后端,是一个非常不错的技术方向,但是前端再使用Asp.NET 进行开发的话,虽然会快捷一点,不过可能显得有点累赘了,因此B
- 切片是 Python 中最迷人最强大最 Amazing 的语言特性(几乎没有之一),在《Python进阶:切片的误区与高级用法》中,我介绍了
- 在ASP中,为什么有时候刷新页面后,重新执行ASP代码时就连不上数据库了?这种情况一般发生在动态IP分配中,由于ASP连接数据库是定时的,默
- JavaScript: <script type="text/javascript"> var level1
- 在Perfection kills上看到他去年写的一篇文章,关于HTML优化的,讲的很详细,姑且记录之,尽管里面有些东西并不能在目前的环境里
- 题目:转换RBG颜色值我们知道在网页中的颜色值设置都是用16进制的RGB来表示的,比如#FFFFFF,表示R:255,G:255,B:255
- 单体最佳实践的由来对于很多初创公司来说,业务的早期我们更应该关注于业务价值的交付,并且此时用户体量也很小,QPS也非常低,我们应该使用更简单