1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-12 02:28:11 +02:00

- fixed empty tavern in new towns

- by default new heroes\new towns will be enabled on maps (no effect without mods)
This commit is contained in:
Ivan Savenko 2012-12-17 12:55:29 +00:00
parent e775ad8804
commit ff146a80fe
7 changed files with 63 additions and 33 deletions

View File

@ -2298,16 +2298,16 @@ void OptionsTab::nextHero( int player, int dir )
if (s.hero == PlayerSettings::RANDOM) // first/last available
{
int max = (s.castle*GameConstants::HEROES_PER_TYPE*2+15),
min = (s.castle*GameConstants::HEROES_PER_TYPE*2);
s.hero = nextAllowedHero(min,max,0,dir);
int max = CGI->heroh->heroes.size(),
min = 0;
s.hero = nextAllowedHero(player, min,max,0,dir);
}
else
{
if(dir > 0)
s.hero = nextAllowedHero(s.hero,(s.castle*GameConstants::HEROES_PER_TYPE*2+16),1,dir);
s.hero = nextAllowedHero(player, s.hero, CGI->heroh->heroes.size(), 1, dir);
else
s.hero = nextAllowedHero(s.castle*GameConstants::HEROES_PER_TYPE*2-1,s.hero,1,dir);
s.hero = nextAllowedHero(player, 0, s.hero, 1, dir);
}
if(old != s.hero)
@ -2320,28 +2320,29 @@ void OptionsTab::nextHero( int player, int dir )
SEL->propagateOptions();
}
int OptionsTab::nextAllowedHero( int min, int max, int incl, int dir )
int OptionsTab::nextAllowedHero( int player, int min, int max, int incl, int dir )
{
if(dir>0)
{
for(int i=min+incl; i<=max-incl; i++)
if(canUseThisHero(i))
if(canUseThisHero(player, i))
return i;
}
else
{
for(int i=max-incl; i>=min+incl; i--)
if(canUseThisHero(i))
if(canUseThisHero(player, i))
return i;
}
return -1;
}
bool OptionsTab::canUseThisHero( int ID )
bool OptionsTab::canUseThisHero( int player, int ID )
{
return CGI->heroh->heroes.size() > ID
&& !vstd::contains(usedHeroes, ID)
&& SEL->current->mapHeader->allowedHeroes[ID];
&& SEL->sInfo.playerInfos[player].castle == CGI->heroh->heroes[ID]->heroClass->faction
&& !vstd::contains(usedHeroes, ID)
&& SEL->current->mapHeader->allowedHeroes[ID];
}
void OptionsTab::nextBonus( int player, int dir )

View File

