2022-08-09 07:54:32 +02:00
|
|
|
/*
|
|
|
|
* Functions.cpp, part of VCMI engine
|
|
|
|
*
|
|
|
|
* Authors: listed in file AUTHORS in main folder
|
|
|
|
*
|
|
|
|
* License: GNU General Public License v2.0 or later
|
|
|
|
* Full text of license available in license.txt file, in main folder
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "StdInc.h"
|
|
|
|
#include "Functions.h"
|
|
|
|
#include "CMapGenerator.h"
|
|
|
|
#include "RmgMap.h"
|
|
|
|
#include "TileInfo.h"
|
|
|
|
#include "RmgPath.h"
|
2023-01-09 01:17:37 +02:00
|
|
|
#include "../TerrainHandler.h"
|
2022-08-09 07:54:32 +02:00
|
|
|
#include "../mapping/CMap.h"
|
2023-06-02 20:47:37 +02:00
|
|
|
#include "../mapObjectConstructors/AObjectTypeHandler.h"
|
|
|
|
#include "../mapObjectConstructors/CObjectClassesHandler.h"
|
2022-08-09 07:54:32 +02:00
|
|
|
#include "../VCMI_Lib.h"
|
|
|
|
|
2024-06-01 17:28:17 +02:00
|
|
|
#include <vstd/RNG.h>
|
|
|
|
|
2022-07-26 15:07:42 +02:00
|
|
|
VCMI_LIB_NAMESPACE_BEGIN
|
|
|
|
|
2024-11-23 09:25:55 +02:00
|
|
|
void replaceWithCurvedPath(rmg::Path & path, const Zone & zone, const int3 & src, bool onlyStraight)
|
2024-11-22 10:28:37 +02:00
|
|
|
{
|
|
|
|
auto costFunction = rmg::Path::createCurvedCostFunction(zone.area()->getBorder());
|
|
|
|
auto pathArea = zone.areaForRoads();
|
|
|
|
rmg::Path curvedPath(pathArea);
|
|
|
|
curvedPath.connect(zone.freePaths().get());
|
2024-11-23 09:25:55 +02:00
|
|
|
curvedPath = curvedPath.search(src, onlyStraight, costFunction);
|
2024-11-22 10:28:37 +02:00
|
|
|
if (curvedPath.valid())
|
|
|
|
{
|
|
|
|
path = curvedPath;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
logGlobal->warn("Failed to create curved path to %s", src.toString());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-08-09 07:54:32 +02:00
|
|
|
rmg::Tileset collectDistantTiles(const Zone& zone, int distance)
|
|
|
|
{
|
2022-12-08 23:20:42 +02:00
|
|
|
uint32_t distanceSq = distance * distance;
|
2024-03-27 07:16:48 +02:00
|
|
|
|
|
|
|
auto subarea = zone.area()->getSubarea([&zone, distanceSq](const int3 & t)
|
2022-08-09 07:54:32 +02:00
|
|
|
{
|
|
|
|
return t.dist2dSQ(zone.getPos()) > distanceSq;
|
|
|
|
});
|
|
|
|
return subarea.getTiles();
|
|
|
|
}
|
|
|
|
|
2024-06-01 17:28:17 +02:00
|
|
|
int chooseRandomAppearance(vstd::RNG & generator, si32 ObjID, TerrainId terrain)
|
2022-08-09 07:54:32 +02:00
|
|
|
{
|
|
|
|
auto factories = VLC->objtypeh->knownSubObjects(ObjID);
|
|
|
|
vstd::erase_if(factories, [ObjID, &terrain](si32 f)
|
|
|
|
{
|
2023-04-29 11:46:03 +02:00
|
|
|
//TODO: Use templates with lowest number of terrains (most specific)
|
2022-08-09 07:54:32 +02:00
|
|
|
return VLC->objtypeh->getHandlerFor(ObjID, f)->getTemplates(terrain).empty();
|
|
|
|
});
|
|
|
|
|
|
|
|
return *RandomGeneratorUtil::nextItem(factories, generator);
|
|
|
|
}
|
|
|
|
|
2022-07-26 15:07:42 +02:00
|
|
|
VCMI_LIB_NAMESPACE_END
|