pgzero:用 Python 进行游戏开发

article/2025/9/7 6:40:39

1. pgzero

python在各个领域都有着丰富的第三方库,pygame是python在游戏领域的应用库,可以用来开发各种不同的游戏。但是对于初学者来说,还是存在一定的门槛。

而今天要和大家分享的pgzero(pygame zero)是在pygame基础上做了进一步的封装,使得设计一款游戏十分的方便,特别适合少儿编程领域的教学, 与scratch相得益彰。

  • pgzero的安装

    pip install pygame
    pip install pgzero
    

2. 游戏设计的过程

我们可以简单梳理下开发一款简单游戏需要的过程:

  • 游戏的故事设计

  • 游戏的场景绘制(背景图片和声音)

  • 游戏的角色

  • 如何控制角色

  • 如何判断成功与失败

  • 游戏的关卡设计

3. pgzero基础

pgzero游戏开发的过程如下:

  • 游戏屏幕区域screen pgzero中游戏界面窗口设置由全局变量和内置对象screen来完成:

    • 窗口外观:WIDTH , HEIGHTTITLE

    • 窗口清楚:screen.clear()

    • 窗口背景颜色:screen.fill((red, green, blue))

    • 在窗口绘制图像:screen.blit(image, (left, top))

    • 在窗口绘制几何图案:screen.draw.line screen.draw.circle screen.draw.rect

  • 游戏角色Actor pgzero中所有以图片显示的元素都是Actor类来定义。

    # 'alien' 表示alien图片,默认是images/alien.png
    # (50, 50) 定义了Actor在窗口上显示的位置
    alien = Actor('alien', (50, 50))
    

    Actor的位置:

Actor重要属性和方法:

  • 其他属性同pygame.Rect

    • 外观:image, 如alien.image = 'alien_hurt'

    • 位置: piex坐标值:x,y, 设置位置:pos,left/right/top/bottom

    • 角度:angle

    • 绘制f方法:draw()

    • 距离方法: Actor.distance_to(target)

    • 角度方法:Actor.angle_to(target)

  • 游戏渲染绘制draw

  • 游戏状态的更新update

  • 游戏外部事件的触发控制on_xxx_xxx pgzero提供了常用的鼠标和键盘事件

    键盘的按键信息是通过keyboard内置对象获取的,鼠标是mouse来获取的,如:

     keyboard.a  # The 'A' keykeyboard.left  # The left arrow keykeyboard.rshift  # The right shift keykeyboard.kp0  # The '0' key on the keypadkeyboard.k_0  # The main '0' keymouse.LEFTmouse.RIGHTmouse.MIDDLE
    

    详见

    • https://pygame-zero.readthedocs.io/en/stable/hooks.html#mouse.WHEEL_DOWN

    • 键盘事件:on_key_down, on_key_up

    • 鼠标事件:on_mouse_down, on_mouse_up, on_mouse_move

其他重要元素

  • 声音 sounds:支持wav和ogg, 资源对象目录默认为./sounds

    # 播放声音./sounds/drum.wav
    sounds.drum.play()
    
  • 音乐 music: 支持mp3, 主要是时间较长的音频文件。资源对象目录默认为./music

    # 播放声音./music/drum.mp3
    music.play('drum')
    
  • 动画效果Animations,如移动角色到某个位置

    # animate(object, tween='linear', duration=1, on_finished=None, **targets)
    animate(alien, pos=(100, 100))
    

    详见:

    https://pygame-zero.readthedocs.io/en/stable/builtins.html#Animations

4. pgzero游戏例子

了解了pgzero的基本使用情况,下面来举一个例子,将游戏编写制作的过程串起来。

我们来模拟手机上的一款游戏FlappyBird。游戏简单操作说明