@ -276,9 +276,9 @@ public:
~OptionsTab();
void showAll(SDL_Surface * to);
int nextAllowedHero( int min, int max, int incl, int dir );
int nextAllowedHero(int player, int min, int max, int incl, int dir );
bool canUseThisHero( int ID );
bool canUseThisHero(int player, int ID );
};
/**

View File

@ -66,6 +66,7 @@
"id": 4,
"class" : "knight",
"female": false,
"special" : true,
"skills":
[
{ "skill" : "leadership", "level": "basic" },
@ -2103,6 +2104,7 @@
"id": 144,
"class" : "knight",
"female": false,
"special" : true,
"skills":
[
{ "skill" : "leadership", "level": "advanced" }
@ -2116,6 +2118,7 @@
"id": 145,
"class" : "witch",
"female": true,
"special" : true,
"spellbook": [ 22 ],
"skills":
[
@ -2130,6 +2133,7 @@
"id": 146,
"class" : "knight",
"female": true,
"special" : true,
"skills":
[
{ "skill" : "leadership", "level": "basic" },
@ -2144,6 +2148,7 @@
"id": 147,
"class" : "wizard",
"female": false,
"special" : true,
"spellbook": [ 53 ],
"skills":
[
@ -2159,6 +2164,7 @@
"id": 148,
"class" : "ranger",
"female": false,
"special" : true,
"skills":
[
{ "skill" : "archery", "level": "basic" },
@ -2174,6 +2180,7 @@
"id": 149,
"class" : "barbarian",
"female": false,
"special" : true,
"skills":
[
{ "skill" : "offence", "level": "advanced" }
@ -2189,6 +2196,7 @@
"id": 150,
"class" : "deathknight",
"female": false,
"special" : true,
"spellbook": [ 54 ],
"skills":
[
@ -2205,6 +2213,7 @@
"id": 151,
"class" : "warlock",
"female": true,
"special" : true,
"spellbook": [ 15 ],
"skills":
[
@ -2221,6 +2230,7 @@
"id": 152,
"class" : "knight",
"female": false,
"special" : true,
"skills":
[
{ "skill" : "leadership", "level": "basic" },
@ -2235,6 +2245,7 @@
"id": 153,
"class" : "warlock",
"female": true,
"special" : true,
"spellbook": [ 15 ],
"skills":
[
@ -2251,6 +2262,7 @@
"id": 154,
"class" : "barbarian",
"female": false,
"special" : true,
"skills":
[
{ "skill" : "tactics", "level": "basic" },
@ -2265,6 +2277,7 @@
"id": 155,
"class" : "demoniac",
"female": false,
"special" : true,
"skills":
[
{ "skill" : "leadership", "level": "basic" },

View File

@ -217,7 +217,7 @@ void CHeroHandler::load(const JsonNode & input)
hero->ID = heroes.size();
heroes.push_back(hero);
tlog3 << "Added hero : " << entry.first << "\n";
tlog3 << "Added hero: " << entry.first << "\n";
VLC->modh->identifiers.registerObject("hero." + entry.first, hero->ID);
}
}
@ -264,7 +264,8 @@ CHero * CHeroHandler::loadHero(const JsonNode & node)
void CHeroHandler::loadHeroJson(CHero * hero, const JsonNode & node)
{
// sex: 0=male, 1=female
hero->sex = !!node["female"].Bool();
hero->sex = node["female"].Bool();
hero->special = node["special"].Bool();
BOOST_FOREACH(const JsonNode &set, node["skills"].Vector())
{
@ -418,7 +419,7 @@ void CHeroHandler::loadHeroTexts()
hero->specDescr = parser.readString();
hero->biography = bioParser.readString();
}
while (parser.endLine() && bioParser.endLine() && heroes.size() < i);
while (parser.endLine() && bioParser.endLine() && heroes.size() > i);
}
void CHeroHandler::loadBallistics()
@ -482,12 +483,12 @@ std::vector<ui8> CHeroHandler::getDefaultAllowedHeroes() const
{
// Look Data/HOTRAITS.txt for reference
std::vector<ui8> allowedHeroes;
allowedHeroes.resize(156, 1);
for(int i = 145; i < 156; ++i)
allowedHeroes.reserve(heroes.size());
BOOST_FOREACH(const CHero * hero, heroes)
{
allowedHeroes[i] = 0;
allowedHeroes.push_back(!hero->special);
}
allowedHeroes[4] = 0;
allowedHeroes[25] = 0;
return allowedHeroes;
}
}

View File

@ -56,6 +56,7 @@ public:
std::vector<SSpecialtyInfo> spec;
std::set<si32> spells;
ui8 sex; // default sex: 0=male, 1=female
ui8 special; // hero is special and won't be placed in game (unless preset on map), e.g. campaign heroes
/// Localized texts
std::string name; //name of hero

View File

@ -6,6 +6,7 @@
#include "JsonNode.h"
#include "StringConstants.h"
#include "CModHandler.h"
#include "CHeroHandler.h"
#include "CArtHandler.h"
#include "Filesystem/CResourceLoader.h"
@ -435,7 +436,17 @@ void CTownHandler::loadTown(CTown &town, const JsonNode & source)
town.creatures[i][j] = creature;
});
}
}
/// set chance of specific hero class to appear in this town
BOOST_FOREACH(auto &node, source["tavern"].Struct())
{
int chance = node.second.Float();
VLC->modh->identifiers.requestIdentifier(std::string("heroClass.") + node.first, [=, &town](si32 classID)
{
VLC->heroh->classes.heroClasses[classID]->selectionProbability[town.typeID] = chance;
});
}
loadBuildings(town, source["buildings"]);

View File

@ -12,6 +12,7 @@
#include "../VCMI_Lib.h"
#include "../CSpellHandler.h"
#include "../CCreatureHandler.h"
#include "../CHeroHandler.h"
#include "../CObjectHandler.h"
#include "../CDefObjInfoHandler.h"
@ -268,17 +269,19 @@ void CMapLoaderH3M::readPlayerInfo()
// Factions this player can choose
ui16 allowedFactions = buffer[pos++];
if(mapHeader->version != EMapFormat::ROE)
{
allowedFactions += (buffer[pos++]) * 256;
}
// How many factions will be read from map
ui16 totalFactions = GameConstants::F_NUMBER;
mapHeader->players[i].allowedFactions.clear();
for(int fact = 0; fact < 16; ++fact)
if(mapHeader->version != EMapFormat::ROE)
allowedFactions += (buffer[pos++]) * 256;
else
totalFactions--; //exclude conflux for ROE
for(int fact = 0; fact < totalFactions; ++fact)
{
if(allowedFactions & (1 << fact))
if(!(allowedFactions & (1 << fact)))
{
mapHeader->players[i].allowedFactions.insert(fact);
mapHeader->players[i].allowedFactions.erase(fact);
}
}
@ -475,7 +478,7 @@ void CMapLoaderH3M::readTeamInfo()
void CMapLoaderH3M::readAllowedHeroes()
{
int pom = pos;
mapHeader->allowedHeroes.resize(GameConstants::HEROES_QUANTITY, false);
mapHeader->allowedHeroes.resize(VLC->heroh->heroes.size(), true);
for(; pos < pom + (mapHeader->version == EMapFormat::ROE ? 16 : 20) ; ++pos)
{
ui8 c = buffer[pos];
@ -483,9 +486,9 @@ void CMapLoaderH3M::readAllowedHeroes()
{
if((pos - pom) * 8 + yy < GameConstants::HEROES_QUANTITY)
{
if(c == (c | static_cast<ui8>(std::pow(2., yy))))
if(c != (c | static_cast<ui8>(std::pow(2., yy))))
{
mapHeader->allowedHeroes[(pos - pom) * 8 + yy] = true;
mapHeader->allowedHeroes[(pos - pom) * 8 + yy] = false;
}
}
}