|
|
|
@ -59,6 +59,38 @@ end
|
|
|
|
|
|
|
|
|
|
function UIGameMap:onMouseRelease(mousePosition, mouseButton)
|
|
|
|
|
local tile = self:getTile(mousePosition)
|
|
|
|
|
if tile and GameInterface.processMouseAction(mousePosition, mouseButton, nil, tile:getTopLookThing(), tile:getTopUseThing(), tile:getTopCreature(), tile:getTopMultiUseThing()) then return true end
|
|
|
|
|
if tile == nil then return false end
|
|
|
|
|
if GameInterface.processMouseAction(mousePosition, mouseButton, nil, tile:getTopLookThing(), tile:getTopUseThing(), tile:getTopCreature(), tile:getTopMultiUseThing()) then
|
|
|
|
|
return true
|
|
|
|
|
elseif mouseButton == MouseLeftButton then
|
|
|
|
|
local fromPos = g_game.getLocalPlayer():getPosition()
|
|
|
|
|
local toPos = tile:getPosition()
|
|
|
|
|
if fromPos.z ~= toPos.z then
|
|
|
|
|
TextMessage.displayStatus('There is no way.')
|
|
|
|
|
return true
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
-- simple and stupid pathfinding algorithm
|
|
|
|
|
local dirs = {}
|
|
|
|
|
local pathPos = fromPos
|
|
|
|
|
while pathPos.x ~= toPos.x or pathPos.y ~= toPos.y do
|
|
|
|
|
if pathPos.x < toPos.x then
|
|
|
|
|
pathPos.x = pathPos.x + 1
|
|
|
|
|
table.insert(dirs, East)
|
|
|
|
|
elseif pathPos.x > toPos.x then
|
|
|
|
|
pathPos.x = pathPos.x - 1
|
|
|
|
|
table.insert(dirs, West)
|
|
|
|
|
elseif pathPos.y < toPos.y then
|
|
|
|
|
pathPos.y = pathPos.y + 1
|
|
|
|
|
table.insert(dirs, South)
|
|
|
|
|
else --if pathPos.y > toPos.y then
|
|
|
|
|
pathPos.y = pathPos.y - 1
|
|
|
|
|
table.insert(dirs, North)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
g_game.autoWalk(dirs)
|
|
|
|
|
return true
|
|
|
|
|
end
|
|
|
|
|
return false
|
|
|
|
|
end
|
|
|
|
|