在《FlappyBird》这款游戏中,玩家只需要用一根手指来操控,点击触摸屏幕,小鸟就会往上飞,不断的点击就会不断的往高处飞。放松手指,则会快速下降。所以玩家要控制小鸟一直向前飞行,然后注意躲避途中高低不平的管子。 [3] 
1、在游戏开始后,点击屏幕,要记住是有间歇的点击屏幕,不要让小鸟掉下来。
2、尽量保持平和的心情,点的时候不要下手太重,尽量注视着小鸟。
3、游戏的得分是,小鸟安全穿过一个柱子且不撞上就是1分。当然撞上就直接挂掉,只有一条命。

pgzero游戏代码结构:

import pgzrun# 全局变量和初始化信息
TITLE = 'xxx'
WIDTH = 400
HEIGHT = 500# 绘制游戏元素
def draw():pass# 更新游戏状态
def update():pass# 处理键盘事件
def on_key_down():pass# 处理键盘事件
def on_mouse_down():pass# 执行
pgzrun.go()
import pgzrun
import randomTITLE = 'Flappy Bird'
WIDTH = 400
HEIGHT = 500# These constants control the difficulty of the game
GAP = 130
GRAVITY = 0.3
FLAP_STRENGTH = 6.5
SPEED = 3# bird 
bird = Actor('bird1', (75, 200))
bird.dead = False
bird.score = 0
bird.vy = 0storage = {}
storage['highscore'] = 0def reset_pipes():# 设置随机的高度pipe_gap_y = random.randint(200, HEIGHT - 200)pipe_top.pos = (WIDTH, pipe_gap_y - GAP // 2)pipe_bottom.pos = (WIDTH, pipe_gap_y + GAP // 2)pipe_top = Actor('top', anchor=('left', 'bottom'))
pipe_bottom = Actor('bottom', anchor=('left', 'top'))
reset_pipes()  # Set initial pipe positions.def update_pipes():# 不断的移动柱子pipe_top.left -= SPEEDpipe_bottom.left -= SPEEDif pipe_top.right < 0:reset_pipes()if not bird.dead:bird.score += 1if bird.score > storage['highscore']:storage['highscore'] = bird.scoredef update_bird():# 小鸟下降uy = bird.vybird.vy += GRAVITYbird.y += (uy + bird.vy) / 2bird.x = 75# 根据小鸟死亡切换小鸟的造型if not bird.dead:if bird.vy < -3:bird.image = 'bird2'else:bird.image = 'bird1'# 判断小鸟死亡: 是否触碰柱子if bird.colliderect(pipe_top) or bird.colliderect(pipe_bottom):bird.dead = Truebird.image = 'birddead'# 小鸟超过边界 初始化if not 0 < bird.y < 720:bird.y = 200bird.dead = Falsebird.score = 0bird.vy = 0reset_pipes()def update():update_pipes()update_bird()# 按下任意键, 小鸟上升
def on_key_down():if not bird.dead:bird.vy = -FLAP_STRENGTH# 
def draw():# 背景图片screen.blit('background', (0, 0))# 加载小鸟/柱子pipe_top.draw()pipe_bottom.draw()bird.draw()# 显示分数和最佳screen.draw.text(str(bird.score),color='white',midtop=(WIDTH // 2, 10),fontsize=70,shadow=(1, 1))screen.draw.text("Best: {}".format(storage['highscore']),color=(200, 170, 0),midbottom=(WIDTH // 2, HEIGHT - 10),fontsize=30,shadow=(1, 1))pgzrun.go()

5. 总结

本文分享了基于pygame封装版的pgzero开发python游戏的过程,希望对您有帮助。总结如下:

  • pgzero开发三剑客:draw() / update() / on_xxx_xxx()

  • pgzero内置对象:screen负责窗口设置,Actor负责图像显示,sounds负责短音频,music负责长音频bgm,动画效果有animate

  • pgzero资源目录:./images/xxx.png ./music/xxx.mp3  ./sounds/xxx/wav

6. 参考资料

  • https://pygame-zero.readthedocs.io/en/stable/

作者简介:wedo实验君, 数据分析师;热爱生活,热爱写作

赞 赏 作 者


点击下方阅读原文加入社区会员


http://chatgpt.dhexx.cn/article/qjMVVAgJ.shtml

相关文章

Python3爬虫、数据清洗与可视化实战之写一个简单的爬虫

