2013-08-17 12:46:48 +00:00
|
|
|
/*
|
|
|
|
* CZonePlacer.h, 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
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2014-05-24 12:42:06 +02:00
|
|
|
#include "float3.h"
|
|
|
|
#include "../int3.h"
|
2022-08-09 09:54:32 +04:00
|
|
|
#include "../GameConstants.h"
|
2014-05-24 12:42:06 +02:00
|
|
|
|
2022-07-26 16:07:42 +03:00
|
|
|
VCMI_LIB_NAMESPACE_BEGIN
|
|
|
|
|
2024-06-01 15:28:17 +00:00
|
|
|
namespace vstd
|
|
|
|
{
|
|
|
|
class RNG;
|
|
|
|
}
|
|
|
|
|
2013-08-17 12:46:48 +00:00
|
|
|
class CZoneGraph;
|
|
|
|
class CMap;
|
2022-08-09 09:54:32 +04:00
|
|
|
class RmgMap;
|
|
|
|
class Zone;
|
2013-08-17 12:46:48 +00:00
|
|
|
|
2022-08-09 09:54:32 +04:00
|
|
|
typedef std::vector<std::pair<TRmgTemplateZoneId, std::shared_ptr<Zone>>> TZoneVector;
|
|
|
|
typedef std::map<TRmgTemplateZoneId, std::shared_ptr<Zone>> TZoneMap;
|
|
|
|
typedef std::map<std::shared_ptr<Zone>, float3> TForceVector;
|
|
|
|
typedef std::map<std::shared_ptr<Zone>, float> TDistanceVector;
|
2023-04-23 10:08:16 +02:00
|
|
|
typedef std::map<int, std::map<int, size_t>> TDistanceMap;
|
2013-08-17 12:46:48 +00:00
|
|
|
|
|
|
|
class CZonePlacer
|
|
|
|
{
|
|
|
|
public:
|
2022-08-09 09:54:32 +04:00
|
|
|
explicit CZonePlacer(RmgMap & map);
|
2023-02-11 19:05:02 +03:00
|
|
|
int3 cords(const float3 & f) const;
|
2014-05-25 13:02:15 +04:00
|
|
|
float metric (const int3 &a, const int3 &b) const;
|
2024-06-24 03:23:26 +02:00
|
|
|
float getDistance(float distance) const; //additional scaling without 0 division
|
2023-02-11 19:05:02 +03:00
|
|
|
~CZonePlacer() = default;
|
2013-08-17 12:46:48 +00:00
|
|
|
|
2024-06-01 15:28:17 +00:00
|
|
|
void placeZones(vstd::RNG * rand);
|
2023-04-10 09:02:58 +02:00
|
|
|
void findPathsBetweenZones();
|
2024-06-01 15:28:17 +00:00
|
|
|
void placeOnGrid(vstd::RNG* rand);
|
2023-06-23 21:43:12 +02:00
|
|
|
float scaleForceBetweenZones(const std::shared_ptr<Zone> zoneA, const std::shared_ptr<Zone> zoneB) const;
|
2024-06-01 15:28:17 +00:00
|
|
|
void assignZones(vstd::RNG * rand);
|
2023-04-23 10:08:16 +02:00
|
|
|
|
|
|
|
const TDistanceMap & getDistanceMap();
|
2022-05-28 16:03:50 +03:00
|
|
|
|
|
|
|
private:
|
2024-06-01 15:28:17 +00:00
|
|
|
void prepareZones(TZoneMap &zones, TZoneVector &zonesVector, const bool underground, vstd::RNG * rand);
|
2023-02-11 19:05:02 +03:00
|
|
|
void attractConnectedZones(TZoneMap & zones, TForceVector & forces, TDistanceVector & distances) const;
|
2016-07-12 21:23:45 +02:00
|
|
|
void separateOverlappingZones(TZoneMap &zones, TForceVector &forces, TDistanceVector &overlaps);
|
2023-04-20 12:24:57 +02:00
|
|
|
void moveOneZone(TZoneMap & zones, TForceVector & totalForces, TDistanceVector & distances, TDistanceVector & overlaps);
|
2013-08-17 12:46:48 +00:00
|
|
|
|
|
|
|
private:
|
2016-07-13 07:54:52 +02:00
|
|
|
int width;
|
|
|
|
int height;
|
2024-06-24 03:23:26 +02:00
|
|
|
//metric coefficient
|
2016-07-12 21:23:45 +02:00
|
|
|
float mapSize;
|
|
|
|
|
|
|
|
float gravityConstant;
|
|
|
|
float stiffnessConstant;
|
2023-04-17 16:37:24 +02:00
|
|
|
float stifness;
|
|
|
|
float stiffnessIncreaseFactor;
|
2023-04-20 12:44:32 +02:00
|
|
|
|
|
|
|
//remember best solution
|
|
|
|
float bestTotalDistance;
|
|
|
|
float bestTotalOverlap;
|
2023-04-10 09:02:58 +02:00
|
|
|
|
|
|
|
//distance [a][b] = number of zone connections required to travel between the zones
|
2023-04-23 10:08:16 +02:00
|
|
|
TDistanceMap distancesBetweenZones;
|
2023-04-20 12:24:57 +02:00
|
|
|
std::set<TRmgTemplateZoneId> lastSwappedZones;
|
2022-08-09 09:54:32 +04:00
|
|
|
RmgMap & map;
|
2013-08-17 12:46:48 +00:00
|
|
|
};
|
2022-07-26 16:07:42 +03:00
|
|
|
|
|
|
|
VCMI_LIB_NAMESPACE_END
|