前言

今天为大家带来解闷用的过迷宫小游戏分享给大家好了。让我们愉快地开始吧~

效果展示

开发工具

Python版本: 3.6.4

相关模块:

pygame模块;

以及一些Python自带的模块。

环境搭建

安装Python并添加到环境变量,pip安装需要的相关模块即可。

原理简介

游戏规则:

玩家通过↑↓←→键控制主角行动,使主角从出发点(左上角)绕出迷宫,到达终点(右下角)即为游戏胜利。

逐步实现:

首先,当然是创建迷宫啦,为了方便,这里采用随机生成迷宫的方式(人工设计真的费眼睛,弄到一半不想弄了,有兴趣的可以自行尝试。)。思路其实很简单,就是把游戏界面划分成多个cell,类似这样子:

然后设计算法遍历所有的cell,每个被遍历到的cell在某几个随机的方向上打开一堵墙(就是去掉分割cell的线条)就ok啦~所以想学的同学,有必要听一下这位老师的课、领取python福利奥,想学的同学可以到梦雅老师的围鑫(同音):前排的是:762,中间一排是:459,后排的一组是:510 ,把以上三组字母按照顺序组合起来即可,她会安排学习的。

具体而言,代码实现如下:

'''随机生成迷宫类'''
class RandomMaze():def __init__(self, maze_size, block_size, border_size, **kwargs):self.block_size = block_sizeself.border_size = border_sizeself.maze_size = maze_sizeself.blocks_list = RandomMaze.createMaze(maze_size, block_size, border_size)self.font = pygame.font.SysFont('Consolas', 15)'''画到屏幕上'''def draw(self, screen):for row in range(self.maze_size[0]):for col in range(self.maze_size[1]):self.blocks_list[row][col].draw(screen)# 起点和终点标志showText(screen, self.font, 'S', (255, 0, 0), (self.border_size[0]-10, self.border_size[1]))showText(screen, self.font, 'D', (255, 0, 0), (self.border_size[0]+(self.maze_size[1]-1)*self.block_size, self.border_size[1]+self.maze_size[0]*self.block_size+5))'''创建迷宫'''@staticmethoddef createMaze(maze_size, block_size, border_size):def nextBlock(block_now, blocks_list):directions = ['top', 'bottom', 'left', 'right']blocks_around = dict(zip(directions, [None]*4))block_next = Nonecount = 0# 查看上边blockif block_now.coordinate[1]-1 >= 0:block_now_top = blocks_list[block_now.coordinate[1]-1][block_now.coordinate[0]]if not block_now_top.is_visited:blocks_around['top'] = block_now_topcount += 1# 查看下边blockif block_now.coordinate[1]+1 < maze_size[0]:block_now_bottom = blocks_list[block_now.coordinate[1]+1][block_now.coordinate[0]]if not block_now_bottom.is_visited:blocks_around['bottom'] = block_now_bottomcount += 1# 查看左边blockif block_now.coordinate[0]-1 >= 0:block_now_left = blocks_list[block_now.coordinate[1]][block_now.coordinate[0]-1]if not block_now_left.is_visited:blocks_around['left'] = block_now_leftcount += 1# 查看右边blockif block_now.coordinate[0]+1 < maze_size[1]:block_now_right = blocks_list[block_now.coordinate[1]][block_now.coordinate[0]+1]if not block_now_right.is_visited:blocks_around['right'] = block_now_rightcount += 1if count > 0:while True:direction = random.choice(directions)if blocks_around.get(direction):block_next = blocks_around.get(direction)if direction == 'top':block_next.has_walls[1] = Falseblock_now.has_walls[0] = Falseelif direction == 'bottom':block_next.has_walls[0] = Falseblock_now.has_walls[1] = Falseelif direction == 'left':block_next.has_walls[3] = Falseblock_now.has_walls[2] = Falseelif direction == 'right':block_next.has_walls[2] = Falseblock_now.has_walls[3] = Falsebreakreturn block_nextblocks_list = [[Block([col, row], block_size, border_size) for col in range(maze_size[1])] for row in range(maze_size[0])]block_now = blocks_list[0][0]records = []while True:if block_now:if not block_now.is_visited:block_now.is_visited = Truerecords.append(block_now)block_now = nextBlock(block_now, blocks_list)else:block_now = records.pop()if len(records) == 0:breakreturn blocks_list```
接下来就是定义角色类啦,角色类需要根据用户的操作进行上下左右的移动,同时,保证移动是不能跨越墙的就OK了~具体而言,代码实现如下:```python
'''定义hero'''
class Hero(pygame.sprite.Sprite):def __init__(self, imagepath, coordinate, block_size, border_size, **kwargs):pygame.sprite.Sprite.__init__(self)self.image = pygame.image.load(imagepath)self.image = pygame.transform.scale(self.image, (block_size, block_size))self.rect = self.image.get_rect()self.rect.left, self.rect.top = coordinate[0] * block_size + border_size[0], coordinate[1] * block_size + border_size[1]self.coordinate = coordinateself.block_size = block_sizeself.border_size = border_size'''移动'''def move(self, direction, maze):blocks_list = maze.blocks_listif direction == 'up':if blocks_list[self.coordinate[1]][self.coordinate[0]].has_walls[0]:return Falseelse:self.coordinate[1] = self.coordinate[1] - 1return Trueelif direction == 'down':if blocks_list[self.coordinate[1]][self.coordinate[0]].has_walls[1]:return Falseelse:self.coordinate[1] = self.coordinate[1] + 1return Trueelif direction == 'left':if blocks_list[self.coordinate[1]][self.coordinate[0]].has_walls[2]:return Falseelse:self.coordinate[0] = self.coordinate[0] - 1return Trueelif direction == 'right':if blocks_list[self.coordinate[1]][self.coordinate[0]].has_walls[3]:return Falseelse:self.coordinate[0] = self.coordinate[0] + 1return Trueelse:raise ValueError('Unsupport direction <%s> in Hero.move...' % direction)'''绑定到屏幕'''def draw(self, screen):self.rect.left, self.rect.top = self.coordinate[0] * self.block_size + self.border_size[0], self.coordinate[1] * self.block_size + self.border_size[1]screen.blit(self.image, self.rect)```
最后,就是写下游戏主循环,这个其实也很简单,只要每次载入一个随机生成的迷宫地图和实例化一个主角,然后不断进行按键检测,并根据按键检测的结果移动主角,最后根据行动结果更新界面数据就OK了~当然,若主角到达了终点,则进入关卡切换界面。具体而言,代码实现如下:```python
'''主函数'''
def main(cfg):# 初始化pygame.init()pygame.mixer.init()pygame.font.init()pygame.mixer.music.load(cfg.BGMPATH)pygame.mixer.music.play(-1, 0.0)screen = pygame.display.set_mode(cfg.SCREENSIZE)pygame.display.set_caption('Maze - 微信公众号: Charles的皮卡丘')font = pygame.font.SysFont('Consolas', 15)# 开始界面Interface(screen, cfg, 'game_start')# 记录关卡数num_levels = 0# 记录最少用了多少步通关best_scores = 'None'# 关卡循环切换while True:num_levels += 1clock = pygame.time.Clock()screen = pygame.display.set_mode(cfg.SCREENSIZE)# --随机生成关卡地图maze_now = RandomMaze(cfg.MAZESIZE, cfg.BLOCKSIZE, cfg.BORDERSIZE)# --生成herohero_now = Hero(cfg.HEROPICPATH, [0, 0], cfg.BLOCKSIZE, cfg.BORDERSIZE)# --统计步数num_steps = 0# --关卡内主循环while True:dt = clock.tick(cfg.FPS)screen.fill((255, 255, 255))is_move = False# ----↑↓←→控制herofor event in pygame.event.get():if event.type == pygame.QUIT:pygame.quit()sys.exit(-1)elif event.type == pygame.KEYDOWN:if event.key == pygame.K_UP:is_move = hero_now.move('up', maze_now)elif event.key == pygame.K_DOWN:is_move = hero_now.move('down', maze_now)elif event.key == pygame.K_LEFT:is_move = hero_now.move('left', maze_now)elif event.key == pygame.K_RIGHT:is_move = hero_now.move('right', maze_now)num_steps += int(is_move)hero_now.draw(screen)maze_now.draw(screen)# ----显示一些信息showText(screen, font, 'LEVELDONE: %d' % num_levels, (255, 0, 0), (10, 10))showText(screen, font, 'BESTSCORE: %s' % best_scores, (255, 0, 0), (210, 10))showText(screen, font, 'USEDSTEPS: %s' % num_steps, (255, 0, 0), (410, 10))showText(screen, font, 'S: your starting point    D: your destination', (255, 0, 0), (10, 600))# ----判断游戏是否胜利if (hero_now.coordinate[0] == cfg.MAZESIZE[1] - 1) and (hero_now.coordinate[1] == cfg.MAZESIZE[0] - 1):breakpygame.display.update()# 更新最优成绩if best_scores == 'None':best_scores = num_stepselse:if best_scores > num_steps:best_scores = num_steps# 关卡切换Interface(screen, cfg, mode='game_switch')

文章到这里就结束了,感谢你的观看,[Python24个小游戏系列],下篇文章分享打地鼠小游戏

为了感谢读者们,我想把我最近收藏的一些编程干货分享给大家,回馈每一个读者,希望能帮到你们。
干货主要有:所以想学的同学,有必要听一下这位老师的课、领取python福利奥,想学的同学可以到梦雅老师的围鑫(同音):前排的是:762,中间一排是:459,后排的一组是:510 ,把以上三组字母按照顺序组合起来即可,她会安排学习的。

① 2000多本Python电子书(主流和经典的书籍应该都有了)

② Python标准库资料(最全中文版)

③ 项目源码(四五十个有趣且经典的练手项目及源码)

④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)

⑤ Python学习路线图(告别不入流的学习)

⑥ 两天的Python爬虫训练营直播权限

All done~详解个人主页简介或者私信获取完整源代码。。

Python游戏开发,pygame模块,Python实现过迷宫小游戏相关推荐

  1. Python版基于pygame的玛丽快跑小游戏源代码,玛丽冒险小游戏代码,支持双人模式

    基于pygame的玛丽快跑小游戏源代码,玛丽冒险小游戏代码,支持双人模式 按空格进入单人模式,按't'进入双人模式,双人模式下玛丽1采用空格键上跳,玛丽2采用方向上键上跳. 完整代码下载地址:Pyth ...

  2. Python游戏开发pygame模块,Python实现球球碰撞小游戏

    相信大家在初中电脑课上都偷偷玩过 Flash 游戏--是男人就坚持 100 秒,在游戏中无数的小球随机运动,玩家用鼠标控制大球,当大球碰撞到小球后,游戏结束,显示坚持的时间.今天我们一起来开发这个小游 ...

  3. Python游戏开发pygame模块,Python实现吃豆人,儿时的回忆

    老规矩,先上效果图 这是一个吃豆人的小游戏.我们8090后这一代人肯定会碰到过.黄点是我们自己,红点就是怪物们.这是最原始版的电子游戏. 然后我们可以在随便一个地方新建一个游戏代码,利用这个包的代码, ...

  4. 【cocos2d游戏开发实战】一款射击类小游戏《Zombie Age》的开发(一)

    前言 因为学习的原因需要完成一款射击类的小游戏,之前做的飞机大战没有达到要求,在网上找了几款射击类游戏后因为素材和难度的关系最后决定山寨一下<僵尸时代2>这款小游戏,开发到游戏主体基本完整 ...

  5. 【游戏开发】unity教程4 打飞碟小游戏

    github传送门:https://github.com/dongzizhu/unity3DLearning/tree/master/hw4/Disk 视频传送门:https://space.bili ...

  6. python迷宫小游戏代码_TensorFlow应用实战-17-Qlearning实现迷宫小游戏

    什么是Q-learning Q是Quality的首字母,表示"质量/优劣",表示给它打一个分. 在某些状态下做某个动作,会给他一个Q的价值. learning就是学习的意思.基于质 ...

  7. python语音开发库-各种 Python 库/模块/工具

    1.1 字符串处理 re 正则表达式的标准库. StringIO / cStringIO 以读写文件的方式来操作字符串(有点类似于内存文件). cStringIO 是 C 语言实现的,提供高性能:而 ...

  8. Python 打字小游戏开发,来体验不一样的打字游戏乐趣(第一篇)

    Python 打字小游戏开发,来体验不一样的打字游戏乐趣(第一篇) 前言 游戏素材准备 游戏项目结构 项目里面的类说明 Python 打字小游戏开发,来体验不一样的打字游戏乐趣(第二篇) Python ...

  9. 视频教程-Python入门-系列游戏开发/太空阻击-Python

    Python入门-系列游戏开发/太空阻击 20年软件项目开发管理经验 工信部人才交流中心特聘专家讲师 日本U-CAN在线教育特聘主任讲师 国家十二·五规划软件工程教材作者(书:清华大学出版社出版) 中 ...

最新文章

  1. 经常被人忽视的:Pandas 文本数据处理!
  2. 《云计算开放应用架构》标准发布,阿里云持续领航云原生
  3. JAVA通信编程(五)——串口通讯的补充说明
  4. OSGI概念理解和入门
  5. 26秒!全球销量第一的AI音箱就被腾讯黑掉了,然后变身窃听器
  6. 帆软扩展后排序(超链排序)
  7. 子账号授权服务器,京东子账号装修权限之怎么授权使用详情页模板市场?
  8. GPIO设备虚拟文件结点的创建【转】
  9. 为啥显示器用RGB而打印机用CMYK
  10. 深度指纹识别:通过深度学习破坏网站指纹防御
  11. Termux解析公网ipv6——从全世界各地连接你的Termux
  12. 毕业设计 基于JavaWeb的奖学金评定管理系统
  13. mysql数据库中求圆的面积_MYSQL数据库
  14. layui 下拉表格选择器
  15. C:通过三边判断三角形种类
  16. STM32CubeMX+FATFS+FREERTOS实现W25Q256虚拟U盘
  17. Lyapunov判稳第一法
  18. 高等数学学习笔记——第八十三讲——对弧长的曲线积分的概念与计算
  19. 厦大,天大两硕士同年论文高度雷同,双方均签署学位论文原创性声明
  20. python中英文混合字符串对齐

热门文章

  1. CVPR新规严禁审稿期间公开宣传论文,可发arXiv,LeCun:疯了吧!
  2. 搞定一个C++项目最快需要多久?
  3. Transformer 又立功了!又快(420 fps)又好的车道线检测算法
  4. OCRNet: 目标区域上下文信息的特征表达 | ECCV 2020
  5. 两个大炸弹:清华大学医学院院长董晨院士回应“24篇论文质疑”;南开校长,曹雪涛团队12篇论文被正式调查“可信性”...
  6. 最年轻和最年长新院士:一个是数学神童 一个曾是氮肥厂工人
  7. 想让语音助手听懂方言,这个数据集或能帮你?
  8. 用Python做一个翻译软件,还怕英语不好?
  9. Django项目中的子项目中自动生成自己想要的文件内容
  10. python之进程和线程的对比