文章目录 关于爬虫的合法性了解网页认识网页结构写一个简单的HTML 使用requests库请求网站安装requests库爬虫的基本原理使用GET方式抓取数据使用POST方式抓取数据 使用Beautiful Soup解析网页清洗和组织数据爬虫攻防战 关于爬虫的合法性 几乎每一个网站都有一个名为robots.tx…

Python3.X 爬虫实战(并发爬取)

【工匠若水 http://blog.csdn.net/yanbober 未经允许严禁转载&#xff0c;请尊重作者劳动成果。私信联系我】 1 背景 在这一系列开始前我们就说过&#xff0c;简单的爬虫很容易&#xff0c;但是要完成一个高效健壮的爬虫不是一个简单的事情&#xff0c;这一系列我们已经明白了爬…

Python爬虫(三)

Python爬虫&#xff08;三&#xff09; 一、ajax请求豆瓣电影第一页 # get请求 # 获取豆瓣电影的第一页数据并保存 import urllib.request url https://movie.douban.com/j/chart/top_list?type5&interval_id100%3A90&action&start0&limit20 headers {use…

Python3爬虫(一)抓取网页的html

因为代码只有几行&#xff0c;所以可以先贴代码&#xff1a; import urllib.request url rhttp://douban.com res urllib.request.urlopen(url) html res.read().decode(utf-8) print(html) 第一行&#xff0c;导入 urllib库的request模块 第二行&#xff0c;指定要抓取的网…

python3爬虫-Python3网络爬虫入门实战解析

网络爬虫简介 网络爬虫&#xff0c;也叫网络蜘蛛(Web?Spider)。它根据网页地址(URL)爬取网页内容&#xff0c;而网页地址(URL)就是我们在浏览器中输入的网站链接。 在浏览器的地址栏输入URL地址&#xff0c;在网页处右键单击&#xff0c;找到检查。(不同浏览器的叫法不同&am…

Python3爬虫概述

爬虫基础 文章目录 爬虫基础爬虫概述Session和Cookie简述1. Session2. Cookie3.关于Session 参考资料 爬虫概述 简单来说&#xff0c;爬虫就是从网页上提取信息并保存的自动化程序。 爬虫程序的工作: 获取网页: 爬虫需要先获取网页信息&#xff0c;即网页源代码进行后续分析。…

python爬虫之

使用BeaufulSoup获取指定class时&#xff0c;结果是将我们所输入的字符串去做模糊匹配&#xff0c;因此会将所有包含的class结果输出&#xff0c;如下图&#xff1a; 但我们所需要的可能是精确匹配的那一条&#xff0c;这个时候更换一下代码即可&#xff1a; web_url http://…

Python3 网络爬虫 <教程全集>

1.1 最简单的爬虫 我的老师&#xff1a;Jack Cui PS&#xff1a;我是通过 看 Jack Cui 老师的文章 学习的爬虫&#xff0c;也为我之后的 爬虫打开了大门。 1.1.1 URL 是什么&#xff1f; 在学习 爬虫之前&#xff0c;我们必须知道 我们 平常 所说的网址&#xff0c;实际上 叫…

爬虫python

一、Urllib 1.什么是互联网爬虫&#xff1f; 如果我们把互联网比作一张大的蜘蛛网&#xff0c;那一台计算机上的数据便是蜘蛛网上的一个猎物&#xff0c;而爬虫程序就是一只小蜘蛛&#xff0c;沿着蜘蛛网抓取自己想要的数据 解释1&#xff1a;通过一个程序&#xff0c;根据Ur…

手把手教你如何入门Python3 网络爬虫

很多朋友学习Python都是先从爬虫开始&#xff0c;其原因不外两方面&#xff1a; 其一Python对爬虫支持度较好&#xff0c;类库众多&#xff0c;其二语法简单&#xff0c;入门容易&#xff0c;所以两者形影相随&#xff0c;不离不弃。 要使用python语言做爬虫&#xff0c;首先需…

python3 爬虫

