贪吃蛇的算法还是比较简单的,蛇的移动我是通过不停添加一个head方块,然后判断应该加到蛇头的哪个方向,加完后删掉蛇尾就行了,如果吃到食物就不删蛇尾。

只是一个贪吃蛇只需要70行代码左右就可以了,后来又加了计分,失败后重新游戏,暂停功能····结果现在代码乱成渣了。。

重新游戏部分肯定有更好的方法,我写的太乱了。。求大神指教。由于没用网格,判断吃到的时候是用范围判断的,有时候有些偏差···

代码:

  1 #-*- coding: utf-8 -*-
2 import pygame, sys, random, time
3 from pygame.locals import *
4
5 pygame.init()
6 font = pygame.font.Font(u"c:\\windows\\fonts\\MSYH.ttf",30)
7 mainClock = pygame.time.Clock()
8 wsurface = pygame.display.set_mode((800,600),0,32)
9 pygame.display.set_caption("My_Snake~")
10
11 Len = 20
12 snakeRect = []
13 for i in range(10,13):
14 snakeRect.append(pygame.Rect(i * (Len) , 50 , Len, Len))
15 food = pygame.Rect(10 * (Len), 10 * (Len), Len, Len)
16 ml = False
17 mr = True
18 mu = False
19 md = False
20 score = 0
21 black = (0, 0, 0)
22 green = (0, 255, 0)
23 white = (255, 255, 255)
24 global FPSCLOCK
25 FPSCLOCK = pygame.time.Clock()
26 #####################################################
27 def judge():
28 if snakeRect[0].left - 15 <= food.left <= snakeRect[0].left + 15 and snakeRect[0].top - 15 <= food.top <= snakeRect[0].top + 15:
29 return True
30 def judge2(a, b):
31 if a.left - 15 <= b.left <= a.left + 15 and a.top - 15 <= b.top <= a.top + 15:
32 return True
33 def checkForKeyPress():
34 #checkForQuit()
35 for event in pygame.event.get([KEYDOWN, KEYUP]):
36 if event.type == KEYUP:
37 continue
38 return event.key
39 return None
40 #######################################################
41 flagg = True
42 speed = 8
43 while True:
44 for event in pygame.event.get():
45 if event.type == QUIT:
46 pygame.QUIT()
47 sys.exit()
48 if event.type == KEYDOWN:
49 if event.key == K_r:
50 snakeRect = []
51 for i in range(10,13):
52 snakeRect.append(pygame.Rect(i * (Len) , 50 , Len, Len))
53 food = pygame.Rect(10 * (Len), 10 * (Len), Len, Len)
54 ml = False
55 mr = True
56 mu = False
57 md = False
58 score = 0
59 flagg = True
60 speed = 8
61 if event.key == K_p:
62 wsurface.fill(black)
63 text_surface1 = font.render('Pause!' , True, (0, 0, 255))
64 wsurface.blit(text_surface1, (10, 50))
65 while checkForKeyPress() == None:
66 pygame.display.update()
67 FPSCLOCK.tick()
68 if event.key == K_LEFT and mr == False:
69 ml = True
70 mr = False
71 mu = False
72 md = False
73 if event.key == K_RIGHT and ml == False:
74 ml = False
75 mr = True
76 mu = False
77 md = False
78 if event.key == K_UP and md == False:
79 ml = False
80 mr = False
81 mu = True
82 md = False
83 if event.key == K_DOWN and mu == False:
84 ml = False
85 mr = False
86 mu = False
87 md = True
88 head = pygame.Rect(snakeRect[0].left,snakeRect[0].top,snakeRect[0].width,snakeRect[0].height)
89 if flagg == False:
90 continue
91 if ml == True:
92 head.right = head.left - 1
93 if mr == True:
94 head.left = head.right + 1
95 if mu == True:
96 head.bottom = head.top - 1
97 if md == True:
98 head.top = head.bottom + 1
99 snakeRect.insert(0, head)
100 #判断失败和重新游戏
101 if head.right < 0 or head.left > 800 or head.bottom < 0 or head.top > 600 or snakeRect[0] in snakeRect[1:]:
102 wsurface.fill(white)
103 text_surface2 = font.render('Press R to restart!' , True, (0, 0, 255))
104 wsurface.blit(text_surface2, (50, 80))
105 pygame.display.update()
106 while checkForKeyPress() == None:
107 pygame.display.update()
108 FPSCLOCK.tick()
109 break
110 flagg = False
111 continue
112 flagg = True
113 if judge():
114 score = score + 10
115 speed = speed + 1
116 while True:
117 flag = True
118 food.left = random.randrange(10,800)
119 food.top = random.randrange(10,600)
120 for temp in snakeRect:
121 if judge2(food, temp):
122 flag = False
123 if flag == True:
124 break
125 else:
126 snakeRect.pop()
127 wsurface.fill(black)
128 for i in range(len(snakeRect)):
129 pygame.draw.rect(wsurface,green,snakeRect[i])
130 pygame.draw.rect(wsurface,white,food)
131 text_surface = font.render(u"分数: " + str(score), True, (0, 0, 255))
132 wsurface.blit(text_surface, (10, 50))
133 pygame.display.update()
134 mainClock.tick(speed)
135
136
137
138
139

截图:

