如何用python做游戏(简单易上手版)【送 源码】

article/2025/8/24 0:37:30

嗨害大家好鸭,我是小熊猫🖤

很多小伙伴后台私信问我说,

“python可以做游戏吗 ?”

“要怎么做呢?”

接下来我就介绍一下,

如何用Python做游戏


有什么python相关报错解答自己不会的、或者源码资料/模块安装/女装大佬精通技巧 都可以来这里:(https://jq.qq.com/?_wv=1027&k=2Q3YTfym)
或者+V:python10010问我

游戏演示截图


2048小游戏

请添加图片描述

表白弹窗

请添加图片描述

贪吃蛇

请添加图片描述

五子棋

请添加图片描述

俄罗斯方块

请添加图片描述

给大家看看我网盘里的代码~

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

更多小游戏可以关注 + 私信 “小游戏” 得源代码哦!!

用PyGame做游戏非常简单,我们今天第一篇文章,让大家实现一个可以在地图上移动的小猪。


基本框架

首先,无论你是做什么游戏,

别管三七二十一,

先把下面这段代码复制粘贴到你的编辑器里面。

所有游戏都需要这几行代码:

###python学习交流群:660193417##3
import pygamedef main():pygame.init()pygame.display.set_caption('Code:小熊猫做的游戏')  # 游戏标题win = pygame.display.set_mode((800, 600))  # 窗口尺寸,宽800高600running = Truewhile running:for event in pygame.event.get():if event.type == pygame.QUIT:  # 点击左上角或者右上角的x关闭窗口时,停止程序running = Falsemain()

运行效果

在这里插入图片描述
加载素材

现在,我们随便找两张图片,

一张作为背景,一张作为主角。

尺寸不用太在意,差不多就可以了,

因为我们可以用代码动态调整。

下面两张图是我随便找的素材,

大家注意图中红框框住的地方,是这两张图片的尺寸。
请添加图片描述

请添加图片描述
我们使用如下代码加载图片:

img_surf = pygame.image.load('图片地址').convert_alpha()

其中的.convert_alpha()是保留 png 图片的透明背景。

如果你加载的图片不 png 图片,可以把convert_alpha()改成convert()。

如果要修改图片尺寸,使用如下代码:

img_surf = pygame.transform.scale(img_surf, (,))

要把图片显示在窗口中,使用下面两行代码:

win.blit(素材对象, (素材左上角的横坐标, 素材左上角的纵坐标))
pygame.display.flip()

完整代码

###python学习交流群:660193417###
import pygamedef main():pygame.init()pygame.display.set_caption('Code:小熊猫做的游戏')  # 游戏标题win = pygame.display.set_mode((800, 600))  # 窗口尺寸bg_small = pygame.image.load('bg.png').convert_alpha()bg_big = pygame.transform.scale(bg_small, (800, 600))pig = pygame.image.load('pig_in_car.png').convert_alpha()running = Truewhile running:for event in pygame.event.get():if event.type == pygame.QUIT:  # 点击左上角或者右上角的x关闭窗口时,停止程序running = Falsewin.blit(bg_big, (0, 0))  # 背景图最先加载,坐标是(left, top)win.blit(pig, (200, 300))pygame.display.flip()main()

运行效果

在这里插入图片描述
需要注意的是,

win.blit和pygame.display.flip()都要放到while循环里面。

其中win.blit的第一个参数是我们刚刚加载的素材对象。

第二个参数是一个元组,

标记这个图片左上角在画布上面的坐标。

整个画布左上角对应坐标(0, 0)。

由于背景图的尺寸也是(800, 600),

所以背景图的左上角放到(0, 0),就刚好可以铺满整个画布。

哪里找素材?

我们做的是一个像素风格的游戏,

可以到itch.io上面找素材:

请添加图片描述
这个网站提高了大量的游戏素材,

并且绝大部分素材,

在个人非商业用途的情况下是免费的。

你找到自己喜欢的素材以后,

就可以直接下载,

整个过程你甚至都不需要登录(比国内的垃圾素材网站可良心多了)。

怎么我的素材长这样?

你下载了素材以后,

可能会发现一件非常奇怪的事情,

怎么素材全部画在一张图上?

请添加图片描述
请添加图片描述
实际上,这就是业界惯例,

做素材的人会把每一类素材排列到一张图片上,

你要用的时候,需要自己去裁剪。

例如所有植物放在一张图上,

所有雕像放在一张图上,

地基贴图也放在一张图上。

上面我们演示用的背景图,初看起来是一张绿色的图,

但是它实际上包含了多个地基元素,

请注意我用红框框住的部分:
请添加图片描述
在正式游戏中,

我们要把每一个基本元素拆出来,

重新组合起来使用。

重组的时候,有些元素要复制多份重复使用,

有些元素要旋转缩放。

最终组合成下面这样看起来好看的地图:

请添加图片描述
一般来说,像素风格的素材,

尺寸大多是16x16,32x32,64x64,128x128。

素材作者正常情况下会提供裁剪说明。

如果没有提供的话,你也可以肉眼观察,然后猜一猜。

例如我要从雕像素材里面剪切出红框框住的女神像:

请添加图片描述
那么,我可以这样写代码:

img_surf = pygame.image.load('雕像素材.png').convert_alpha()
goddess= img_surf.subsurface(( 女神像左上角的横坐标 , 女神像左上角的纵坐标, 女神像的宽, 女神像的高))

运行效果如下图所示:
在这里插入图片描述
可能有同学问:为什么女神的坐标是这样的呢?

我只能说,这个坐标是我试了很多次,试出来的。

使用小精灵来管理对象

除了背景图,我们添加的每一个元素都是一个对象,

例如上面的小猪和女神像。

原则上来讲,上面的代码就足够让你把游戏做得漂亮了,

想加什么东西,就不停加载图片素材,

然后放到合适的位置就可以了。

但我们可以使用面向对象的设计方法,

让代码更容易维护,也更简单。

PyGame 里面,有一个类叫做Sprite,

我们可以为每一个对象实现一个类,继承Sprite,

然后把对象的素材设置成.surf属性,

把对象的位置设置为.rect属性。

例如上面的代码,我们修改一下:

import pygameclass Bg(pygame.sprite.Sprite):def __init__(self):super(Bg, self).__init__()bg_small = pygame.image.load('bg.png').convert_alpha()grass_land = bg_small.subsurface((0, 0, 128, 128))self.surf = pygame.transform.scale(grass_land, (800, 600))self.rect = self.surf.get_rect(left=0, top=0)  # 左上角定位class Pig(pygame.sprite.Sprite):def __init__(self):super(Pig, self).__init__()self.surf = pygame.image.load('pig_in_car.png').convert_alpha()self.rect = self.surf.get_rect(center=(400, 300))  # 中心定位class Goddess(pygame.sprite.Sprite):def __init__(self):super(Goddess, self).__init__()building = pygame.image.load('building.png').convert_alpha()self.surf = building.subsurface(((7 * 64 - 10, 0, 50, 100)))self.rect = self.surf.get_rect(center=(500, 430))  # 女神像的中心放到画布(500, 430)的位置def main():pygame.init()pygame.display.set_caption('未闻Code:青南做的游戏')  # 游戏标题win = pygame.display.set_mode((800, 600))  # 窗口尺寸bg = Bg()goddess = Goddess()pig = Pig()all_sprites = [bg, goddess, pig]  # 注意添加顺序,后添加的对象图层在先添加的对象的图层上面running = Truewhile running:for event in pygame.event.get():if event.type == pygame.QUIT:  # 点击左上角或者右上角的x关闭窗口时,停止程序running = Falsefor sprite in all_sprites:win.blit(sprite.surf, sprite.rect)pygame.display.flip()if __name__ == '__main__':main()

运行效果如下图所示:
在这里插入图片描述
注意代码中的all_sprites = [bg, goddess, pig],

这里我使用的是列表。

后面会有更高级的数据结构SpriteGroup来储存他们。

今天使用列表就足够了

素材对象.get_rect()会返回一个坐标定位对象,这个对象有多个属性,例如.left, .top, .center, .width, .height。

在不传参数的情况下,默认.left=0, .top=0,PyGame会自动根据这个对象的尺寸计算.width,.height和.center。我们可以通过传入参数的形式主动设定。

当你设定左上角的时候,它自动就能算出中心点的坐标;当你传入中心坐标的时候,它自动就能算出左上角的坐标。

理论上来讲,在每个类里面,素材对象可以用任何名字,不一定要用.surf。

坐标定位对象也不一定要用.rect,只要你在win.blit的时候对应起来就可以了。

但是如果你统一使用.surf和.rect会给你带来很多好处。这一点我们到物体碰撞那个地方再讲。因此我建议你就使用这两个名字。

让小猪动起来

既然是游戏,那肯定要按键盘让主角动起来。否则跟一幅画有什么区别呢?

大家注意main()函数里面的while running这个循环,如果你在循环里面加上一行代码:print(111),你会发现当你运行这个游戏的时候,111会一直不停的打印出来。

PyGame 本质上,就是通过win.blit不停地画图,由于这个while循环每秒要运行很多次,如果每次运行的时候,我们让win.blit的第二个参数,也就是素材对象的坐标有细微的差异,那么在人眼看起来,这个素材对象就在运动了。

我们的目标是按住键盘的上下左右方向键,小猪向 4 个不同的方向移动。

在 PyGame 里面,获得键盘按住不放的键,使用如下代码实现:

keys = pygame.key.get_pressed()

它返回的是一个长得像列表的对象(但不是列表),

当我们要判断某个键是否被按下的时候,

只需要判断if keys[想要判断的键],如果返回True,

说明被按住了。基于这个原理,我们来写两段代码。

首先修改Pig类,新增一个.update方法:

class Pig(pygame.sprite.Sprite):def __init__(self):super(Pig, self).__init__()self.surf = pygame.image.load('pig_in_car.png').convert_alpha()self.rect = self.surf.get_rect(center=(400, 300))  # 中心定位def update(self, keys):if keys[pygame.K_LEFT]:self.rect.move_ip((-5, 0))  # 横坐标向左elif keys[pygame.K_RIGHT]:self.rect.move_ip((5, 0))  # 横坐标向右elif keys[pygame.K_UP]:self.rect.move_ip((0, -5))  #纵坐标向上elif keys[pygame.K_DOWN]:self.rect.move_ip((0, 5))  # 纵坐标向下# 防止小猪跑到屏幕外面if self.rect.left < 0:self.rect.left = 0if self.rect.right > 800:self.rect.right = 800if self.rect.top < 0:self.rect.top = 0if self.rect.bottom > 600:self.rect.bottom = 600

.update方法接收一个参数keys,

就是我们按键返回的长得像列表的对象。

然后判断是哪个方向键被按下了。

根据被按下的键,.rect坐标定位对象修改相应方向的值。

rect.move_ip这里的ip是inplace的简写,也就是修改.rect这个属性自身。

它的参数是一个元组,对应横坐标和纵坐标。横纵坐标小于 0 表示向左或者向上,大于 0 表示向右或者向下。

原来的main()函数只需要在win.blit之前增加两行代码:

keys = pygame.key.get_pressed()
pig.update(keys)

完整代码如下:

import pygameclass Bg(pygame.sprite.Sprite):def __init__(self):super(Bg, self).__init__()bg_small = pygame.image.load('bg.png').convert_alpha()grass_land = bg_small.subsurface((0, 0, 128, 128))self.surf = pygame.transform.scale(grass_land, (800, 600))self.rect = self.surf.get_rect(left=0, top=0)  # 左上角定位class Pig(pygame.sprite.Sprite):def __init__(self):super(Pig, self).__init__()self.surf = pygame.image.load('pig_in_car.png').convert_alpha()self.rect = self.surf.get_rect(center=(400, 300))  # 中心定位def update(self, keys):if keys[pygame.K_LEFT]:self.rect.move_ip((-5, 0))elif keys[pygame.K_RIGHT]:self.rect.move_ip((5, 0))elif keys[pygame.K_UP]:self.rect.move_ip((0, -5))elif keys[pygame.K_DOWN]:self.rect.move_ip((0, 5))# 防止小猪跑到屏幕外面if self.rect.left < 0:self.rect.left = 0if self.rect.right > 800:self.rect.right = 800if self.rect.top < 0:self.rect.top = 0if self.rect.bottom > 600:self.rect.bottom = 600class Goddess(pygame.sprite.Sprite):def __init__(self):super(Goddess, self).__init__()building = pygame.image.load('building.png').convert_alpha()self.surf = building.subsurface(((7 * 64 - 10, 0, 50, 100)))self.rect = self.surf.get_rect(center=(500, 430))  # 女神像的中心放到画布(500, 430)的位置def main():pygame.init()pygame.display.set_caption('未闻Code:青南做的游戏')  # 游戏标题win = pygame.display.set_mode((800, 600))  # 窗口尺寸bg = Bg()goddess = Goddess()pig = Pig()all_sprites = [bg, goddess, pig]  # 注意添加顺序,后添加的对象图层在先添加的对象的图层上面running = Truewhile running:for event in pygame.event.get():if event.type == pygame.QUIT:  # 点击左上角或者右上角的x关闭窗口时,停止程序running = Falsekeys = pygame.key.get_pressed()pig.update(keys)for sprite in all_sprites:win.blit(sprite.surf, sprite.rect)pygame.display.flip()if __name__ == '__main__':main()

最后的运行效果如图所示:
在这里插入图片描述

总结

PyGame 做游戏真的非常简单,

只要会加载素材,就能做出一个还能看得过去的游戏。

今天我们学会了怎么添加素材,怎么捕获键盘事件。

PyGame 可以读取 Gif 图片,

但是你会发现加载进来以后,Gif 不会动。


请添加图片描述

感觉还是很简单的哈~

今天的文章就是这样啦~

我是小熊猫,咱下篇文章再见(✿◡‿◡)

在这里插入图片描述


http://chatgpt.dhexx.cn/article/2x3b0PSs.shtml

相关文章

python小游戏-移动木板

文章目录 一、游戏简介二、编写步骤1.引入库2.初始化3.相关自定义函数4.相关自定义函数 一、游戏简介 本游戏是通过python编写的小游戏&#xff0c;给初学者熟悉python编程语言抛砖引玉&#xff0c;希望有所帮助。 成型的效果图如下&#xff1a; 二、编写步骤 1.引入库 代码…

UDP over Socks5 实现全局透明代理

Socks5代理协议很强大&#xff0c;不光可以实现HTTP/HTTPS代理的TCP隧道代理功能&#xff0c;类似connect&#xff0c;还可以实现HTTP代理不能做到的UDP代理功能。 要知道UDP代理的重要过程&#xff0c;以方便我们排查错误&#xff0c;我们还需要了解Socks5协议对UDP代理方式的…

阿里P7测开岗大手子手把手教你【软件测试秘籍】

本人阿里CTO线测试开发岗&#xff0c;入职阿里系已有两年&#xff0c;从事软件测试岗位五年有余。双非一本计算机系出身&#xff0c;大佬说不上&#xff0c;今天跟学弟学妹分享一下我这几年的学习软件测试心得。 一、 熟练使用SQL 常用的 sql 语句一定会写。比如说增删改查之类…

软件测试人员必备的60个测试工具清单,建议收藏一波~

据统计&#xff0c;中国软件外包市场的潜力和机会已远远超过软件王国印度&#xff0c;不过由于软件人才的严重不足致使我国软件发展遭遇“瓶颈”。国家为了大力培养软件人才&#xff0c;不断采取积极有效的措施。我国对软件测试人才的需求数量还将持续增加&#xff0c;因此软件…

软件测试精华总结,入门到精通全流程(必看,知识点很全)

软件测试基础 软件测试的概念 通过一系列手段去证明软件是符合用户需求的,满足质量要求的。预期结果和实际结果的一个对比。 软件测试分类 按方法分:黑盒测试、白盒测试、灰盒测试 黑盒测试:把软件比作一个“黑匣子”,不考虑具体是内部是如何实现的,只考虑外部功能的运行…

400 页共计 800 道软件测试面试真题汇总,2022年吐血整理

800 道软件测试面试真题&#xff0c;高清打印版打包带走&#xff0c;横扫软件测试面试高频问题&#xff0c;涵盖测试理论、Linux、MySQL、Web 测试、接口测试、App 测试、Python、Selenium、性能测试、LordRunner、计算机网络、数据结构与算法、逻辑思维、人力资源等模块面试题…

软件测试人员必备的60个测试工具清单,果断收藏了!

前言 据统计&#xff0c;中国软件外包市场的潜力和机会已远远超过软件王国印度&#xff0c;不过由于软件人才的严重不足致使我国软件发展遭遇“瓶颈”。国家为了大力培养软件人才&#xff0c;不断采取积极有效的措施。我国对软件测试人才的需求数量还将持续增加&#xff0c;因…

软件测试面试题集(含答案)

软件测试面试题集 一、Bug基本要素 缺陷ID&#xff0c;状态&#xff0c;类型&#xff0c;所属项目&#xff0c;所属模块&#xff0c;缺陷提交时间&#xff0c;缺陷提交人&#xff08;检测者&#xff09;&#xff0c;严重程度&#xff0c;优先级别&#xff0c;缺陷描述信息&…

常用的软件测试工具清单,建议收藏。

常用的测试工具有10类&#xff1a; 1.测试管理工具 2.接口测试工具 3.性能测试工具 4.C/S自动化工具 5.白盒测试工具 6.代码扫描工具 7.持续集成工具 8.网络测试工具 9.app自动化工具 10.web安全测试工具 1.测试管理工具 1&#xff0c;TestDirector(大而全) 2&…

什么是软件测试,软件测试究竟是做什么的

我犹豫了很久&#xff0c;想来想去还是写了一篇文章&#xff0c;这篇文章可以告诉你什么是软件测试&#xff1f; 来看看官方的回答&#xff1a; 软件测试(英语&#xff1a;Software Testing)&#xff0c;描述一种用来促进鉴定软件的正确性、完整性、安全性和质量的过程。换句话…

swiper自定义分页器使用

解决问题&#xff1a;不想使用swiper的自带的圆钮式的分页器&#xff0c;想使用自定义的分页器。 解决方案&#xff1a;利用swiper提供的paginationCustomRender()方法&#xff08;自定义特殊类型分页器&#xff0c;当分页器类型设置为自定义时可用。&#xff09; 下面的代码可…

element-ui 分页器的使用

1. ui组件 1.在element-ui找到Paginaion分页器 打开代码拷贝第四个组件 2. 在vue template里写 //分页区 <el-pagination size-change"handleSizeChange" current-change"handleCurrentChange":current-page"queryInfo.pagenum" :page-size…

分页器的使用-1 自己找的分页器插件

这个插件是自己网上找的&#xff0c;具体代码如下&#xff1a; 具体步骤&#xff1a;1. 先引入css和js2. 分页器放在请求成功之后&#xff0c;3. 最重要的中间件就是currentPage&#xff1a;当前页码。4. 具体代码详情都在里面写清楚了。用到的js文件&#xff1a; https://pa…

vue实战-分页器

vue实战-分页器 1.分页器静态组件 因为是公共全局组件&#xff0c;在components里新建文件夹Pagination&#xff0c;并将分页器的静态组件填入 静态组件 <template><div class"pagination"><button>1</button><button>上一页</b…

html分页器的实现原理,js分页器详解

本文主要和大家分享js分页器详解,我们先来看一下效果,希望能帮助到大家。 依赖于:bootstrap 和 jquery html代码:通过class="pj_pager"引用,pj_total初始化总条数 js代码:/** * 分页器,依赖于bootstrap,jquery */ var pager = {init : function(r) {this.obj …

JavaScript--Swiper自定义分页器

图片是以背景显示的&#xff0c;图片上有一层遮罩&#xff0c;最上面是文字。分页器激活状态下是自定义的图片。代码比较容易进行删改&#xff0c;比如不想要遮罩或者文字可以直接删掉。 分页器的效果&#xff1a; html <!DOCTYPE html> <html lang"en"…

快速实现-简单分页器(上)

首先形形色色的分页器大家肯定都看过,这一次就快速实现一个简单的分页器,应该不会耽搁太久吧~ 先来看一下简洁布局: 瞜一眼这布局: 页码数量总共只有9个当足够显示所有页码的情况就全部显示了那么问题来了,如果不够呢? 第一种情况 第二种情况 第三种情况

完整分页器最骚的讲解(亲测)

咱也不敢问&#xff0c;咱也不敢说。先来个图瞅瞅分页器是个什么鬼叭 就目前来讲&#xff0c;这应该算是功能最全的分页器啦吧 下面我们一步一步研究一下这玩意怎么玩叭 啥也不说了&#xff0c;先去element-ui官网嫖代码吧哈哈哈 <el-paginationsize-change"handleS…

用vue封装分页器,让你的页面简单而不失优雅

前言 当我们在开发 web 应用时&#xff0c;经常需要对大量数据进行分页展示&#xff0c;这时候用到的就是分页器。element 是一款流行的前端 ui 框架&#xff0c;它提供了许多有用的工具和组件&#xff0c;其中就包括分页器组件。在本文中&#xff0c;我们将学习如何使用 vue 基…

js分页器

写分页器的时候引用别人的js总是不能达到自己想要的效果&#xff0c;在这里记录下自制分页器的历程 html部分 <!DOCTYPE html> <html> <head><title></title><meta charset"utf-8" /><script src"https://code.jquery…