100行python代码完成贪吃蛇小游戏,附上源码
ztj100 2024-10-29 18:21 15 浏览 0 评论
大家小时候都玩过贪吃蛇吧?小编小时候可喜欢拿爸妈的手机玩了,厉害着呢!今天,小编就来用100行代码实现一个简易版的贪吃蛇。在网上,贪吃蛇教程蛮多的,但要安装蛮多库的,而且也不够清晰,今天的代码比较短,而且理解起来或者说你更改起来要简单一些。最终会实现效果如下:
基本准备
首先,我们需要安装pygame库,小编通过pip install pygame,很快就安装好了。在完成贪吃蛇小游戏的时候,我们需要知道整个游戏分为四部分:
- 游戏显示:游戏界面、结束界面
- 贪吃蛇:头部、身体、食物判断、死亡判断
- 树莓:随机生成
- 按键控制:上、下、左、右
游戏显示
首先,我们来初始化pygame,定义颜色、游戏界面的窗口大小、标题和图标等。
1# 初始化pygame
2pygame.init()
3fpsClock = pygame.time.Clock()
4# 创建pygame显示层
5playSurface = pygame.display.set_mode((600,460))#窗口大小
6pygame.display.set_caption('Snake Game')#窗口名称
7# 定义颜色变量
8redColour = pygame.Color(255,0,0)
9blackColour = pygame.Color(0,0,0)
10whiteColour = pygame.Color(255,255,255)
11greyColour = pygame.Color(150,150,150)
游戏结束界面,我们会显示“Game Over!”和该局游戏所得分数,相关代码如下:
1# 定义gameOver函数
2def gameOver(playSurface,score):
3 gameOverFont = pygame.font.SysFont('arial.ttf',54) #游戏结束字体和大小
4 gameOverSurf = gameOverFont.render('Game Over!', True, greyColour) #游戏结束内容显示
5 gameOverRect = gameOverSurf.get_rect()
6 gameOverRect.midtop = (300, 10) #显示位置
7 playSurface.blit(gameOverSurf, gameOverRect)
8 scoreFont = pygame.font.SysFont('arial.ttf',54) #得分情况显示
9 scoreSurf = scoreFont.render('Score:'+str(score), True, greyColour)
10 scoreRect = scoreSurf.get_rect()
11 scoreRect.midtop = (300, 50)
12 playSurface.blit(scoreSurf, scoreRect)
13 pygame.display.flip() #刷新显示界面
14 time.sleep(5) #休眠五秒钟自动退出界面
15 pygame.quit()
16 sys.exit()
贪吃蛇和树莓
我们需要将整个界面看成许多20*20的小方块,每个方块代表一个单位,蛇的长度用单位来表示,同时我们采用列表的形式存储蛇的身体。同时,我们都知道,树莓的位置是随机的。所以,我们需要让树莓出现的位置是游戏界面中的随机位置,同时,每吃到一颗树莓,就需要重新生成一颗新的树莓,并且得分加1。相关初始化设置如下:
1snakePosition = [100,100] #贪吃蛇 蛇头的位置
2snakeSegments = [[100,100]] #贪吃蛇 蛇的身体,初始为一个单位
3raspberryPosition = [300,300] #树莓的初始位置
4raspberrySpawned = 1 #树莓的个数为1
5direction = 'right' #初始方向为右
6changeDirection = direction
7score = 0 #初始得分
其实做为一个开发者,有一个学习的氛围跟一个交流圈子是一个特别重要的事情,这里我创建了一个python交流群12546470,不管你是小白还是大牛欢迎入驻,大家一起交流成长。
如何控制贪吃蛇的运动轨迹呢,那么就需要按键控制了。我们通过键盘的↑↓←→和WSAD来控制,如果想直接退出游戏,则可以通过Esc键。这里需要强调的是,贪吃蛇里面是不能反方向运动,因此,我们需要进一步的增加限制条件:
1# 检测例如按键等pygame事件
2for event in pygame.event.get():
3 if event.type == QUIT:
4 pygame.quit()
5 sys.exit()
6 elif event.type == KEYDOWN:
7 # 判断键盘事件
8 if event.key == K_RIGHT or event.key == ord('d'):
9 changeDirection = 'right'
10 if event.key == K_LEFT or event.key == ord('a'):
11 changeDirection = 'left'
12 if event.key == K_UP or event.key == ord('w'):
13 changeDirection = 'up'
14 if event.key == K_DOWN or event.key == ord('s'):
15 changeDirection = 'down'
16 if event.key == K_ESCAPE:
17 pygame.event.post(pygame.event.Event(QUIT))
18# 判断是否输入了反方向
19if changeDirection == 'right' and not direction == 'left':
20 direction = changeDirection
21if changeDirection == 'left' and not direction == 'right':
22 direction = changeDirection
23if changeDirection == 'up' and not direction == 'down':
24 direction = changeDirection
25if changeDirection == 'down' and not direction == 'up':
26 direction = changeDirection
方向设置好了,那么贪吃蛇蛇身变换怎么做啊?很简单,我们只需要根据方向变换一下坐标即可。
1# 根据方向移动蛇头的坐标
2if direction == 'right':
3 snakePosition[0] += 20
4if direction == 'left':
5 snakePosition[0] -= 20
6if direction == 'up':
7 snakePosition[1] -= 20
8if direction == 'down':
9 snakePosition[1] += 20
10# 增加蛇的长度
11snakeSegments.insert(0,list(snakePosition))
贪吃蛇游戏里面最重要的就是食物判断和死亡判断。首先是食物判断,我们通过键盘按键来决定贪吃蛇的走向,以便它能吃到树莓。如何判断贪吃蛇有没有吃到树莓呢?很简单,如果贪吃蛇蛇头的位置和树莓的位置重合了,也就是相同,那么贪吃蛇就吃到树莓了,否则没有。同时,一旦发生了树莓被吃的情况,立刻重新随机生成一个新的树莓。相关代码如下:
1# 判断是否吃掉了树莓
2if snakePosition[0] == raspberryPosition[0] and snakePosition[1] == raspberryPosition[1]:
3 raspberrySpawned = 0
4 else:
5 snakeSegments.pop() #若没有吃掉树莓,需将最后一单位的蛇身提出列表,此处和蛇身移动时位置变换有关
6# 如果吃掉树莓,则重新生成树莓
7if raspberrySpawned == 0:
8 x = random.randrange(1,30) #和游戏界面大小相关
9 y = random.randrange(1,23)
10 raspberryPosition = [int(x*20),int(y*20)]
11 raspberrySpawned = 1
12 score += 1
死亡判断则分为两类情况,一是触碰到了游戏界面的边界,二是贪吃蛇触碰到了自己的身体。一旦发生死亡,则触发gameover。
1# 判断是否死亡
2if snakePosition[0] > 600 or snakePosition[0] < 0: #若超过左右边界,触发gameover
3 gameOver(playSurface,score)
4if snakePosition[1] > 460 or snakePosition[1] < 0: #若超过上下边界,触发gameover
5 gameOver(playSurface,score)
6for snakeBody in snakeSegments[1:]: #若触碰到自己的身体,触发gameover
7 if snakePosition[0] == snakeBody[0] and snakePosition[1] == snakeBody[1]:
8 gameOver(playSurface,score)
贪吃蛇运动和吃掉树莓的过程中,游戏界面需要不断更新。同时,我们设置了游戏速度。
1# 绘制pygame显示层
2playSurface.fill(blackColour) #蛇身为白色
3for position in snakeSegments:
4 pygame.draw.rect(playSurface,whiteColour,Rect(position[0],position[1],20,20))
5 pygame.draw.rect(playSurface,redColour,Rect(raspberryPosition[0], raspberryPosition[1],20,20))
6
7# 刷新pygame显示层
8pygame.display.flip()
9# 控制游戏速度
10fpsClock.tick(5)
来源于DataGo数据狗 ,作者胡萝卜酱
相关推荐
- 如何将数据仓库迁移到阿里云 AnalyticDB for PostgreSQL
-
阿里云AnalyticDBforPostgreSQL(以下简称ADBPG,即原HybridDBforPostgreSQL)为基于PostgreSQL内核的MPP架构的实时数据仓库服务,可以...
- Python数据分析:探索性分析
-
写在前面如果你忘记了前面的文章,可以看看加深印象:Python数据处理...
- C++基础语法梳理:算法丨十大排序算法(二)
-
本期是C++基础语法分享的第十六节,今天给大家来梳理一下十大排序算法后五个!归并排序...
- C 语言的标准库有哪些
-
C语言的标准库并不是一个单一的实体,而是由一系列头文件(headerfiles)组成的集合。每个头文件声明了一组相关的函数、宏、类型和常量。程序员通过在代码中使用#include<...
- [深度学习] ncnn安装和调用基础教程
-
1介绍ncnn是腾讯开发的一个为手机端极致优化的高性能神经网络前向计算框架,无第三方依赖,跨平台,但是通常都需要protobuf和opencv。ncnn目前已在腾讯多款应用中使用,如QQ,Qzon...
- 用rust实现经典的冒泡排序和快速排序
-
1.假设待排序数组如下letmutarr=[5,3,8,4,2,7,1];...
- ncnn+PPYOLOv2首次结合!全网最详细代码解读来了
-
编辑:好困LRS【新智元导读】今天给大家安利一个宝藏仓库miemiedetection,该仓库集合了PPYOLO、PPYOLOv2、PPYOLOE三个算法pytorch实现三合一,其中的PPYOL...
- C++特性使用建议
-
1.引用参数使用引用替代指针且所有不变的引用参数必须加上const。在C语言中,如果函数需要修改变量的值,参数必须为指针,如...
- Qt4/5升级到Qt6吐血经验总结V202308
-
00:直观总结增加了很多轮子,同时原有模块拆分的也更细致,估计为了方便拓展个管理。把一些过度封装的东西移除了(比如同样的功能有多个函数),保证了只有一个函数执行该功能。把一些Qt5中兼容Qt4的方法废...
- 到底什么是C++11新特性,请看下文
-
C++11是一个比较大的更新,引入了很多新特性,以下是对这些特性的详细解释,帮助您快速理解C++11的内容1.自动类型推导(auto和decltype)...
- 掌握C++11这些特性,代码简洁性、安全性和性能轻松跃升!
-
C++11(又称C++0x)是C++编程语言的一次重大更新,引入了许多新特性,显著提升了代码简洁性、安全性和性能。以下是主要特性的分类介绍及示例:一、核心语言特性1.自动类型推导(auto)编译器自...
- 经典算法——凸包算法
-
凸包算法(ConvexHull)一、概念与问题描述凸包是指在平面上给定一组点,找到包含这些点的最小面积或最小周长的凸多边形。这个多边形没有任何内凹部分,即从一个多边形内的任意一点画一条线到多边形边界...
- 一起学习c++11——c++11中的新增的容器
-
c++11新增的容器1:array当时的初衷是希望提供一个在栈上分配的,定长数组,而且可以使用stl中的模板算法。array的用法如下:#include<string>#includ...
- C++ 编程中的一些最佳实践
-
1.遵循代码简洁原则尽量避免冗余代码,通过模块化设计、清晰的命名和良好的结构,让代码更易于阅读和维护...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- node卸载 (33)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- exceptionininitializererror (33)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)