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

Refugee Camp supported.

This commit is contained in:
Michał W. Urbańczyk 2010-07-23 21:05:49 +00:00
parent 4e9e3fce73
commit a981dfd1fd
8 changed files with 57 additions and 77 deletions

View File

@ -656,3 +656,19 @@ void CCreatureHandler::loadUnitAnimInfo(CCreature & unit, std::string & src, int
CCreatureHandler::~CCreatureHandler()
{
}
int CCreatureHandler::pickRandomMonster(const boost::function<int()> &randGen) const
{
int r = 0;
do
{
if(randGen)
r = randGen();
else
r = rand();
r %= 197;
} while (vstd::contains(VLC->creh->notUsedMonsters,r));
return r;
}

View File

@ -113,6 +113,9 @@ public:
bool isGood (si8 faction) const;
bool isEvil (si8 faction) const;
int pickRandomMonster(const boost::function<int()> &randGen = 0) const;
CCreatureHandler();
~CCreatureHandler();

View File

@ -1568,6 +1568,10 @@ void CGDwelling::initObj()
hoverName = VLC->generaltexth->creGens4[subID];
break;
case 78: //Refugee Camp
//is handled within newturn func
break;
case 106: //War Machine Factory
creatures.resize(3);
creatures[0].second.push_back(146); //Ballista
@ -1597,11 +1601,26 @@ void CGDwelling::setProperty(ui8 what, ui32 val)
cb->gameState()->players[val].dwellings.push_back (this);
}
break;
case ObjProperty::AVAILABLE_CREATURE:
creatures.resize(1);
creatures[0].second.resize(1);
creatures[0].second[0] = val;
break;
}
CGObjectInstance::setProperty(what,val);
CGObjectInstance::setProperty(what,val);
}
void CGDwelling::onHeroVisit( const CGHeroInstance * h ) const
{
if(ID == 78 && !creatures[0].first) //Refugee Camp, no available cres
{
InfoWindow iw;
iw.player = h->tempOwner;
iw.text.addTxt(MetaString::ADVOB_TXT, 44); //{%s} \n\n The camp is deserted. Perhaps you should try next week.
iw.text.addReplacement(MetaString::OBJ_NAMES, ID);
cb->sendAndApply(&iw);
return;
}
if(h->tempOwner != tempOwner && stacksCount() > 0) //object is guarded
{
BlockingDialog bd;
@ -1630,6 +1649,13 @@ void CGDwelling::onHeroVisit( const CGHeroInstance * h ) const
for(size_t i = 0; i < creatures.size(); i++)
bd.text.addReplacement(MetaString::CRE_PL_NAMES, creatures[i].second[0]);
}
else if(ID == 78)
{
bd.text.addTxt(MetaString::ADVOB_TXT, 35); //{%s} Would you like to recruit %s?
bd.text.addReplacement(MetaString::OBJ_NAMES, ID);
for(size_t i = 0; i < creatures.size(); i++)
bd.text.addReplacement(MetaString::CRE_PL_NAMES, creatures[i].second[0]);
}
else if(ID == 106)
bd.text.addTxt(MetaString::ADVOB_TXT, 157); //{War Machine Factory} Would you like to purchase War Machines?
else
@ -1647,6 +1673,11 @@ void CGDwelling::newTurn() const
if(ID == TOWNI_TYPE || ID == 106)
return;
if(ID == 78) //if it's a refugee camp, we need to pick an available creature
{
cb->setObjProperty(id, ObjProperty::AVAILABLE_CREATURE, VLC->creh->pickRandomMonster());
}
bool change = false;
SetAvailableCreatures sac;
@ -1676,7 +1707,7 @@ void CGDwelling::heroAcceptsCreatures( const CGHeroInstance *h, ui32 answer ) co
int crid = creatures[0].second[0];
CCreature *crs = VLC->creh->creatures[crid];
if(crs->level == 1) //first level - creatures are for free
if(crs->level == 1 && ID != 78) //first level - creatures are for free
{
if(creatures[0].first) //there are available creatures
{
@ -1737,7 +1768,7 @@ void CGDwelling::heroAcceptsCreatures( const CGHeroInstance *h, ui32 answer ) co
OpenWindow ow;
ow.id1 = id;
ow.id2 = h->id;
ow.window = ID == 17
ow.window = (ID == 17 || ID == 78)
? OpenWindow::RECRUITMENT_FIRST
: OpenWindow::RECRUITMENT_ALL;
cb->sendAndApply(&ow);
@ -6175,41 +6206,6 @@ void CCartographer::buyMap (const CGHeroInstance *h, ui32 accept) const
}
}
void CShop::newTurn() const
{
switch (ID)
{
case 7: //ArtMerchant aka. Black Market
if (cb->getDate(0)%28 == 1)
{
cb->setObjProperty (id, 13, 0);
cb->setObjProperty (id, 14, rand());
}
break;
case 78: //Refugee Camp
case 95: //Tavern -- global hero pool?
if (cb->getDate(0)%7 == 1)
cb->setObjProperty (id, 14, rand());
break;
}
}
void CShop::setPropertyDer (ui8 what, ui32 val)
{
switch (what)
{
case 14: //reset - get new items
reset(val);
break;
}
}
void CGRefugeeCamp::reset(ui32 val)
{
creatureID = VLC->creh->creatures[val%VLC->creh->creatures.size()]->idNumber;
}
void CGDenOfthieves::onHeroVisit (const CGHeroInstance * h) const
{
cb->showThievesGuildWindow(id);

View File

@ -1089,37 +1089,6 @@ public:
h & static_cast<CPlayersVisited&>(*this);
h & players;
}
};
class DLL_EXPORT CShop : public CGObjectInstance
{
///base class for university, art merchant, slave market etc.
public:
void initObj() {};
void setPropertyDer (ui8 what, ui32 val);
void newTurn() const;
virtual void reset (ui32 val) {}; //get new items for Black Market, Tavern, Refugee Camp
virtual void onHeroVisit (const CGHeroInstance * h) const {};
virtual void trade (const CGHeroInstance * h) const {};
template <typename Handler> void serialize(Handler &h, const int version)
{
h & static_cast<CGObjectInstance&>(*this);
}
};
class DLL_EXPORT CGRefugeeCamp : public CShop
{
public:
ui16 creatureID;
void reset (ui32 val);
void onHeroVisit (const CGHeroInstance * h) const {};
template <typename Handler> void serialize(Handler &h, const int version)
{
h & creatureID & static_cast<CShop&>(*this);
}
};
class DLL_EXPORT CGDenOfthieves : public CGObjectInstance

