本文实例讲述了Python基于分水岭算法解决走迷宫游戏。分享给大家供大家参考,具体如下:
#Solving maze with morphological transformation
"""
usage:Solving maze with morphological transformation
needed module:cv2/numpy/sys
ref:
1.http://www.mazegenerator.net/
2.http://blog.leanote.com/post/leeyoung/539a629aab35bc44e2000000
@author:Robin Chen
"""
import cv2
import numpy as np
import sys
def SolvingMaze(image):
#load an image
try:
img = cv2.imread(image)
except Exception,e:
print 'Error:can not open the image!'
sys.exit()
#show image
#cv2.namedWindow('image', cv2.WINDOW_NORMAL)
cv2.imshow('maze_image',img)
#convert to gray
gray_image = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
#show gray image
#cv2.imshow('gray_image',gray_image)
#convert to binary image
retval,binary_image = cv2.threshold(gray_image, 10,255, cv2.THRESH_BINARY_INV)
#cv2.imshow('binary_image',binary_image)
contours,hierarchy = cv2.findContours(binary_image, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_NONE)
if len(contours) != 2:
sys.exit("This is not a 'perfect maze' with just 2 walls!")
h, w, d = img.shape
#The first wall
path = np.zeros((h,w),dtype = np.uint8)#cv2.CV_8UC1
cv2.drawContours(path, contours, 0, (255,255,255),-1)#cv2.FILLED
#cv2.imshow('The first wall',path)
#Dilate the wall by a few pixels
kernel = np.ones((19, 19), dtype = np.uint8)
path = cv2.dilate(path, kernel)
#cv2.imshow('Dilate the wall by a few pixels',path)
#Erode by the same amount of pixels
path_erode = cv2.erode(path, kernel);
#cv2.imshow('Erode by the same amount of pixels',path_erode)
#absdiff
path = cv2.absdiff(path, path_erode);
#cv2.imshow('absdiff',path)
#solution
channels = cv2.split(img);
channels[0] &= ~path;
channels[1] &= ~path;
channels[2] |= path;
dst = cv2.merge(channels);
cv2.imshow("solution", dst);
#waiting for any key to close windows
cv2.waitKey(0)
cv2.destroyAllWindows()
if __name__ == '__main__':
image = sys.argv[-1]
SolvingMaze(image)
更多关于Python相关内容可查看本站专题:《Python游戏开发技巧总结》、《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。
# Python
# 分水岭算法
# 解决
# 走迷宫
# 游戏
# python实现的生成随机迷宫算法核心代码分享(含游戏完整代码)
# Python解决走迷宫问题算法示例
# 用Python代码来解图片迷宫的方法整理
# Python基于递归算法实现的走迷宫问题
# Python深度优先算法生成迷宫
# Python使用Tkinter实现机器人走迷宫
# Python使用回溯法子集树模板解决迷宫问题示例
# 一道python走迷宫算法题
# Python 实现递归法解决迷宫问题的示例代码
# python实现地牢迷宫生成的完整步骤
# 进阶
# 操作技巧
# 相关内容
# 数据结构
# 给大家
# 更多关于
# 所述
# 程序设计
# 使用技巧
# 游戏开发
# 编程技巧
# 讲述了
# np
# Chen
# import
# image
# SolvingMaze
# def
# leeyoung
相关文章:
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
c# 在高并发场景下,委托和接口调用的性能对比
如何通过建站之星自助学习解决操作问题?
Swift中循环语句中的转移语句 break 和 continue
如何选择香港主机高效搭建外贸独立站?
制作充值网站的软件,做人力招聘为什么要自己交端口钱?
武清网站制作公司,天津武清个人营业执照注销查询系统网站?
在线制作视频网站免费,都有哪些好的动漫网站?
网站制作公司广州有几家,广州尚艺美发学校网站是多少?
制作网站的模板软件,网站怎么建设?
威客平台建站流程解析:高效搭建教程与设计优化方案
如何选择高效便捷的WAP商城建站系统?
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
大连 网站制作,大连天途有线官网?
如何在云服务器上快速搭建个人网站?
如何高效完成独享虚拟主机建站?
如何配置FTP站点权限与安全设置?
建站之星2.7模板:企业网站建设与h5定制设计专题
建站之星代理商如何保障技术支持与售后服务?
阿里云网站制作公司,阿里云快速搭建网站好用吗?
如何打造高效商业网站?建站目的决定转化率
香港服务器租用每月最低只需15元?
代刷网站制作软件,别人代刷火车票靠谱吗?
高端企业智能建站程序:SEO优化与响应式模板定制开发
详解jQuery停止动画——stop()方法的使用
广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?
建站之星在线版空间:自助建站+智能模板一键生成方案
Python路径拼接规范_跨平台处理说明【指导】
教程网站设计制作软件,怎么创建自己的一个网站?
建站之星导航菜单设置与功能模块配置全攻略
建站之星微信建站一键生成小程序+多端营销系统
建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南
孙琪峥织梦建站教程如何优化数据库安全?
如何通过.red域名打造高辨识度品牌网站?
如何用美橙互联一键搭建多站合一网站?
宝塔建站助手安装配置与建站模板使用全流程解析
制作旅游网站html,怎样注册旅游网站?
如何挑选优质建站一级代理提升网站排名?
怎么将XML数据可视化 D3.js加载XML
香港服务器租用费用高吗?如何避免常见误区?
如何在万网开始建站?分步指南解析
宝塔Windows建站如何避免显示默认IIS页面?
如何通过FTP空间快速搭建安全高效网站?
家庭建站与云服务器建站,如何选择更优?
如何选择高效可靠的多用户建站源码资源?
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
昆明高端网站制作公司,昆明公租房申请网上登录入口?
ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?
小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?
临沂网站制作企业,临沂第三中学官方网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。