2013-08-17 12:46:48 +00:00
|
|
|
/*
|
|
|
|
* CMapGenOptions.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
|
|
|
|
|
|
|
|
#include "../GameConstants.h"
|
2022-12-14 04:37:11 +04:00
|
|
|
#include "CRmgTemplate.h"
|
2013-08-17 12:46:48 +00:00
|
|
|
|
2022-07-26 16:07:42 +03:00
|
|
|
VCMI_LIB_NAMESPACE_BEGIN
|
|
|
|
|
2022-05-31 12:25:39 +03:00
|
|
|
class CRandomGenerator;
|
2013-08-17 12:46:48 +00:00
|
|
|
|
2023-05-20 13:29:55 +02:00
|
|
|
enum class EPlayerType
|
2013-08-17 12:46:48 +00:00
|
|
|
{
|
2023-05-20 13:29:55 +02:00
|
|
|
HUMAN,
|
|
|
|
AI,
|
|
|
|
COMP_ONLY
|
|
|
|
};
|
2013-08-17 12:46:48 +00:00
|
|
|
|
|
|
|
/// The map gen options class holds values about general map generation settings
|
|
|
|
/// e.g. the size of the map, the count of players,...
|
|
|
|
class DLL_LINKAGE CMapGenOptions
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/// The player settings class maps the player color, starting town and human player flag.
|
|
|
|
class DLL_LINKAGE CPlayerSettings
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
CPlayerSettings();
|
|
|
|
|
|
|
|
/// The color of the player ranging from 0 to PlayerColor::PLAYER_LIMIT - 1.
|
|
|
|
/// The default value is 0.
|
|
|
|
PlayerColor getColor() const;
|
2023-02-11 19:05:02 +03:00
|
|
|
void setColor(const PlayerColor & value);
|
2013-08-17 12:46:48 +00:00
|
|
|
|
|
|
|
/// The starting town of the player ranging from 0 to town max count or RANDOM_TOWN.
|
|
|
|
/// The default value is RANDOM_TOWN.
|
|
|
|
si32 getStartingTown() const;
|
|
|
|
void setStartingTown(si32 value);
|
|
|
|
|
|
|
|
/// The default value is EPlayerType::AI.
|
2023-05-20 13:29:55 +02:00
|
|
|
EPlayerType getPlayerType() const;
|
|
|
|
void setPlayerType(EPlayerType value);
|
2022-12-17 03:52:40 +04:00
|
|
|
|
|
|
|
/// Team id for this player. TeamID::NO_TEAM by default - team will be randomly assigned
|
|
|
|
TeamID getTeam() const;
|
2023-02-11 19:05:02 +03:00
|
|
|
void setTeam(const TeamID & value);
|
2013-08-17 12:46:48 +00:00
|
|
|
|
|
|
|
/// Constant for a random town selection.
|
|
|
|
static const si32 RANDOM_TOWN = -1;
|
|
|
|
|
|
|
|
private:
|
|
|
|
PlayerColor color;
|
|
|
|
si32 startingTown;
|
2023-05-20 13:29:55 +02:00
|
|
|
EPlayerType playerType;
|
2022-12-17 03:52:40 +04:00
|
|
|
TeamID team;
|
2013-08-17 12:46:48 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
template <typename Handler>
|
|
|
|
void serialize(Handler & h, const int version)
|
|
|
|
{
|
2017-07-31 16:35:42 +03:00
|
|
|
h & color;
|
|
|
|
h & startingTown;
|
|
|
|
h & playerType;
|
2022-12-17 03:52:40 +04:00
|
|
|
if(version >= 806)
|
|
|
|
h & team;
|
2013-08-17 12:46:48 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
CMapGenOptions();
|
2022-05-28 16:03:50 +03:00
|
|
|
CMapGenOptions(const CMapGenOptions&) = delete;
|
2013-08-17 12:46:48 +00:00
|
|
|
|
|
|
|
si32 getWidth() const;
|
|
|
|
void setWidth(si32 value);
|
|
|
|
|
|
|
|
si32 getHeight() const;
|
|
|
|
void setHeight(si32 value);
|
|
|
|
|
|
|
|
bool getHasTwoLevels() const;
|
|
|
|
void setHasTwoLevels(bool value);
|
|
|
|
|
2015-05-27 11:30:46 +02:00
|
|
|
/// The count of all (human or computer) players ranging from 1 to PlayerColor::PLAYER_LIMIT or RANDOM_SIZE for random. If you call
|
2013-08-17 12:46:48 +00:00
|
|
|
/// this method, all player settings are reset to default settings.
|
|
|
|
si8 getPlayerCount() const;
|
|
|
|
void setPlayerCount(si8 value);
|
|
|
|
|
|
|
|
/// The count of the teams ranging from 0 to <players count - 1> or RANDOM_SIZE for random.
|
|
|
|
si8 getTeamCount() const;
|
|
|
|
void setTeamCount(si8 value);
|
|
|
|
|
|
|
|
/// The count of the computer only players ranging from 0 to <PlayerColor::PLAYER_LIMIT - players count> or RANDOM_SIZE for random.
|
|
|
|
/// If you call this method, all player settings are reset to default settings.
|
|
|
|
si8 getCompOnlyPlayerCount() const;
|
|
|
|
void setCompOnlyPlayerCount(si8 value);
|
|
|
|
|
|
|
|
/// The count of the computer only teams ranging from 0 to <comp only players - 1> or RANDOM_SIZE for random.
|
|
|
|
si8 getCompOnlyTeamCount() const;
|
|
|
|
void setCompOnlyTeamCount(si8 value);
|
|
|
|
|
|
|
|
EWaterContent::EWaterContent getWaterContent() const;
|
|
|
|
void setWaterContent(EWaterContent::EWaterContent value);
|
|
|
|
|
2023-05-21 00:13:45 +02:00
|
|
|
EMonsterStrength::EMonsterStrength getMonsterStrength() const;
|
|
|
|
void setMonsterStrength(EMonsterStrength::EMonsterStrength value);
|
2022-12-17 03:52:40 +04:00
|
|
|
|
|
|
|
bool isRoadEnabled(const std::string & roadName) const;
|
|
|
|
void setRoadEnabled(const std::string & roadName, bool enable);
|
2013-08-17 12:46:48 +00:00
|
|
|
|
|
|
|
/// The first player colors belong to standard players and the last player colors belong to comp only players.
|
|
|
|
/// All standard players are by default of type EPlayerType::AI.
|
|
|
|
const std::map<PlayerColor, CPlayerSettings> & getPlayersSettings() const;
|
2023-02-11 19:05:02 +03:00
|
|
|
void setStartingTownForPlayer(const PlayerColor & color, si32 town);
|
2013-08-17 12:46:48 +00:00
|
|
|
/// Sets a player type for a standard player. A standard player is the opposite of a computer only player. The
|
|
|
|
/// values which can be chosen for the player type are EPlayerType::AI or EPlayerType::HUMAN.
|
2023-05-20 13:29:55 +02:00
|
|
|
void setPlayerTypeForStandardPlayer(const PlayerColor & color, EPlayerType playerType);
|
2023-02-11 19:05:02 +03:00
|
|
|
|
|
|
|
void setPlayerTeam(const PlayerColor & color, const TeamID & team = TeamID::NO_TEAM);
|
2013-08-17 12:46:48 +00:00
|
|
|
|
|
|
|
/// The random map template to generate the map with or empty/not set if the template should be chosen randomly.
|
|
|
|
/// Default: Not set/random.
|
|
|
|
const CRmgTemplate * getMapTemplate() const;
|
|
|
|
void setMapTemplate(const CRmgTemplate * value);
|
2022-12-14 04:37:11 +04:00
|
|
|
void setMapTemplate(const std::string & name);
|
2013-08-17 12:46:48 +00:00
|
|
|
|
2022-09-17 15:04:01 +04:00
|
|
|
std::vector<const CRmgTemplate *> getPossibleTemplates() const;
|
|
|
|
|
2013-08-17 12:46:48 +00:00
|
|
|
/// Finalizes the options. All random sizes for various properties will be overwritten by numbers from
|
|
|
|
/// a random number generator by keeping the options in a valid state. Check options should return true, otherwise
|
|
|
|
/// this function fails.
|
2014-03-17 19:51:07 +00:00
|
|
|
void finalize(CRandomGenerator & rand);
|
2013-08-17 12:46:48 +00:00
|
|
|
|
|
|
|
/// Returns false if there is no template available which fits to the currently selected options.
|
|
|
|
bool checkOptions() const;
|
|
|
|
|
|
|
|
static const si8 RANDOM_SIZE = -1;
|
|
|
|
|
|
|
|
private:
|
|
|
|
void resetPlayersMap();
|
|
|
|
int countHumanPlayers() const;
|
2015-06-02 07:01:38 +02:00
|
|
|
int countCompOnlyPlayers() const;
|
2013-08-17 12:46:48 +00:00
|
|
|
PlayerColor getNextPlayerColor() const;
|
|
|
|
void updateCompOnlyPlayers();
|
|
|
|
void updatePlayers();
|
2014-03-17 19:51:07 +00:00
|
|
|
const CRmgTemplate * getPossibleTemplate(CRandomGenerator & rand) const;
|
2013-08-17 12:46:48 +00:00
|
|
|
|
|
|
|
si32 width, height;
|
|
|
|
bool hasTwoLevels;
|
2020-07-07 19:45:53 +08:00
|
|
|
si8 playerCount, teamCount, compOnlyPlayerCount, compOnlyTeamCount;
|
2013-08-17 12:46:48 +00:00
|
|
|
EWaterContent::EWaterContent waterContent;
|
2023-05-21 00:13:45 +02:00
|
|
|
EMonsterStrength::EMonsterStrength monsterStrength;
|
2013-08-17 12:46:48 +00:00
|
|
|
std::map<PlayerColor, CPlayerSettings> players;
|
2022-12-17 03:52:40 +04:00
|
|
|
std::set<std::string> disabledRoads;
|
|
|
|
|
2013-08-17 12:46:48 +00:00
|
|
|
const CRmgTemplate * mapTemplate;
|
|
|
|
|
|
|
|
public:
|
|
|
|
template <typename Handler>
|
|
|
|
void serialize(Handler & h, const int version)
|
|
|
|
{
|
2017-07-31 16:35:42 +03:00
|
|
|
h & width;
|
|
|
|
h & height;
|
|
|
|
h & hasTwoLevels;
|
|
|
|
h & playerCount;
|
|
|
|
h & teamCount;
|
|
|
|
h & compOnlyPlayerCount;
|
|
|
|
h & compOnlyTeamCount;
|
|
|
|
h & waterContent;
|
|
|
|
h & monsterStrength;
|
|
|
|
h & players;
|
2022-12-14 04:37:11 +04:00
|
|
|
std::string templateName;
|
|
|
|
if(mapTemplate && h.saving)
|
|
|
|
{
|
|
|
|
templateName = mapTemplate->getId();
|
|
|
|
}
|
2022-12-17 03:52:40 +04:00
|
|
|
if(version >= 806)
|
2022-12-14 04:37:11 +04:00
|
|
|
{
|
2022-12-17 03:52:40 +04:00
|
|
|
h & templateName;
|
|
|
|
if(!h.saving)
|
|
|
|
{
|
|
|
|
setMapTemplate(templateName);
|
|
|
|
}
|
|
|
|
|
|
|
|
h & disabledRoads;
|
2022-12-14 04:37:11 +04:00
|
|
|
}
|
2013-08-17 12:46:48 +00:00
|
|
|
}
|
|
|
|
};
|
2022-07-26 16:07:42 +03:00
|
|
|
|
|
|
|
VCMI_LIB_NAMESPACE_END
|