python实现贪吃蛇的更多相关文章

  1. 【python】10分钟教你用python打造贪吃蛇超详细教程

    10分钟教你用python打造贪吃蛇超详细教程 在家闲着没妹子约, 刚好最近又学了一下python,听说pygame挺好玩的.今天就在家研究一下, 弄了个贪吃蛇出来.希望大家喜欢. 先看程序效果: 0 ...

  2. 多线程的Python 教程--“贪吃蛇”

    本指南的里代码可以在这里下载:  threadworms.py ,或者从  GitHub.代码需要  Python 3 或 Python 2 ,同时也需要安装  Pygame . 点击查看大版本图片 ...

  3. 一步步教你怎么用python写贪吃蛇游戏

    目录 0 引言 1 环境 2 需求分析 3 代码实现 4 后记 0 引言 前几天,星球有人提到贪吃蛇,一下子就勾起了我的兴趣,毕竟在那个Nokia称霸的年代,这款游戏可是经典中的经典啊!而用Pytho ...

  4. 如何用python制作贪吃蛇以及AI版贪吃蛇

    用python制作普通贪吃蛇 哈喽,大家不知道是上午好还是中午好还是下午好还是晚上好! 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手.很 ...

  5. Python实例:贪吃蛇(简单贪吃蛇编写)🐍

    d=====( ̄▽ ̄*)b 叮~ Python -- 简易贪吃蛇实现 目录: 1.基本原理 2.需要学习的库 3.代码实现 1.基本原理 基本贪吃蛇所需要的东西其实很少,只需要有一块让蛇动的屏幕, 在 ...

  6. 【C/C++】10分钟教你用C++写一个贪吃蛇附带AI功能(附源代码详解和下载)

    C++编写贪吃蛇小游戏快速入门 刚学完C++.一时兴起,就花几天时间手动做了个贪吃蛇,后来觉得不过瘾,于是又加入了AI功能.希望大家Enjoy It. 效果图示 AI模式演示 imageimage 整 ...

  7. 用Python写一个贪吃蛇

    最近在学Python,想做点什么来练练手,命令行的贪吃蛇一般是C的练手项目,但是一时之间找不到别的,就先做个贪吃蛇来练练简单的语法. 由于Python监听键盘很麻烦,没有C语言的kbhit(),所以这 ...

  8. Python制作AI贪吃蛇

    前提:本文实现AI贪吃蛇自行对战,加上人机对战,文章末尾附上源代码以及各位大佬的链接,还有一些实现步骤,读者可再次基础上自行添加电脑VS电脑和玩家VS玩家(其实把人机对战写完,这2个都没什么了,思路都 ...

  9. 如何用Python写一个贪吃蛇AI

    前言 这两天在网上看到一张让人涨姿势的图片,图片中展示的是贪吃蛇游戏, 估计大部分人都玩过.但如果仅仅是贪吃蛇游戏,那么它就没有什么让人涨姿势的地方了. 问题的关键在于,图片中的贪吃蛇真的很贪吃XD, ...

随机推荐

  1. 微信小程序text标签

    最近在做小程序,使用<text>标签的时候发现里面的文本text-family不生效, 经过试验,发现直接在text标签的class设置不生效,可以在外层包一个父元素就可以设置了. < ...

  2. 第30题:LeetCode155. Min Stack最小栈

    设计一个支持 push,pop,top 操作,并能在O(1)时间内检索到最小元素的栈. push(x) -- 将元素 x 推入栈中. pop() -- 删除栈顶的元素. top() -- 获取栈顶元素 ...

  3. D-bus交叉编译

    在嵌入式中如果需要Qt系统支持U盘插拔,则需要Qt支持D-bus. D-bus的交叉编译依赖expat库,此库为XML解析库. 交叉编译expat库: #./configure --host=XXX ...

  4. 5.7 并行复制配置 基于GTID 搭建中从 基于GTID的备份与恢复,同步中断处理

    5.7 并行复制配置 基于GTID 搭建中从 基于GTID的备份与恢复,同步中断处理 这个文章包含三个部分 1:gtid的多线程复制2:同步中断处理3:GTID的备份与恢复 下面文字相关的东西 大部分 ...

  5. Linux入门-第七周

    1.编写脚本实现传入进程PID,查看对应进程/proc下CPU.内存指标. #!/bin/bash read -p "Input PID Value: " pid #读取PID进程 ...

  6. 判断IP连接数前五,并自动加入防火墙

    #!/bin/bash #Author Template #Time -- : log_file=/tmp/tmp.log JudgeExt(){ if expr "$1" : & ...

  7. crontab -e 和/etc/crontab的区别

    /etc/crontab文件和crontab -e命令区别/etc/crontab文件和crontab -e命令区别 1.格式不同 前者 # For details see man 4 crontab ...

  8. JZOJ 3383. 【NOIP2013模拟】太鼓达人

    3383. [NOIP2013模拟]太鼓达人 (Standard IO) Time Limits: 1000 ms  Memory Limits: 131072 KB  Detailed Limits ...

  9. 笔记-python-装饰器

    笔记-python-装饰器 1.  装饰器 装饰器的实质是返回的函数对象的函数,其次返回的函数对象是可以调用的,搞清楚这两点后,装饰器是很容易理解的. 1.1.  相关概念理解 首先,要理解在Pyth ...

  10. Python及其常用模块库下载及安装

    一.Python下载:https://www.python.org/downloads/ 二.Python模块下载:http://www.lfd.uci.edu/~gohlke/pythonlibs/ ...