2022-08-09 09:54:32 +04:00
|
|
|
/*
|
|
|
|
* ObjectManager.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
|
|
|
|
|
2023-05-20 10:17:37 +02:00
|
|
|
#include "../Zone.h"
|
|
|
|
#include "../RmgObject.h"
|
2022-08-20 14:17:27 +04:00
|
|
|
#include <boost/heap/priority_queue.hpp> //A*
|
2022-08-09 09:54:32 +04:00
|
|
|
|
2022-07-26 16:07:42 +03:00
|
|
|
VCMI_LIB_NAMESPACE_BEGIN
|
|
|
|
|
2022-08-09 09:54:32 +04:00
|
|
|
class CGObjectInstance;
|
|
|
|
class ObjectTemplate;
|
|
|
|
class CGCreature;
|
|
|
|
|
2023-04-18 00:11:16 +03:00
|
|
|
using TDistance = std::pair<int3, float>;
|
2022-08-20 14:17:27 +04:00
|
|
|
struct DistanceMaximizeFunctor
|
|
|
|
{
|
|
|
|
bool operator()(const TDistance & lhs, const TDistance & rhs) const
|
|
|
|
{
|
|
|
|
return (rhs.second > lhs.second);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2023-07-06 22:15:00 +02:00
|
|
|
struct RequiredObjectInfo
|
|
|
|
{
|
|
|
|
RequiredObjectInfo();
|
2023-07-07 20:17:20 +02:00
|
|
|
RequiredObjectInfo(CGObjectInstance* obj, ui32 guardStrength = 0, bool createRoad = false, CGObjectInstance* nearbyTarget = nullptr);
|
2023-07-06 22:15:00 +02:00
|
|
|
|
|
|
|
CGObjectInstance* obj;
|
|
|
|
CGObjectInstance* nearbyTarget;
|
|
|
|
int3 pos;
|
|
|
|
ui32 guardStrength;
|
2023-07-07 20:17:20 +02:00
|
|
|
bool createRoad;
|
2023-07-06 22:15:00 +02:00
|
|
|
};
|
|
|
|
|
2022-08-09 09:54:32 +04:00
|
|
|
class ObjectManager: public Modificator
|
|
|
|
{
|
2022-08-20 14:17:27 +04:00
|
|
|
public:
|
|
|
|
enum OptimizeType
|
|
|
|
{
|
|
|
|
NONE = 0x00000000,
|
|
|
|
WEIGHT = 0x00000001,
|
2023-12-12 07:40:54 +01:00
|
|
|
DISTANCE = 0x00000010,
|
|
|
|
BOTH = 0x00000011
|
2022-08-20 14:17:27 +04:00
|
|
|
};
|
2023-04-18 00:11:16 +03:00
|
|
|
|
2022-08-09 09:54:32 +04:00
|
|
|
public:
|
|
|
|
MODIFICATOR(ObjectManager);
|
2022-09-18 16:39:10 +02:00
|
|
|
|
2022-08-09 09:54:32 +04:00
|
|
|
void process() override;
|
|
|
|
void init() override;
|
2022-09-18 16:39:10 +02:00
|
|
|
|
2023-07-06 22:15:00 +02:00
|
|
|
void addRequiredObject(const RequiredObjectInfo & info);
|
|
|
|
void addCloseObject(const RequiredObjectInfo & info);
|
|
|
|
void addNearbyObject(const RequiredObjectInfo & info);
|
2022-09-18 16:39:10 +02:00
|
|
|
|
2023-12-18 14:25:07 +01:00
|
|
|
bool createMonoliths();
|
2022-08-09 09:54:32 +04:00
|
|
|
bool createRequiredObjects();
|
2022-09-18 16:39:10 +02:00
|
|
|
|
2022-08-20 14:17:27 +04:00
|
|
|
int3 findPlaceForObject(const rmg::Area & searchArea, rmg::Object & obj, si32 min_dist, OptimizeType optimizer) const;
|
2023-02-11 19:05:02 +03:00
|
|
|
int3 findPlaceForObject(const rmg::Area & searchArea, rmg::Object & obj, const std::function<float(const int3)> & weightFunction, OptimizeType optimizer) const;
|
2022-09-18 16:39:10 +02:00
|
|
|
|
2022-08-20 14:17:27 +04:00
|
|
|
rmg::Path placeAndConnectObject(const rmg::Area & searchArea, rmg::Object & obj, si32 min_dist, bool isGuarded, bool onlyStraight, OptimizeType optimizer) const;
|
2023-02-11 19:05:02 +03:00
|
|
|
rmg::Path placeAndConnectObject(const rmg::Area & searchArea, rmg::Object & obj, const std::function<float(const int3)> & weightFunction, bool isGuarded, bool onlyStraight, OptimizeType optimizer) const;
|
2022-09-18 16:39:10 +02:00
|
|
|
|
2022-08-09 09:54:32 +04:00
|
|
|
CGCreature * chooseGuard(si32 strength, bool zoneGuard = false);
|
|
|
|
bool addGuard(rmg::Object & object, si32 strength, bool zoneGuard = false);
|
2023-07-07 20:17:20 +02:00
|
|
|
void placeObject(rmg::Object & object, bool guarded, bool updateDistance, bool createRoad = false);
|
2022-09-18 16:39:10 +02:00
|
|
|
|
2022-08-09 09:54:32 +04:00
|
|
|
void updateDistances(const rmg::Object & obj);
|
2023-06-18 19:20:12 +02:00
|
|
|
void updateDistances(const int3& pos);
|
2023-06-25 18:31:54 +02:00
|
|
|
void updateDistances(std::function<ui32(const int3 & tile)> distanceFunction);
|
2022-08-20 14:17:27 +04:00
|
|
|
void createDistancesPriorityQueue();
|
2022-09-18 16:39:10 +02:00
|
|
|
|
2022-08-09 09:54:32 +04:00
|
|
|
const rmg::Area & getVisitableArea() const;
|
2022-09-04 08:54:06 +02:00
|
|
|
|
|
|
|
std::vector<CGObjectInstance*> getMines() const;
|
2022-08-09 09:54:32 +04:00
|
|
|
|
|
|
|
protected:
|
|
|
|
//content info
|
2023-07-06 22:15:00 +02:00
|
|
|
std::vector<RequiredObjectInfo> requiredObjects;
|
|
|
|
std::vector<RequiredObjectInfo> closeObjects;
|
|
|
|
std::vector<RequiredObjectInfo> instantObjects;
|
|
|
|
std::vector<RequiredObjectInfo> nearbyObjects;
|
2022-08-09 09:54:32 +04:00
|
|
|
std::vector<CGObjectInstance*> objects;
|
|
|
|
rmg::Area objectsVisitableArea;
|
2022-08-20 14:17:27 +04:00
|
|
|
|
|
|
|
boost::heap::priority_queue<TDistance, boost::heap::compare<DistanceMaximizeFunctor>> tilesByDistance;
|
|
|
|
|
2022-08-09 09:54:32 +04:00
|
|
|
};
|
2022-07-26 16:07:42 +03:00
|
|
|
|
|
|
|
VCMI_LIB_NAMESPACE_END
|