Pygame 游戏框架(二)
Python的Pygame游戏框架基本使用
- 一、前言
- 二、Pygame 的基础使用
一、前言
- 个人主页: ζ小菜鸡
- 大家好我是ζ小菜鸡,小伙伴们,让我们一起来学习Python的Pygame游戏框架基本使用,来制作一个小游戏吧。
- 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)
二、Pygame 的基础使用
pygame 有很多模块,每个模块又有很多方法,在此不能逐一讲解,所以,我们通过一个实例来学习pygame,然后再分解代码,讲解代码中的模块。
示例:制作一个跳跃的兔子游戏
创建一个游戏窗口,然后在窗口内创建一个小球。以一定的速度移动小球,当小球碰到游戏窗口的边缘时,小球弹回,继续移动。可以按照如下步骤实现该功能:
(1)创建一个游戏窗口,宽和高设置为640*480。代码如下:
'''
****作者:ζ小菜鸡
'''
# _*_ coding:utf-8 _*_
import sys # 导入模块sys
import pygame # 导入模块pygame
pygame.init() # 初始化pygame
size = width, height = 640, 480 # 设置窗口
screen = pygame.display.set_mode(size) # 显示窗口
上述代码中,首先导入pygame模块,然后调用init()方法初始化pygame模块。接下来,设置窗口的宽和高,最后使用display模块的常用方法如下表所示:
方法名称 |
功能 |
pygame.display.init |
初始化display模块 |
pygame.display.quit |
结束display模块 |
pygame.display.get_init |
如果display模块已经被初始化,则返回True |
pygame.display.set_mode |
初始化一个准备显示的界面 |
pygame.display.get_surface |
获取当前的surface对象 |
pygame.display.flip |
更新整个待显示的surface对象到屏幕上 |
pygame.display.update |
更新部分内容显示到屏幕上,如果没有参数则与flip功能相同 |
(2)运行上述代码,会出现一个一闪而过的黑色窗口,这是因为程序执行完成后,会自动关闭。如果让窗口一直显示,需要使用while True语句让程序一直执行,此外,还需要设置关闭按钮,具体代码如下:
'''
****作者:ζ小菜鸡
'''
# _*_ coding:utf-8 _*_
import sys # 导入模块sys
import pygame # 导入模块pygame
pygame.init() # 初始化pygame
size = width, height = 640, 480 # 设置窗口
screen = pygame.display.set_mode(size) # 显示窗口
# 执行死循环,确保窗口一直显示
while True:
# 检查事件
for event in pygame.event.get(): # 遍历所有事件
if event.type == pygame.QUIT: # 如果单击关闭窗口,则退出
sys.exit()
pygame.quit() # 退出pygame
上述代码中,添加了轮询事件检测。pygame.event.get()方法能够获取事件队列,使用for…in语句遍历事件,然后根据type属性判断事件类型。这里事件处理方式与GUI类似,如果event.type等于pygame.QUIT,表示检测到关闭pygame窗口事件;pygame.KEYDOWN表示键盘按下事件,pygame.MOUSEBUTTONDOWN表示鼠标按下事件。
(3)在窗口中添加小兔子。先准备好一张ball.png图片,然后加载该图片,然后加载该图片,最后将图片显示在窗口中,具体代码如下:
'''
****作者:ζ小菜鸡
'''
# _*_ coding:utf-8 _*_
import sys # 导入模块sys
import pygame # 导入模块pygame
from pygame.locals import *
pygame.init() # 初始化pygame
size = width, height = 640, 480 # 设置窗口
screen = pygame.display.set_mode(size) # 显示窗口
color = (0, 0, 0) # 设置颜色
ball = pygame.image.load("ball.png") # 加载图片
space = pygame.transform.smoothscale(ball, (100, 100))
ballrect = space.get_rect() # 获取矩形区域
myfont = pygame.font.Font(None, 60)
textImage = myfont.render("小兔子游戏", True, color)
# 执行死循环,确保窗口一直显示
while True:
# 检查事件
for event in pygame.event.get(): # 遍历所有事件
if event.type == pygame.QUIT: # 如果单击关闭窗口,则退出
sys.exit()
screen.fill(color) # 填充颜色
screen.blit(space, ballrect) # 将图片画到窗口上
pygame.display.flip() # 更新全部窗口
pygame.quit() # 退出pygame
上述代码中使用image模块的load()方法加载图片,将返回值ball是一个Surface对象。Surface是用来代表图片的Pygame对象,可以对一个Surface对象进行涂画、变形、复制等各种操作。事实上,屏幕也只是一个Surface,pygame.display.set_mode就返回了一个屏幕Surface对象。如果将ball这个Surface对象画到screen Surface对象。需要使用blit()方法,最后使用display模块的flip方法更新整个待显示的Surface对象到屏幕上。 对象的常用方法如表所示:
方法名称 |
功能 |
pygame.Surface.blit |
将一个图像画到另外一个图像上 |
pygame.Surface.convent |
转换图像的像素格式 |
pygame.Surface.convent_alpha |
转化图像的像素格式,包含alpha通道的转换 |
pygame.Surface.fill |
使颜色填充Surface |
pygame.Surface.get_rect |
获取Surface的矩形区域 |
运行上述代码,结果如下图所示:
(4)下面该让小兔子动起来了。ball.get_rect()方法返回值ballrect是一个Rect对象,该对象有一个move()方法可以使用移动矩形。move(x,y)函数有两个参数:第一参数是x轴移动距离;第二个参数是y轴移动距离。窗口左上角坐标为(0,0),如果使用move(100,50),如图所示:
为了实现小兔子不停的移动,将move()函数加到while循环中,具体代码如下:
'''
****作者:ζ小菜鸡
'''
# _*_ coding:utf-8 _*_
import sys # 导入模块sys
import pygame # 导入模块pygame
from pygame.locals import *
pygame.init() # 初始化pygame
size = width, height = 640, 480 # 设置窗口
screen = pygame.display.set_mode(size) # 显示窗口
color = (0, 0, 0) # 设置颜色
ball = pygame.image.load("ball.png") # 加载图片
space = pygame.transform.smoothscale(ball, (100, 100))
ballrect = space.get_rect() # 获取矩形区域
myfont = pygame.font.Font(None, 60)
textImage = myfont.render("小兔子游戏", True, color)
speed = [5, 5] # 设置x轴,y轴
# 执行死循环,确保窗口一直显示
while True:
# 检查事件
for event in pygame.event.get(): # 遍历所有事件
if event.type == pygame.QUIT: # 如果单击关闭窗口,则退出
sys.exit()
ballrect = ballrect.move(speed) # 移动小兔子
screen.fill(color) # 填充颜色
screen.blit(space, ballrect) # 将图片画到窗口上
pygame.display.flip() # 更新全部窗口
pygame.quit() # 退出pygame
(5)运行上述代码,发现小兔子在屏幕中一闪而过,此时,小兔子并没有消失,而是移动到窗口之外,此时添加碰撞检测功能。当小兔子与窗体任何一边缘发生碰撞,则更改小兔子的移动方向。具体代码如下:
'''
****作者:ζ小菜鸡
'''
# _*_ coding:utf-8 _*_
import sys # 导入模块sys
import pygame # 导入模块pygame
from pygame.locals import *
pygame.init() # 初始化pygame
size = width, height = 640, 480 # 设置窗口
screen = pygame.display.set_mode(size) # 显示窗口
color = (0, 0, 0) # 设置颜色
ball = pygame.image.load("ball.png") # 加载图片
space = pygame.transform.smoothscale(ball, (100, 100))
ballrect = space.get_rect() # 获取矩形区域
myfont = pygame.font.Font(None, 60)
textImage = myfont.render("小兔子游戏", True, color)
speed = [5, 5] # 设置x轴,y轴
# 执行死循环,确保窗口一直显示
while True:
# 检查事件
for event in pygame.event.get(): # 遍历所有事件
if event.type == pygame.QUIT: # 如果单击关闭窗口,则退出
sys.exit()
ballrect = ballrect.move(speed) # 移动小兔子
# 碰撞左右边缘
if ballrect.left < 0 or ballrect.right > width:
speed[0] = -speed[0]
# 碰撞上下边缘
if ballrect.top < 0 or ballrect.bottom > height:
speed[1] = -speed[1]
screen.fill(color) # 填充颜色
screen.blit(space, ballrect) # 将图片画到窗口上
pygame.display.flip() # 更新全部窗口
pygame.quit() # 退出pygame
上述代码中,添加了碰撞检测功能。如果碰撞到左右边缘,更改x轴数据为负数;如果碰撞到上下边缘,更改y轴数据为负数,则运行结果如下图:
(6)运行上述代码,发现好像有多个小兔子在飞快的移动,这是因为代码事件非常短,导致肉眼观察出现错觉,因此需要添加一个“时钟”来控制运行的时间。这时需要使用pygame的time模块。使用pygame时钟之前,必须创建Clock对象的一个实例,然后在While循环中设置多长时间运行一次。具体代码如下:
'''
****作者:ζ小菜鸡
'''
# _*_ coding:utf-8 _*_
import sys # 导入模块sys
import pygame # 导入模块pygame
pygame.init() # 初始化pygame
size = width, height = 640, 480 # 设置窗口
screen = pygame.display.set_mode(size) # 显示窗口
color = (0, 0, 0) # 设置颜色
ball = pygame.image.load("ball.png") # 加载图片
space = pygame.transform.smoothscale(ball, (100, 100))
ballrect = space.get_rect() # 获取矩形区域
myfont = pygame.font.Font(None, 60)
textImage = myfont.render("小兔子游戏", True, color)
speed = [5, 5] # 设置x轴,y轴
clock = pygame.time.Clock() # 设置时钟
# 执行死循环,确保窗口一直显示
while True:
clock.tick(60) # 每60秒执行一次
# 检查事件
for event in pygame.event.get(): # 遍历所有事件
if event.type == pygame.QUIT: # 如果单击关闭窗口,则退出
sys.exit()
ballrect = ballrect.move(speed) # 移动小兔子
# 碰撞左右边缘
if ballrect.left < 0 or ballrect.right > width:
speed[0] = -speed[0]
# 碰撞上下边缘
if ballrect.top < 0 or ballrect.bottom > height:
speed[1] = -speed[1]
screen.fill(color) # 填充颜色
screen.blit(space, ballrect) # 将图片画到窗口上
pygame.display.flip() # 更新全部窗口
pygame.quit() # 退出pygame
Pygame游戏框架(二)到此就结束了,感谢大家阅读,如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)
推荐阅读
-
腾讯文明 IP 改编游戏《天下启功》将于 4 月 25 日二测
-
游戏 UI 框架设计 (I) :架构设计理论
-
UNIX 之父肯和丹尼斯(第二部分)--也许是因为宣传的缘故,今天人们的注意力大多集中在 "野生 "黑客身上,更多关注的是他们造成的破坏,而不是他们给技术带来的突破。如果回到 50 年前,情况就完全不同了。那时的黑客更像是为了爱好而自愿加班的模范员工,他们根本不在自己家里工作。 当然,那时的电脑还远远买不起。如果你对计算机技术感兴趣,就必须投身于学术机构或巨型企业。比如通用电气或贝尔实验室。 肯尼斯-莱恩-汤普森(Kenneth Lane Thompson)就是这些老派黑客中的一员,黑客们亲切地称他为 "肯"。他出生于 1943 年的前婴儿潮时代,22 岁从大学毕业,一年后获得硕士学位--这两个学位都来自加州大学伯克利分校的电子工程和计算科学专业。随后,他进入贝尔实验室,开始了 Multics 的研发工作。 不过,他并不总是在工作。他利用大型计算机编写了一款名为 "星际迷航 "的游戏,他和同事丹尼斯-里奇(Dennis Ritchie)在办公室里玩这款游戏。因此,当贝尔实验室在 1969 年退出 Multics 计划时,他和丹尼斯都有点失望。 不过很快,他们就找到了一台闲置的 PDP-7 机器。这台机器在当时属于低端产品,售价只有 7.2 万美元,所以贝尔实验室并没有太在意。幸运的是肯重写了《星际迷航》程序,开发了基于 Multics 的新操作系统,以便在 PDP-7 上运行游戏,甚至还为操作系统开发了一种新的编程语言 "B"。 这位 Unix 之父没有得到应有的尊重。
-
[安卓游戏开发]游戏框架构建
-
基于蜘蛛接龙游戏的二次开发
-
二维游戏作业:Tkinter 图形绘制 - 许可程序的图形版本
-
NeurIPS 2022 | 最强斗地主AI!网易互娱AI Lab提出基于完美信息蒸馏的方法-完美信息蒸馏(PTIE) 在斗地主游戏中,非完美信息的引入主要是由于三位玩家均不能看到别人的手牌,对于任意一位玩家而言,仅可知道其余两位玩家当前手牌的并集,而难于精准判断每位玩家当前手牌。完美信息蒸馏的思路是针对这种非完美问题,构建一个第三方角色,该角色可以看到三位玩家的手牌,该角色在不告知每位玩家完美信息的情况下通过信息蒸馏的方式引导玩家打出当前情况下合理的出牌。 以强化学习常用的 Actor-Critic 算法为例,PTIE 在 Actor-Critic 算法的应用中可以利用 Critic 的 Value 输出作为蒸馏手段来提升 Actor 的表现。具体而言即在训练中 Critic 的输入为完美信息(包含所有玩家的手牌信息),Actor 的输入为非完美信息(仅包含自己手牌信息),此种情况下 Critic 给予的 Value 值包含了完美信息,可以更好地帮助 Actor 学习到更好的策略。 从更新公式上来看,正常的 Actor-Critic 算法 Actor 更新的方式如下: 在 PTIE 模式下,对于每个非完美信息状态 h,我们可以在 Critic 中构建对应的完美信息状态 D(h),并用 Critic 的输出来更新 Actor 的策略梯度,从而达到完美信息蒸馏的效果。 PTIE 框架的整体结构如下图所示: 无论是训练还是执行过程中智能体都不会直接使用完美信息,在训练中通过蒸馏将完美信息用于提升策略,从而帮助智能体达到一个更高的强度。 PTIE 的另一种蒸馏方式是将完美信息奖励引入到奖励值函数的训练中,PerfectDou 提出了基于阵营设计的完美信息奖励 node reward,以引导智能体学习到斗地主游戏中的合作策略,其定义如下: 如上所示,完美信息部分 代表 t 时刻地主手牌最少几步可以出完,在斗地主游戏中可以近似理解为是距游戏获胜的距离, 代表 t 时刻地主阵营和农民阵营距游戏获胜的距离之差, 为调节系数。通过此种奖励设计,在训练时既可以一定程度地引入各玩家的手牌信息(出完的步数需要知道具体手牌才能计算),同时也鼓励农民以阵营的角度做出决策,提升农民的合作性。 特征构建: PerfectDou 针对牌类游戏的特点主要构建了两部分特征:牌局状态特征和动作特征。其中牌局状态特征主要包括当前玩家手牌牌型特征、当前玩家打出的卡牌牌型特征、玩家角色、玩家手牌数目等常用特征,动作特征主要用于刻画当前状态下玩家的所有可能出牌,包括了每种出牌动作的牌型特征、动作的卡牌数目、是否为最大动作等特征。 牌型特征为 12 * 15 的矩阵,如下图所示: 该矩阵前 4 行代表对应每种卡牌的张数,5-12 行代表该种卡牌的种类和对应位置。 网络结构和动作空间设计 针对斗地主游戏出牌组合数较多的问题,PerfectDou 基于 RLCard 的工作上对动作空间进行了简化,对占比最大的两个出牌牌型:飞机带翅膀和四带二进行了动作压缩,将整体动作空间由 27472 种缩减到 621 种。 PerfectDou 策略网络结构如下图所示: 策略网络结构同样分为两部分:状态特征部分和动作特征部分。 在状态特征部分,LSTM 网络用于提取玩家的历史行为特征,当前牌局状态特征和提取后的行为特征会再通过多层的 MLP 网络输出当前的状态信息 embedding。 在动作特征部分,每个可行动作同样会经过多层 MLP 网络进行编码,编码后的动作特征会与其对应的状态信息 embedding 经过一层 MLP 网络计算两者间的相似度,并经由 softmax 函数输出对应的动作概率。 实验结果
-
Pygame 经典游戏:蛇
-
梦泪人气如此夸张?2020腾讯游戏玩家盛典投票遥遥领先第二名
-
第二款VR游戏推荐丨和洋葱小姐姐跳舞太累?这里的小姐姐都是随机抽取的!