#define VCMI_DLL #include "../stdafx.h" #include "CHeroHandler.h" #include #include "CLodHandler.h" #include "../lib/VCMI_Lib.h" extern CLodHandler * bitmaph; void loadToIt(std::string &dest, std::string &src, int &iter, int mode); CHeroClass::CHeroClass() { skillLimit = 8; } CHeroClass::~CHeroClass() { } int CHeroClass::chooseSecSkill(std::set possibles) //picks secondary skill out from given possibilities { if(possibles.size()==1) return *possibles.begin(); int totalProb = 0; for(std::set::iterator i=possibles.begin(); i!=possibles.end(); i++) { totalProb += proSec[*i]; } int ran = rand()%totalProb; for(std::set::iterator i=possibles.begin(); i!=possibles.end(); i++) { ran -= proSec[*i]; if(ran<0) return *i; } } CHeroHandler::~CHeroHandler() {} void CHeroHandler::loadPortraits() { std::string strs = bitmaph->getTextFile("PRISKILL.TXT"); int itr=0; for (int i=0; iheroh = this; int ID=0; std::string buf = bitmaph->getTextFile("HOTRAITS.TXT"); int it=0; std::string dump; for(int i=0; i<2; ++i) { loadToIt(dump,buf,it,3); } int numberOfCurrentClassHeroes = 0; int currentClass = 0; int additHero = 0; EHeroClasses addTab[12]; addTab[0] = HERO_KNIGHT; addTab[1] = HERO_WITCH; addTab[2] = HERO_KNIGHT; addTab[3] = HERO_WIZARD; addTab[4] = HERO_RANGER; addTab[5] = HERO_BARBARIAN; addTab[6] = HERO_DEATHKNIGHT; addTab[7] = HERO_WARLOCK; addTab[8] = HERO_KNIGHT; addTab[9] = HERO_WARLOCK; addTab[10] = HERO_BARBARIAN; addTab[11] = HERO_DEMONIAC; for (int i=0; iheroType = (EHeroClasses)currentClass; ++numberOfCurrentClassHeroes; if(numberOfCurrentClassHeroes==8) { numberOfCurrentClassHeroes = 0; ++currentClass; } } else { nher->heroType = addTab[additHero++]; } std::string pom ; loadToIt(nher->name,buf,it,4); for(int x=0;x<3;x++) { loadToIt(pom,buf,it,4); nher->lowStack[x] = atoi(pom.c_str()); loadToIt(pom,buf,it,4); nher->highStack[x] = atoi(pom.c_str()); loadToIt(nher->refTypeStack[x],buf,it,(x==2) ? (3) : (4)); int hlp = nher->refTypeStack[x].find_first_of(' ',0); if(hlp>=0) nher->refTypeStack[x].replace(hlp,1,""); } nher->ID = heroes.size(); heroes.push_back(nher); } loadSpecialAbilities(); loadBiographies(); loadHeroClasses(); initHeroClasses(); expPerLevel.push_back(0); expPerLevel.push_back(1000); expPerLevel.push_back(2000); expPerLevel.push_back(3200); expPerLevel.push_back(4500); expPerLevel.push_back(6000); expPerLevel.push_back(7700); expPerLevel.push_back(9000); expPerLevel.push_back(11000); expPerLevel.push_back(13200); expPerLevel.push_back(15500); expPerLevel.push_back(18500); expPerLevel.push_back(22100); expPerLevel.push_back(26420); expPerLevel.push_back(31604); return; } void CHeroHandler::loadSpecialAbilities() { std::string buf = bitmaph->getTextFile("HEROSPEC.TXT"); int it=0; std::string dump; for(int i=0; i<2; ++i) { loadToIt(dump,buf,it,3); } for (int i=0;ibonusName,buf,it,4); loadToIt(heroes[i]->shortBonus,buf,it,4); loadToIt(heroes[i]->longBonus,buf,it,3); } } void CHeroHandler::loadBiographies() { std::string buf = bitmaph->getTextFile("HEROBIOS.TXT"); int it=0; for (int i=0;ibiography,buf,it,3); } } void CHeroHandler::loadHeroClasses() { std::string buf = bitmaph->getTextFile("HCTRAITS.TXT"); int andame = buf.size(); for(int y=0; yname = buf.substr(befi, i-befi); ++i; befi=i; for(i; iaggression = atof(buf.substr(befi, i-befi).c_str()); ++i; befi=i; for(i; iinitialAttack = atoi(buf.substr(befi, i-befi).c_str()); ++i; befi=i; for(i; iinitialDefence = atoi(buf.substr(befi, i-befi).c_str()); ++i; befi=i; for(i; iinitialPower = atoi(buf.substr(befi, i-befi).c_str()); ++i; befi=i; for(i; iinitialKnowledge = atoi(buf.substr(befi, i-befi).c_str()); ++i; hc->primChance.resize(PRIMARY_SKILLS); for(int x=0;xprimChance[x].first = atoi(buf.substr(befi, i-befi).c_str()); ++i; } for(int x=0;xprimChance[x].second = atoi(buf.substr(befi, i-befi).c_str()); ++i; } //CHero kkk = heroes[0]; for(int dd=0; ddproSec.push_back(buff); } for(int dd=0; dd<9; ++dd) { befi=i; for(i; iselectionProbability[dd] = atoi(buf.substr(befi, i-befi).c_str()); ++i; } ++i; heroClasses.push_back(hc); } } void CHeroHandler::initHeroClasses() { for(int gg=0; ggheroClass = heroClasses[heroes[gg]->heroType]; } initTerrainCosts(); } unsigned int CHeroHandler::level(unsigned int experience) { int add=0; while(experience>=expPerLevel[expPerLevel.size()-1]) { experience/=1.2; add+=1; } for(int i=expPerLevel.size()-1; i>=0; --i) { if(experience>=expPerLevel[i]) return i+add; } return -1; } unsigned int CHeroHandler::reqExp(unsigned int level) { level-=1; if(level<=expPerLevel.size()) return expPerLevel[level]; else { unsigned int exp = expPerLevel[expPerLevel.size()-1]; level-=expPerLevel.size(); while(level>0) { --level; exp*=1.2; } } return -1; } void CHeroHandler::initTerrainCosts() { std::ifstream inp; inp.open("config" PATHSEPARATOR "TERCOSTS.TXT", std::ios_base::in|std::ios_base::binary); int tynum; inp>>tynum; for(int i=0; i<2*tynum; i+=2) { int catNum; inp>>catNum; for(int k=0; k>curCost; heroClasses[i]->terrCosts.push_back(curCost); heroClasses[i+1]->terrCosts.push_back(curCost); } } inp.close(); }