基于 Python 制作的迷宫小游戏

基于 Python 制作的迷宫小游戏 导语 大家假日愉快呀~不想出门看人山人海,所以干脆过来更波公众号好了~ 有一个月没更小游戏系列的文章了

本文包含相关资料包-----> 点击直达获取<-------

基于 Python 制作的迷宫小游戏

导语

大家假日愉快呀~不想出门看人山人海,所以干脆过来更波公众号好了~

有一个月没更小游戏系列的文章了,随手写个节日解闷用的过迷宫小游戏分享给大家好了。让我们愉快地开始吧~

开发工具

Python 版本: 3.6.4

相关模块:

pygame 模块;

以及一些 Python 自带的模块。

环境搭建

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

先睹为快

在 cmd 窗口运行 Game20.py 文件即可。

效果如下:

原理简介

游戏规则:

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

逐步实现:

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

然后设计算法遍历所有的 cell,每个被遍历到的 cell 在某几个随机的方向上打开一堵墙(就是去掉分割 cell 的线条)就 ok 啦~

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

```python

'''随机生成迷宫类''' class RandomMaze(): def init (self, maze_size, block_size, border_size, kwargs): self.block_size = block_size self.border_size = border_size self.maze_size = maze_size self.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)) '''创建迷宫''' @staticmethod def 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 = None count = 0 # 查看上边block if 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_top count += 1 # 查看下边block if 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_bottom count += 1 # 查看左边block if 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_left count += 1 # 查看右边block if 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_right count += 1 if 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] = False block_now.has_walls[0] = False elif direction == 'bottom': block_next.has_walls[0] = False block_now.has_walls[1] = False elif direction == 'left': block_next.has_walls[3] = False block_now.has_walls[2] = False elif direction == 'right': block_next.has_walls[2] = False block_now.has_walls[3] = False break return block_next blocks_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 = True records.append(block_now) block_now = nextBlock(block_now, blocks_list) else: block_now = records.pop() if len(records) == 0: break return 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 = coordinate self.block_size = block_size self.border_size = border_size '''移动''' def move(self, direction, maze): blocks_list = maze.blocks_list if direction == 'up': if blocks_list[self.coordinate[1]][self.coordinate[0]].has_walls[0]: return False else: self.coordinate[1] = self.coordinate[1] - 1 return True elif direction == 'down': if blocks_list[self.coordinate[1]][self.coordinate[0]].has_walls[1]: return False else: self.coordinate[1] = self.coordinate[1] + 1 return True elif direction == 'left': if blocks_list[self.coordinate[1]][self.coordinate[0]].has_walls[2]: return False else: self.coordinate[0] = self.coordinate[0] - 1 return True elif direction == 'right': if blocks_list[self.coordinate[1]][self.coordinate[0]].has_walls[3]: return False else: self.coordinate[0] = self.coordinate[0] + 1 return True else: 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 += 1 clock = pygame.time.Clock() screen = pygame.display.set_mode(cfg.SCREENSIZE) # --随机生成关卡地图 maze_now = RandomMaze(cfg.MAZESIZE, cfg.BLOCKSIZE, cfg.BORDERSIZE) # --生成hero hero_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 # ----↑↓←→控制hero for 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): break pygame.display.update() # 更新最优成绩 if best_scores == 'None': best_scores = num_steps else: if best_scores > num_steps: best_scores = num_steps # 关卡切换 Interface(screen, cfg, mode='game_switch') ```

All done ~完整源代码详见相关文件~

参考文献

  • 在线旅游管理信息系统的设计与实现(电子科技大学·任缘)
  • 网页游戏平台的管理与设计(哈尔滨师范大学·苏润泽)
  • 网络流量统计分析系统(吉林大学·石景龙)
  • 基于B/S体系架构的旅游信息管理系统设计与实现(电子科技大学·李建森)
  • 网络游戏虚拟物品交易系统设计与实现(吉林大学·李云峰)
  • 基于B/S架构的酷跑社区系统的设计与实现(内蒙古大学·张晓乐)
  • 基于B/S架构的酷跑社区系统的设计与实现(内蒙古大学·张晓乐)
  • 基于VF的社区物业信息管理系统的设计与实现(电子科技大学·徐玮)
  • 在线旅游管理信息系统的设计与实现(电子科技大学·任缘)
  • 在线旅游管理信息系统的设计与实现(电子科技大学·任缘)
  • 网络游戏虚拟物品交易系统设计与实现(吉林大学·李云峰)
  • 促进计算思维发展的教学游戏设计与开发(山东师范大学·宗伟伟)
  • 基于.NET平台的游戏门户系统设计与实现(电子科技大学·余胜鹏)
  • 基于SSH架构的个人空间交友网站的设计与实现(北京邮电大学·隋昕航)
  • 基于.NET的酒店管理系统的设计与实现(吉林大学·陈阳)

本文内容包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主题。发布者:毕设工厂 ,原文地址:https://m.bishedaima.com/yuanma/36063.html

