2025-08-07 22:01:34 -07:00
|
|
|
/* Copyright (C) 2025 Wildfire Games.
|
2023-12-02 16:30:12 -08:00
|
|
|
* This file is part of 0 A.D.
|
2011-07-20 12:48:06 -07:00
|
|
|
*
|
2023-12-02 16:30:12 -08:00
|
|
|
* 0 A.D. is free software: you can redistribute it and/or modify
|
2011-07-20 12:48:06 -07:00
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
|
* the Free Software Foundation, either version 2 of the License, or
|
|
|
|
|
* (at your option) any later version.
|
|
|
|
|
*
|
2023-12-02 16:30:12 -08:00
|
|
|
* 0 A.D. is distributed in the hope that it will be useful,
|
2011-07-20 12:48:06 -07:00
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU General Public License
|
2023-12-02 16:30:12 -08:00
|
|
|
* along with 0 A.D. If not, see <http://www.gnu.org/licenses/>.
|
2011-07-20 12:48:06 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#ifndef INCLUDED_ICMPTERRITORYMANAGER
|
|
|
|
|
#define INCLUDED_ICMPTERRITORYMANAGER
|
|
|
|
|
|
2025-08-07 22:01:34 -07:00
|
|
|
#include "lib/types.h"
|
2011-08-18 13:28:53 -07:00
|
|
|
#include "simulation2/helpers/Player.h"
|
2025-08-07 22:01:34 -07:00
|
|
|
#include "simulation2/helpers/Position.h"
|
|
|
|
|
#include "simulation2/system/Component.h"
|
|
|
|
|
#include "simulation2/system/Interface.h"
|
2011-07-20 12:48:06 -07:00
|
|
|
|
2025-08-07 22:01:34 -07:00
|
|
|
#include <cstddef>
|
|
|
|
|
#include <js/Value.h>
|
2020-12-09 06:39:14 -08:00
|
|
|
#include <vector>
|
|
|
|
|
|
2025-08-07 22:01:34 -07:00
|
|
|
template<typename T> class Grid;
|
2017-12-10 00:59:43 -08:00
|
|
|
|
2011-07-20 12:48:06 -07:00
|
|
|
class ICmpTerritoryManager : public IComponent
|
|
|
|
|
{
|
|
|
|
|
public:
|
2018-02-03 06:17:31 -08:00
|
|
|
/**
|
|
|
|
|
* Returns whether the territory texture needs to be updated.
|
|
|
|
|
*/
|
|
|
|
|
virtual bool NeedUpdateTexture(size_t* dirtyID) = 0;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns whether the AI territory map needs to be updated.
|
|
|
|
|
*/
|
|
|
|
|
virtual bool NeedUpdateAI(size_t* dirtyID, size_t* dirtyBlinkingID) const = 0;
|
2011-07-20 12:48:06 -07:00
|
|
|
|
New long-range pathfinder.
Based on Philip's work located at
http://git.wildfiregames.com/gitweb/?p=0ad.git;a=shortlog;h=refs/heads/projects/philip/pathfinder
Includes code by wraitii, sanderd17 and kanetaka.
An updated version of docs/pathfinder.pdf describing the changes in
detail will be committed ASAP.
Running update-workspaces is needed after this change.
Fixes #1756.
Fixes #930, #1259, #2908, #2960, #3097
Refs #1200, #1914, #1942, #2568, #2132, #2563
This was SVN commit r16751.
2015-06-12 11:58:24 -07:00
|
|
|
/**
|
|
|
|
|
* Number of pathfinder navcells per territory tile.
|
|
|
|
|
* Passability data is stored per navcell, but we probably don't need that much
|
|
|
|
|
* resolution, and a lower resolution can make the boundary lines look prettier
|
|
|
|
|
* and will take less memory, so we downsample the passability data.
|
|
|
|
|
*/
|
|
|
|
|
static const int NAVCELLS_PER_TERRITORY_TILE = 8;
|
|
|
|
|
|
2015-05-29 00:02:16 -07:00
|
|
|
static const int TERRITORY_PLAYER_MASK = 0x1F;
|
|
|
|
|
static const int TERRITORY_CONNECTED_MASK = 0x20;
|
|
|
|
|
static const int TERRITORY_BLINKING_MASK = 0x40;
|
2012-01-18 13:22:58 -08:00
|
|
|
static const int TERRITORY_PROCESSED_MASK = 0x80; //< For internal use; marks a tile as processed.
|
2011-08-18 13:28:53 -07:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* For each tile, the TERRITORY_PLAYER_MASK bits are player ID;
|
|
|
|
|
* TERRITORY_CONNECTED_MASK is set if the tile is connected to a root object
|
|
|
|
|
* (civ center etc).
|
|
|
|
|
*/
|
2011-07-20 12:48:06 -07:00
|
|
|
virtual const Grid<u8>& GetTerritoryGrid() = 0;
|
|
|
|
|
|
2011-08-06 01:11:05 -07:00
|
|
|
/**
|
2011-08-18 13:28:53 -07:00
|
|
|
* Get owner of territory at given position.
|
2011-08-06 01:11:05 -07:00
|
|
|
* @return player ID of owner; 0 if neutral territory
|
|
|
|
|
*/
|
2011-08-18 13:28:53 -07:00
|
|
|
virtual player_id_t GetOwner(entity_pos_t x, entity_pos_t z) = 0;
|
|
|
|
|
|
2015-05-25 07:17:45 -07:00
|
|
|
/**
|
|
|
|
|
* get the number of neighbour tiles for per player for the selected position
|
|
|
|
|
* @return A list with the number of neighbour tiles per player
|
|
|
|
|
*/
|
|
|
|
|
virtual std::vector<u32> GetNeighbours(entity_pos_t x, entity_pos_t z, bool filterConnected) = 0;
|
|
|
|
|
|
2011-08-18 13:28:53 -07:00
|
|
|
/**
|
|
|
|
|
* Get whether territory at given position is connected to a root object
|
|
|
|
|
* (civ center etc) owned by that territory's player.
|
|
|
|
|
*/
|
|
|
|
|
virtual bool IsConnected(entity_pos_t x, entity_pos_t z) = 0;
|
2011-08-06 01:11:05 -07:00
|
|
|
|
2015-05-29 00:02:16 -07:00
|
|
|
/**
|
|
|
|
|
* Set a piece of territory to blinking. Must be updated on every territory calculation
|
|
|
|
|
*/
|
2016-04-09 12:57:34 -07:00
|
|
|
virtual void SetTerritoryBlinking(entity_pos_t x, entity_pos_t z, bool enable) = 0;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Check if a piece of territory is blinking.
|
|
|
|
|
*/
|
|
|
|
|
virtual bool IsTerritoryBlinking(entity_pos_t x, entity_pos_t z) = 0;
|
2015-05-29 00:02:16 -07:00
|
|
|
|
2015-08-23 10:44:37 -07:00
|
|
|
/**
|
|
|
|
|
* Returns the percentage of the world controlled by a given player as defined by
|
|
|
|
|
* the number of territory cells the given player owns
|
|
|
|
|
*/
|
|
|
|
|
virtual u8 GetTerritoryPercentage(player_id_t player) = 0;
|
|
|
|
|
|
2016-01-03 04:41:04 -08:00
|
|
|
/**
|
|
|
|
|
* Enables or disables rendering of an territory borders.
|
|
|
|
|
*/
|
|
|
|
|
virtual void SetVisibility(bool visible) = 0;
|
|
|
|
|
|
2018-02-03 06:17:31 -08:00
|
|
|
/**
|
|
|
|
|
* Updates the boundary and territory colors.
|
|
|
|
|
*/
|
|
|
|
|
virtual void UpdateColors() = 0;
|
|
|
|
|
|
2024-11-02 16:05:26 -07:00
|
|
|
/**
|
|
|
|
|
* Whether the territory lines are visible.
|
|
|
|
|
*/
|
|
|
|
|
virtual bool IsVisible() const = 0;
|
|
|
|
|
|
2011-07-20 12:48:06 -07:00
|
|
|
DECLARE_INTERFACE_TYPE(TerritoryManager)
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
#endif // INCLUDED_ICMPTERRITORYMANAGER
|