cocos2d-x游戏实例(8)-A星算法(4)
2012-02-29 20:16
309 查看
小满(bill man)个人原创,欢迎转载,转载请注明地址,小满(bill man)的专栏地址http://blog.csdn.net/bill_man
继续A星算法,我们在经历了地图的检测,并且检测open列表和close列表之后。如果还没有被加入到open和close列表中,我们就把他加入到我们的open列表中,方法如下:
很简单,就是设置我们之前已经提到过的参数,然后使用堆排序排列如下:
堆排序之前已经介绍过,就是保证树形结构的父节点的f值比子节点的f值小就可以了
之后我们就进入这样的循环:首先把起点放入close列表,并检测这点周围点的f值(g+h,h我们通过本点到终点的横纵索引差估计而来),把剩下的点放入open列表中,并根据f值进行堆排序,然后把f值最小的点放入close列表中,继续处理,直到找到终点为止。其实之前我们进行的就是这个步骤。
然后我们找到路径后就通过getpath把路径存入到path数组中就可以了
我们就是把close列表中的节点一个个的插入到path中,直到找到起始点,也就是说g代价为0的点就结束了。
最后作一些处理,我们的A星算法就完成了。
处理的代码如下
首先就是将open和close列表清空,以便下一次使用,然后如果我们的path中的数量为0时,返回空值,否则检测path中有没有终点,如果没有加入终点并返回path。
到此A星算法已经完成,下一篇讲解如何使用这个类
如有错误之处,希望大家多多指正
下一篇继续A星算法游戏实例
继续A星算法,我们在经历了地图的检测,并且检测open列表和close列表之后。如果还没有被加入到open和close列表中,我们就把他加入到我们的open列表中,方法如下:
很简单,就是设置我们之前已经提到过的参数,然后使用堆排序排列如下:
堆排序之前已经介绍过,就是保证树形结构的父节点的f值比子节点的f值小就可以了
之后我们就进入这样的循环:首先把起点放入close列表,并检测这点周围点的f值(g+h,h我们通过本点到终点的横纵索引差估计而来),把剩下的点放入open列表中,并根据f值进行堆排序,然后把f值最小的点放入close列表中,继续处理,直到找到终点为止。其实之前我们进行的就是这个步骤。
然后我们找到路径后就通过getpath把路径存入到path数组中就可以了
我们就是把close列表中的节点一个个的插入到path中,直到找到起始点,也就是说g代价为0的点就结束了。
最后作一些处理,我们的A星算法就完成了。
处理的代码如下
首先就是将open和close列表清空,以便下一次使用,然后如果我们的path中的数量为0时,返回空值,否则检测path中有没有终点,如果没有加入终点并返回path。
到此A星算法已经完成,下一篇讲解如何使用这个类
如有错误之处,希望大家多多指正
下一篇继续A星算法游戏实例
相关文章推荐
- cocos2d-x游戏实例(5)-A星算法(1)
- cocos2d-x游戏实例(6)-A星算法(2)
- cocos2d-x游戏实例(6)-A星算法(2)
- cocos2d-x游戏实例(7)-A星算法(3)
- cocos2d-x游戏实例(8)-A星算法(4)
- cocos2d-x游戏实例(9)-A星算法(5)
- cocos2d-x游戏实例(5)-A星算法(1)
- cocos2d-x游戏实例(7)-A星算法(3)
- cocos2d-x游戏实例(9)-A星算法(5)
- cocos2d-x游戏实例(4)-地图碰撞
- cocos2d-x游戏实例(26)-简易动作游戏(4)
- Cocos2d-x3.0游戏实例之《别救我》第九篇——从tmx文件中加载关卡怪物
- cocos2d-x 3.0游戏实例学习笔记《卡牌塔防》第七步---英雄要升级&属性--解析csv配置文件
- 【木头Cocos2d-x 013】游戏实例-《跑跑跑》制作教程(第五篇)——主角上下移动
- cocos2d-x游戏实例(2)-主角根据输入移动
- cocos2d-x 3.0游戏实例学习笔记 《跑酷》 完结篇--源代码放送
- cocos2d-x游戏实例(27)-简易动作游戏(5)
- Cocos2d-x3.0游戏实例《别救我》目录导航(共10篇,已完结)
- Cocos2d-x3.0游戏实例之《别救我》第四篇——乱入的主角
- cocos2d-x游戏实例(3)-获得地图索引