Python使用海龟绘图实现贪吃蛇游戏


Posted in Python onJune 18, 2021

在实现贪吃蛇游戏时,首先需要使用python内置的turtle模块来实现创建游戏窗体与键盘按键的监听工作,然后使用freegames模块进行贪吃蛇的绘制工作。

1、turtle模块

turtle模块是python的内置模块,所以在使用前需要使用import导入该模块。代码如下:

import turtle

(1) 创建游戏窗体可以使用turtle模块中的setup()方法来实现。语法格式如下:

turtle.setup(width=_CFG["width"],height=_CFG["height"],startx=_CFG["leftright"],starty=_CFG["topbottom"])

参数说明如下:

  • width:表示窗体的宽度,如果是整数,大小以像素为单位,如果是浮动,则为屏幕的一小部分;默认值为屏幕的50%。
  • height:表示窗体的高度,如果是整数,高度以像素为单位,如果是浮动,则为屏幕的一小部分;默认值为屏幕的75%。
  • startx:表示窗体显示在屏幕的横向位置,如果为正,则以像素为单位从屏幕左边缘开始,如果为负,则从右边缘开始,如果没有,则水平居中窗口。
  • starty:表示窗体显示在屏幕的纵向位置,如果为正,则以像素为单位从屏幕上边缘开始,如果为负,则从下边缘开始,如果没有,则垂直居中窗口。

创建游戏窗体的关键代码如下:

import turtle      # 导入绘图海龟模块
turtle.setup(420, 420)      # 创建窗体大小
turtle.done()       # 停止画笔绘制,但绘图窗体不关闭

(2)通过turtle模块中的onkey()方法可以实现对应键盘中按键的监听工作。语法格式如下:

turtle.onkey(fun,key)

参数说明如下:

  • fun:表示需要执行的方法。
  • key:该参数为字符串,表示键盘中对应的按键,例如“a”或“space”。

注意:在使用onkey()方法实现键盘的监听时,还需要调用turtle.listen()方法即可实现键盘按键的监听。

实现键盘中上、下、左、右按键监听工作的关键代码如下:

turtle.listen()                        # 事件监听器
turtle.onkey(lambda: change(10, 0), 'Right')    # 按键盘右键,蛇向右走
turtle.onkey(lambda: change(-10, 0), 'Left')    # 按键盘左键,蛇向左走
turtle.onkey(lambda: change(0, 10), 'Up')       # 按键盘上键,蛇向上走
turtle.onkey(lambda: change(0, -10), 'Down')    # 按键盘下键,蛇向下走

2、freegames模块

freegames模块是第三方模块,所以在使用前需要先通过以下命令进行模块的安装:

pip install freegames

模块安装完成以后,首先需要导入freegames模块中的vector与square函数。代码如下:

from freegames import vector,square  # 导入向量类与绘图函数

(1)通过freegames模块中的vector()类可以根据指定的x、y坐标创建一个二维向量对象。vector()类的语法格式如下:

class freegames.vector(x,y)

参数说明如下:

  • x:表示横向坐标。
  • y:表示纵向坐标。

实现定义游戏中的食物位置、蛇位置以及蛇移动的位置与距离。关键代码如下:

food = vector(0,0)        # 食物
snake = [vector(10, 0)]   # 蛇
position = vector(0, -10) # 移动位置,一步的距离为10

(2)通过freegames模块中square函数可以实现在(x,y)处绘制指定边长大小的正方形,并填充指定颜色。square()函数的语法格式如下:

freegames.square(x,y,size,name)

参数说明如下:

  • x:表示横向坐标。
  • y:表示纵向坐标。
  • size:表示绘制正方形的边长。
  • name:表示填充颜色的名称。

实现绘制游戏中食物、蛇。关键代码如下:

square(body.x, body.y, 9, 'black') # 绘制黑色蛇
square(food.x, food.y, 9, 'green')     # 绘制绿色食物

实例

from random import randrange          # 导入随机函数
from freegames import vector,square  # 导入向量函数与绘图函数
import turtle                         # 导入绘图海龟模块

food = vector(0,0)        # 食物
snake = [vector(10, 0)]   # 蛇
position = vector(0, -10) # 移动位置,一步的距离为10

def change(x, y):        # 改变蛇的移动方向
    position.x = x
    position.y = y

def is_inside(head):        # 判断蛇头是否在窗体内
    return -200 < head.x < 190 and -200 < head.y < 190

def move():                   # 可以让蛇移动的方法
    head = snake[-1].copy()    # 确定蛇头的位置
    head.move(position)        # 移动一步
    if not is_inside(head) or head in snake:   # 如果蛇的头部位于边界外或者蛇头在蛇的身体中
        square(head.x, head.y, 9, 'red')     # 绘制红色蛇头,说明游戏结束
        turtle.update()                      # 更新
        return
    snake.append(head)                       # 更新蛇的位置
    if head == food:                      # 如果蛇吃到食物
        print('Snake:', len(snake))       # 根据蛇的长度进行加分
        food.x = randrange(-15, 15) * 10  # 随机生成食物x坐标
        food.y = randrange(-15, 15) * 10  # 随机生成食物y坐标
    else:
        snake.pop(0)            # 移除蛇走过的坐标
    turtle.clear()              # 清空蛇走过的位置
    for body in snake:          # 循环遍历蛇的坐标
        square(body.x, body.y, 9, 'black') # 绘制黑色蛇
    square(food.x, food.y, 9, 'green')     # 绘制绿色食物
    turtle.update()
    turtle.ontimer(move, 100)           # 定时执行move函数

