1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
|
/* This file is part of the Spring engine (GPL v2 or later), see LICENSE.html */
#ifndef PATH_HEATMAP_HDR
#define PATH_HEATMAP_HDR
#include <vector>
class CPathManager;
class CSolidObject;
struct MoveDef;
/**
* Heat mapping makes the pathfinder favor unused paths more.
* Less path overlap should make units behave more intelligently.
*/
class PathHeatMap {
public:
static PathHeatMap* GetInstance();
static void FreeInstance(PathHeatMap*);
PathHeatMap(unsigned int sizex, unsigned int sizez);
~PathHeatMap();
void Update() { ++heatMapOffset; }
unsigned int GetHeatMapIndex(unsigned int x, unsigned int y) const;
void AddHeat(const CSolidObject* owner, const CPathManager* pm, unsigned int pathID);
void UpdateHeatValue(unsigned int x, unsigned int y, unsigned int value, unsigned int ownerID);
const int GetHeatValue(unsigned int x, unsigned int y) const {
const unsigned int idx = GetHeatMapIndex(x, y);
const unsigned int val = heatMap[idx].value;
return (heatMapOffset >= val)? 0: (val - heatMapOffset);
}
float GetHeatCost(unsigned int x, unsigned int z, const MoveDef&, unsigned int ownerID) const;
private:
struct HeatCell {
HeatCell(): value(0), ownerID(0) {}
unsigned int value;
unsigned int ownerID;
};
bool enabled;
unsigned int heatMapOffset; //! heatmap values are relative to this
std::vector<HeatCell> heatMap; //! resolution is hmapx*hmapy
unsigned int xscale, xsize;
unsigned int zscale, zsize;
};
#endif
|