相关推荐

  • 基于SpringBoot框架的二手车交易系统

    这是一套采用Java编程语言,基于SpringBoot框架构建的二手车辆交易系统源代码,开发工具为Idea或Eclipse,采用了现代化的SpringBoot和Vue技术栈
    2024年05月23日
    7 1 3
  • 基于ssm+bootstrsp简单极易上手的小型图书系统

    基于 ssm+bootstrsp 简单极易上手的小型图书系统 效果图: 步骤 第一步 idea 下载 idea, 怎么下载安装配置 idea 第二步 创建项目 打开 idea —> File —> new —> project —> maven —> create from archetype —> maven-archetype-webapp —> 接下来一般默认即可 先放上项目结构图 第三步 配置 maven 依赖
    2024年05月14日
    3 1 1
  • 基于springboot实现的整合dubbo服务框架

    本文你将学到什么? 本文将以原理+实战的方式,首先对“微服务”相关的概念进行知识点扫盲,然后开始手把手教你搭建这一整套的微服务系统, 这套微服务框架能干啥? 这套系统搭建完之后
    2024年05月14日
    1 1 1
  • 基于Python实现书店销售管理系统

    书店销售管理管理子系统 一,设 计 总 说 明 现在社会随着计算机技术迅速发展与技术的逐渐成熟,信息技术已经使人们的生活发生深刻的变化,生活中的各种服务系统也使人们在生活中的联系日常销售活动方式发生了很大的变化
    2024年05月14日
    6 1 1
  • 基于python + dlib实现人脸识别

    python 进行人脸识别 人脸识别的主要算法 其核心算法是 欧式距离算法使用该算法计算两张脸的面部特征差异,一般在 0,6 以下都可以被认为是同一张脸 人脸识别的主要步骤 获得人脸图片 将人脸图片转为 128D 的矩阵(这个也就是人脸特征的一种数字化表现) 保存人脸 128D 的特征到文件中 获取其他人脸转为 128D 特征通过欧式距离算法与我们保存的特征对比
    2024年05月14日
    2 1 1
  • 基于SSM的中医管理系统源码

    这是一个🔥🔥基于SSM的中医管理系统🔥🔥的项目源码,开发语言Java,开发环境Idea/Eclipse,这个 中医管理系统开发技术栈为SSM项目,可以作为毕业设计课程设计作业使用SSM框架实现一个中医管理系统
    2024年05月23日
    7 1 3
  • 基于Python的信息检索课程设计

    基于Python的信息检索课程设计 sdu视点新闻 全站爬虫爬取+索引构建+搜索引擎查询练习程序 爬虫功能使用Python的scrapy库实现
    2024年05月14日
    2 1 1
  • 基于jsp+servlet+mysql的图书管理系统

    Book-management-jsp 基于jsp+servlet+mysql的图书管理系统 参考文献 基于RBAC的SSH架构下的图书管理应用研究(大连理工大学·姜楠) 高校图书管理系统的设计与实现(东北大学·黄鑫) 复旦大学数字图书馆个人图书管理系统的设计与实现(电子科技大学·陆卫国) 图书综合管理系统(吉林大学·王宇) 宁波职业技术学院图书管理系统分析与设计(云南大学·赵顺勇) 大同实验小学图书馆借还系统的设计与实现(电子科技大学·王洪宇) 山西电大图书管理信息系统的设计与实现(北京工业大学·李莹) 山西电大图书管理信息系统的设计与实现(北京工业大学·李莹) 山西电大图书管理信息系统的设计与实现(北京工业大学·李莹) 医疗卫生图书网的设计与实现(电子科技大学·张占平) 基于Web的书刊进销存系统的设计与实现(大连理工大学·王宁) 基于JSP/Servlet的三层式网上书店的研究与实现(吉林大学·郭小雪) 基于RBAC的SSH架构下的图书管理应用研究(大连理工大学·姜楠) 基于B/S架构的网上书店系统的设计与实现(电子科技大学·陈云英) 基于
    2024年05月14日
    11 1 2
  • 基于Springboot和Redis实现的在线选课系统

    基于Springboot和Redis实现的在线选课系统 1,项目简介 1,1 介绍 毕业设计真的就是demo吗?作为工作前的最后一个校园项目,毕业设计应当尽可能的贴近企业实战
    2024年05月14日
    1 1 1
  • 基于Springmvc+MyBatis+Spring+Bootstrap+EasyUI+Mysql的个人博客系统

    Blog-master 基于Springmvc+MyBatis+Spring+Bootstrap+EasyUI+Mysql的个人博客系统 参考文献 基于SSH框架的博客用户分享平台的设计与实现(河北工业大学·刘磊) 基于SSH框架的人力资源管理系统的设计与开发(电子科技大学·唐伟) 博客管理系统的设计与实现(吉林大学·赵岩) 基于SSH架构的个人空间交友网站的设计与实现(北京邮电大学·隋昕航) 基于MVC设计模式的博客系统的设计与实现(大连理工大学·侯林) 基于SSH框架的博客用户分享平台的设计与实现(河北工业大学·刘磊) 基于SSH框架模式的博客系统的设计与实现(西北师范大学·王刚成) 基于SSH2的轻博客系统的研究与实现(吉林大学·杨雪梅) 博客管理系统的设计与实现(吉林大学·赵岩) 基于OAuth2
    2024年05月14日
    4 1 1

发表回复

登录后才能评论