cocos2dx之寻路 A星
来源:互联网 发布:js value 赋值 编辑:程序博客网 时间:2024/05/17 01:10
–寻路
local MAX_ROW_NUM = 9 --行数local MAX_COL_NUM = 9 --列数local director = cc.Director:getInstance()local visibleSize = director:getVisibleSize()
–小方块宽高
local ItemWidth = visibleSize.width / MAX_COL_NUMlocal ItemHeight = ItemWidth
–查找方向
local SEARCH_POS = {cc.p(-1, 0), --左边cc.p(0, 1), --上cc.p(1, 0), --右cc.p(0, -1), --下}
self.m_allItems = {}for i=1,MAX_ROW_NUM do self.m_allItems[i] = {} for j=1,MAX_COL_NUM do local smallItem = smallItem:create(i, j) smallItem:setPosition((j - 1) * ItemWidth, (i - 1) * ItemHeight) self:addChild(smallItem) self.m_allItems[i][j] = smallItem endend
–从(1, 1)找向(7, 7)
self:_AStar(cc.p(1, 1), cc.p(7, 7))
function TestLayer:_AStar(from, to) local queue = {from} --记录行走的路径 local searchMap = {[from.x*MAX_ROW_NUM + from.y] = {from}} repeat local p = table.remove(queue, 1) if(not p) then break end --将目前格子的周围相邻的格子压栈 for _,point in ipairs(SEARCH_POS) do local x = point.x + p.x local y = point.y + p.y if x > 0 and x <= MAX_COL_NUM and y > 0 and y <= MAX_ROW_NUM then --格子有效范围内 local pp = clone(searchMap[p.x*MAX_ROW_NUM + p.y]) table.insert(pp, cc.p(x, y)) if x == to.x and y == to.y then --找到了 for _,point in pairs(pp) do -- print("x, y: ", point.x, point.y) end return elseif not self.m_allItems[x][y]:_getIsMask() then --格子未寻过 self.m_allItems[x][y]:_setIsMask(true) --标记格子寻路过 table.insert(queue, cc.p(x, y)) searchMap[x*MAX_ROW_NUM + y] = pp end end end until falseend
阅读全文
0 0
- cocos2dx之寻路 A星
- cocos2dx之A星算法
- cocos2dx A*寻路算法
- cocos2dx A*寻路算法lua实现
- cocos2dx 3.x 实现 A星(A*)(A-star)算法自动寻路(一)
- cocos2dx 3.x 实现 A星(A*)(A-star)算法自动寻路(二)
- Cocos2dx 学习随笔(二) A星(A*)寻路算法在iOS开发的运用
- cocos2dx游戏中A*寻路算法的实现
- cocos2dx下的A星算法
- cocos2dx学习之路--拼图游戏
- JS算法之A*(A星)寻路算法
- cocos2dx A星寻路
- cocos2dx A*算法
- cocos2dx A* + tiledMap
- cocos2dx A*算法
- Cocos2dx------A*寻路
- cocos2dx学习之路(二)
- 我的cocos2dx学习之路
- 店铺淘客如何做到单店利润过万的个人实战技巧
- Centos7如何修改ssh默认端口
- 【学习摘记】马士兵bbs改良版_课时10_dreamweaver修图
- C# BackupSupport v1.2 (文本复制工具)
- SimpAdapter适配器
- cocos2dx之寻路 A星
- Oracle 错误总结及问题解决 ORA
- drools的懒加载和执行
- hiveserver2和zookeeper的HA搭建
- 接口
- Electron相关
- sql语句优化的几个要点
- keepalived+nginx+tomcat7+redis搭建高可用集群(一)
- MySQL备份与还原导入