mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-26 03:52:01 +02:00
Improved road routing so they can go under any passable object.
This commit is contained in:
parent
f78b524731
commit
cc452bdfa9
@ -275,8 +275,8 @@ CCallback::~CCallback()
|
|||||||
|
|
||||||
bool CCallback::canMoveBetween(const int3 &a, const int3 &b)
|
bool CCallback::canMoveBetween(const int3 &a, const int3 &b)
|
||||||
{
|
{
|
||||||
//TODO: merge with Pathfinder::canMoveBetween
|
//bidirectional
|
||||||
return gs->checkForVisitableDir(a, b) && gs->checkForVisitableDir(b, a);
|
return gs->map->canMoveBetween(a, b);
|
||||||
}
|
}
|
||||||
|
|
||||||
const CPathsInfo * CCallback::getPathsInfo(const CGHeroInstance *h)
|
const CPathsInfo * CCallback::getPathsInfo(const CGHeroInstance *h)
|
||||||
|
@ -385,6 +385,12 @@ bool CMap::isWaterTile(const int3 &pos) const
|
|||||||
{
|
{
|
||||||
return isInTheMap(pos) && getTile(pos).isWater();
|
return isInTheMap(pos) && getTile(pos).isWater();
|
||||||
}
|
}
|
||||||
|
bool CMap::canMoveBetween(const int3 &src, const int3 &dst) const
|
||||||
|
{
|
||||||
|
const TerrainTile * dstTile = &getTile(dst);
|
||||||
|
const TerrainTile * srcTile = &getTile(src);
|
||||||
|
return checkForVisitableDir(src, dstTile, dst) && checkForVisitableDir(dst, srcTile, src);
|
||||||
|
}
|
||||||
|
|
||||||
bool CMap::checkForVisitableDir(const int3 & src, const TerrainTile *pom, const int3 & dst ) const
|
bool CMap::checkForVisitableDir(const int3 & src, const TerrainTile *pom, const int3 & dst ) const
|
||||||
{
|
{
|
||||||
|
@ -304,6 +304,7 @@ public:
|
|||||||
bool isInTheMap(const int3 & pos) const;
|
bool isInTheMap(const int3 & pos) const;
|
||||||
bool isWaterTile(const int3 & pos) const;
|
bool isWaterTile(const int3 & pos) const;
|
||||||
|
|
||||||
|
bool canMoveBetween(const int3 &src, const int3 &dst) const;
|
||||||
bool checkForVisitableDir( const int3 & src, const TerrainTile *pom, const int3 & dst ) const;
|
bool checkForVisitableDir( const int3 & src, const TerrainTile *pom, const int3 & dst ) const;
|
||||||
int3 guardingCreaturePosition (int3 pos) const;
|
int3 guardingCreaturePosition (int3 pos) const;
|
||||||
|
|
||||||
|
@ -319,7 +319,7 @@ void CMapGenerator::fillZones()
|
|||||||
it.second->createObstacles2(this);
|
it.second->createObstacles2(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define PRINT_MAP_BEFORE_ROADS true
|
#define PRINT_MAP_BEFORE_ROADS false
|
||||||
if (PRINT_MAP_BEFORE_ROADS) //enable to debug
|
if (PRINT_MAP_BEFORE_ROADS) //enable to debug
|
||||||
{
|
{
|
||||||
std::ofstream out("road debug");
|
std::ofstream out("road debug");
|
||||||
|
@ -776,6 +776,7 @@ bool CRmgTemplateZone::createRoad(CMapGenerator* gen, const int3& src, const int
|
|||||||
pq.pop(); //remove top element
|
pq.pop(); //remove top element
|
||||||
int3 currentNode = node.first;
|
int3 currentNode = node.first;
|
||||||
closed.insert (currentNode);
|
closed.insert (currentNode);
|
||||||
|
auto currentTile = &gen->map->getTile(currentNode);
|
||||||
|
|
||||||
if (currentNode == dst || gen->isRoad(currentNode))
|
if (currentNode == dst || gen->isRoad(currentNode))
|
||||||
{
|
{
|
||||||
@ -798,7 +799,7 @@ bool CRmgTemplateZone::createRoad(CMapGenerator* gen, const int3& src, const int
|
|||||||
bool directNeighbourFound = false;
|
bool directNeighbourFound = false;
|
||||||
float movementCost = 1;
|
float movementCost = 1;
|
||||||
|
|
||||||
auto foo = [gen, this, &pq, &distances, &closed, &cameFrom, ¤tNode, &node, &dst, &directNeighbourFound, &movementCost](int3& pos) -> void
|
auto foo = [gen, this, &pq, &distances, &closed, &cameFrom, ¤tNode, ¤tTile, &node, &dst, &directNeighbourFound, &movementCost](int3& pos) -> void
|
||||||
{
|
{
|
||||||
if (vstd::contains(closed, pos)) //we already visited that node
|
if (vstd::contains(closed, pos)) //we already visited that node
|
||||||
return;
|
return;
|
||||||
@ -810,10 +811,13 @@ bool CRmgTemplateZone::createRoad(CMapGenerator* gen, const int3& src, const int
|
|||||||
|
|
||||||
if (distance < bestDistanceSoFar)
|
if (distance < bestDistanceSoFar)
|
||||||
{
|
{
|
||||||
auto obj = gen->map->getTile(pos).topVisitableObj();
|
auto tile = &gen->map->getTile(pos);
|
||||||
//FIXME: make road go through any empty or visitable tile
|
auto obj = tile->topVisitableObj();
|
||||||
//if (gen->map->checkForVisitableDir(currentNode, &gen->map->getTile(pos), pos)) //TODO: why it has no effect?
|
bool canMoveBetween = gen->map->canMoveBetween(currentNode, pos);
|
||||||
if (gen->isFree(pos) || (obj && obj->ID == Obj::MONSTER) || pos == dst)
|
|
||||||
|
if (gen->isFree(pos) && gen->isFree(currentNode) //empty path
|
||||||
|
|| ((tile->visitable || currentTile->visitable) && canMoveBetween) //moving from or to visitable object
|
||||||
|
|| pos == dst) //we already compledted the path
|
||||||
{
|
{
|
||||||
if (gen->getZoneID(pos) == id || pos == dst) //otherwise guard position may appear already connected to other zone.
|
if (gen->getZoneID(pos) == id || pos == dst) //otherwise guard position may appear already connected to other zone.
|
||||||
{
|
{
|
||||||
@ -821,7 +825,6 @@ bool CRmgTemplateZone::createRoad(CMapGenerator* gen, const int3& src, const int
|
|||||||
distances[pos] = distance;
|
distances[pos] = distance;
|
||||||
pq.push(std::make_pair(pos, distance));
|
pq.push(std::make_pair(pos, distance));
|
||||||
directNeighbourFound = true;
|
directNeighbourFound = true;
|
||||||
//logGlobal->traceStream() << boost::format("Found connection between node %s and %s, current distance %d") % currentNode % pos % distance;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user