一.网络爬虫&#xff08;Web Crawler&#xff09; 1.网络爬虫&#xff1a;是一种按照一定的规则&#xff0c;自动地抓取网上信息的程序或者脚本。 2.爬虫&#xff1a;为了获取网上大量的我们能看的到或看不到的数据 3.基本步骤&#xff1a;&#xff08;1&#xff09;定位要爬的…

python 爬虫

Python 爬虫教程(更新中) 目录 1. 简介 2. 注意 3. xpathselenium 4. xpathscarpy&#xff08;更新中&#xff09; 5. icrawler 【借助更加便捷操作的pip包】 1. 简介 爬虫主要有2种方式&#xff1a;API(报文)-静态、模拟鼠标点击形式-动态&#xff1b; Xpath Scrapy(…

【python】python爬虫

爬虫基础 HTTP协议 HTTP是Hyper Text Transfer Protocol&#xff08;超文本传输协议&#xff09;的缩写&#xff0c;是用于从万维网&#xff08;WWW:World Wide Web &#xff09;服务器传输超文本到本地浏览器的传送协议。 HTTP是基于TCP/IP通信协议来传递数据&#xff08;HT…

Python3 网络爬虫(一):初识网络爬虫之夜探老王家(2020年最新版)

一、前言 3年前&#xff0c;我在 csdn 写过 Python3 网络爬虫系列教程&#xff0c;经过三年的积累&#xff0c;累计阅读量近 90W。 同时&#xff0c;我也在 Github 开源了所有 Python3 网络爬虫代码&#xff0c;累积获得 10.3k 的 star&#xff0c;4.1k 的 fork。 可以说&…

Python3 爬虫快速入门攻略

一、什么是网络爬虫&#xff1f; 1、定义&#xff1a;网络爬虫&#xff08;Web Spider&#xff09;&#xff0c;又被称为网页蜘蛛&#xff0c;是一种按照一定的规则&#xff0c;自动地抓取网站信息的程序或者脚本。 2、简介&#xff1a;网络蜘蛛是一个很形象的名字。如果把互…

Python3爬虫(一):Python的入门学习以及Python网络爬虫的初步认识

Author&#xff1a;baiyucraft BLog&#xff1a; baiyucraft’s Home IDE&#xff1a;PyCharm 其实对于Python&#xff0c;一直想去学习&#xff0c;但一直没有足够的的时候去研究&#xff0c;这次趁疫情在家的时间&#xff0c;对于Python好好的研究研究。算是作为自己对于Py…

Python3网络爬虫(一):利用urllib进行简单的网页抓取

运行平台&#xff1a;Windows Python版本&#xff1a;Python3.x IDE&#xff1a;Sublime text3 转载请注明作者和出处&#xff1a;http://blog.csdn.net/c406495762/article/details/58716886 一直想学习Python爬虫的知识&#xff0c;在网上搜索了一下&#xff0c;大部分都是…

python3 爬虫(初试牛刀)

此文章仅供学习交流使用 在学习爬虫之前&#xff0c;把最近对于 VMware 的网络学习做个总结 接下来&#xff0c;步入正题&#xff01; 分析 Robots 协议 禁止所有爬虫访问任何目录的代码&#xff1a; User-agent: * Disallow:/允许所有爬虫访问任何目录的代码&#xff1a; …

Python3爬虫详解

1概述 爬虫在Python中是个实现起来比较简单&#xff0c;关键在于网页的分析和内容的抓取。最近由于个人需要写了些内容&#xff0c;这里总结下爬虫相关的内容。 本文爬虫相关实现没有使用scrapy框架&#xff0c;通过urllib请求、bs4来实现。 2网络请求 网络请求部分用到urlli…

python3爬虫学习

python3爬虫学习 一、爬虫流程&#xff1a; ①先由urllib的request打开Url得到网页html文档 ②浏览器打开网页源代码分析元素节点 ③通过Beautiful Soup或则正则表达式提取想要的数据 ④存储数据到本地磁盘或数据库&#xff08;抓取&#xff0c;分析&#xff0c;存储&…