if __name__ == '__main__':                  # 程序入口
    turtle.setup(420, 420, 370, 0)          # 创建窗体大小
    turtle.hideturtle()                     # 隐藏箭头显示
    turtle.tracer(False)                   # 关闭绘画效果
    move()          # 调用让蛇移动的方法
    turtle.listen()                        # 事件监听器
    turtle.onkey(lambda: change(10, 0), 'Right')    # 按键盘右键,蛇向右走
    turtle.onkey(lambda: change(-10, 0), 'Left')    # 按键盘左键,蛇向左走
    turtle.onkey(lambda: change(0, 10), 'Up')       # 按键盘上键,蛇向上走
    turtle.onkey(lambda: change(0, -10), 'Down')    # 按键盘下键,蛇向下走
    turtle.done()   # 停止画笔绘制,但绘图窗体不关闭

更多关于python游戏的精彩文章请点击查看以下专题:

python俄罗斯方块游戏集合

python经典小游戏汇总

python微信跳一跳游戏集合

更多有趣的经典小游戏实现专题,分享给大家:

C++经典小游戏汇总

JavaScript经典游戏 玩不停

java经典小游戏汇总

javascript经典小游戏汇总

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python动态加载变量示例分享
Feb 17 Python
python中列表元素连接方法join用法实例
Apr 07 Python
Python简单连接MongoDB数据库的方法
Mar 15 Python
对于Python中RawString的理解介绍
Jul 07 Python
对numpy 数组和矩阵的乘法的进一步理解
Apr 04 Python
PyQt5每天必学之单行文本框
Apr 19 Python
Python实现的计算器功能示例
Apr 26 Python
python基于物品协同过滤算法实现代码
May 31 Python
python 以16进制打印输出的方法
Jul 09 Python
python取数作为临时极大值(极小值)的方法
Oct 15 Python
详解python中TCP协议中的粘包问题
Mar 22 Python
Python初学者常见错误详解
Jul 02 Python
Python turtle实现贪吃蛇游戏
python中%格式表达式实例用法
Jun 18 #Python
如何用python清洗文件中的数据
Jun 18 #Python
Python中glob库实现文件名的匹配
python中的装饰器该如何使用
Jun 18 #Python
Python预测分词的实现
学会Python数据可视化必须尝试这7个库
You might like
PHP也可以?成Shell Script
2006/10/09 PHP
PHP+Tidy-完美的XHTML纠错+过滤
2007/04/10 PHP
php防止SQL注入详解及防范
2013/11/12 PHP
一个经典的PHP验证码类分享
2014/11/18 PHP
PHP中使用SimpleXML检查XML文件结构实例
2015/01/07 PHP
php数组去除空值函数分享
2015/02/02 PHP
php使用str_replace替换多维数组的实现方法分析
2017/06/15 PHP
基于jQuery的计算文本框字数的代码
2012/06/06 Javascript
JS 获取select(多选下拉)中所选值的示例代码
2013/08/02 Javascript
jQuery中appendTo()方法用法实例
2015/01/08 Javascript
轻松掌握jQuery中wrap()与unwrap()函数的用法
2016/05/24 Javascript
基于JS实现省市联动效果代码分享
2016/06/06 Javascript
PHP抓取HTTPS内容和错误处理的方法
2016/09/30 Javascript
移动端基础事件总结与应用
2017/01/12 Javascript
Angular 4.x+Ionic3踩坑之Ionic 3.x界面传值详解
2018/03/13 Javascript
ES6 新增的创建数组的方法(小结)
2019/08/01 Javascript
Vue 使用Props属性实现父子组件的动态传值详解
2019/11/13 Javascript
Vue路由的模块自动化与统一加载实现
2020/06/05 Javascript
[02:40]DOTA2殁境神蚀者 英雄基础教程
2013/11/26 DOTA
浅谈Python中数据解析
2015/05/05 Python
python实现自动登录人人网并采集信息的方法
2015/06/28 Python
浅析python中的分片与截断序列
2016/08/09 Python
python subprocess 杀掉全部派生的子进程方法
2017/01/16 Python
python数据处理实战(必看篇)
2017/06/11 Python
Python 3.6 中使用pdfminer解析pdf文件的实现
2019/09/25 Python
解决json中ensure_ascii=False的问题
2020/04/03 Python
Keras实现支持masking的Flatten层代码
2020/06/16 Python
用纯CSS3实现网页中常见的小箭头
2017/10/16 HTML / CSS
linux面试题参考答案(2)
2015/12/06 面试题
自荐书模板
2013/12/15 职场文书
爷爷追悼会答谢词
2014/01/24 职场文书
聘用意向书
2014/07/29 职场文书
一年级班主任工作总结2014
2014/11/08 职场文书
读后感作文评语
2014/12/25 职场文书
推荐六本经典文学奖书籍:此生必读
2019/08/22 职场文书
使用JS前端技术实现静态图片局部流动效果
2022/08/05 Javascript