View File

@ -933,12 +933,7 @@ std::pair<int,int> CGameState::pickObject (CGObjectInstance *obj)
}
case 71: //random monster
{
int r;
do
{
r = ran()%197;
} while (vstd::contains(VLC->creh->notUsedMonsters,r));
return std::pair<int,int>(54,r);
return std::pair<int,int>(54,VLC->creh->pickRandomMonster(boost::ref(ran)));
}
case 72: //random monster lvl1
return std::pair<int,int>(54,VLC->creh->levelCreatures[1][ran()%VLC->creh->levelCreatures[1].size()]->idNumber);

View File

@ -747,7 +747,7 @@ struct InfoWindow : public CPackForClient //103 - displays simple info window
namespace ObjProperty
{
//TODO: move non general properties out to the appropriate objs classes
enum {OWNER = 1, BLOCKVIS = 2, PRIMARY_STACK_COUNT = 3, VISITORS = 4, VISITED = 5, ID = 6};
enum {OWNER = 1, BLOCKVIS = 2, PRIMARY_STACK_COUNT = 3, VISITORS = 4, VISITED = 5, ID = 6, AVAILABLE_CREATURE = 7};
}
struct SetObjectProperty : public CPackForClient//1001

View File

@ -1678,6 +1678,7 @@ void Mapa::readObjects( const unsigned char * bufor, int &i)
i+=3;
break;
}
case 78: //Refugee Camp
case 106: //War Machine Factory
{
nobj = new CGDwelling();

View File

@ -2703,7 +2703,7 @@ bool CGameHandler::recruitCreatures( si32 objid, ui32 crid, ui32 cram, si32 from
if(dw->ID == TOWNI_TYPE)
dst = dw;
else if(dw->ID == 17 || dw->ID == 20) //advmap dwelling
else if(dw->ID == 17 || dw->ID == 20 || dw->ID == 78) //advmap dwelling
dst = getHero(gs->getPlayer(dw->tempOwner)->currentSelection); //TODO: check if current hero is really visiting dwelling
else if(dw->ID == 106)
dst = dynamic_cast<const CGHeroInstance *>(getTile(dw->visitablePos())->visitableObjects.back());